// @(#)root/graf:$Id$
// Author: Otto Schaile   20/11/99

/*************************************************************************
 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

//______________________________________________________________________________
//
// This class implements curly or wavy polylines typically used to draw Feynman diagrams.
// Amplitudes and wavelengths may be specified in the constructors,
// via commands or interactively from popup menus.
// The class make use of TPolyLine by inheritance, ExecuteEvent methods
// are highly inspired from the methods used in TPolyLine and TArc.
// The picture below has been generated by the tutorial feynman.
//Begin_Html
/*
<img src="gif/feynman.gif">
*/
//End_Html
//______________________________________________________________________________

#include "Riostream.h"
#include "TCurlyLine.h"
#include "TROOT.h"
#include "TVirtualPad.h"
#include "TVirtualX.h"
#include "TMath.h"
#include "TLine.h"
#include "TPoint.h"

Double_t TCurlyLine::fgDefaultWaveLength = 0.02;
Double_t TCurlyLine::fgDefaultAmplitude  = 0.01;
Bool_t   TCurlyLine::fgDefaultIsCurly    = kTRUE;

ClassImp(TCurlyLine)


//______________________________________________________________________________
TCurlyLine::TCurlyLine()
{
   // Default constructor.

   fX1         = 0.;
   fY1         = 0.;
   fX2         = 0.;
   fY2         = 0.;
   fWaveLength = 0.;
   fAmplitude  = 0.;
   fIsCurly    = fgDefaultIsCurly;
   fNsteps     = 0;
}


//______________________________________________________________________________
TCurlyLine::TCurlyLine(Double_t x1, Double_t y1, Double_t x2, Double_t y2, Double_t wl, Double_t amp)
{
   // Create a new TCurlyLine with starting point (x1, y1), end point (x2,y2).
   // The wavelength and amplitude are given in percent of the pad height.

   fX1         = x1;
   fY1         = y1;
   fX2         = x2;
   fY2         = y2;
   fWaveLength = wl;
   fAmplitude  = amp;
   fIsCurly    = fgDefaultIsCurly;
   Build();
}


//______________________________________________________________________________
void TCurlyLine::Build()
{
   // Create a curly (Gluon) or wavy (Gamma) line.

   Double_t pixeltoX = 1;
   Double_t pixeltoY = 1;

   Double_t wavelengthPix,amplitudePix, lengthPix, hPix;
   Double_t px1, py1, px2, py2;
   if (gPad) {
      Double_t ww = (Double_t)gPad->GetWw();
      Double_t wh = (Double_t)gPad->GetWh();
      Double_t pxrange = gPad->GetAbsWNDC()*ww;
      Double_t pyrange = - gPad->GetAbsHNDC()*wh;
      Double_t xrange  = gPad->GetX2() - gPad->GetX1();
      Double_t yrange  = gPad->GetY2() - gPad->GetY1();
      pixeltoX  = xrange / pxrange;
      pixeltoY  = yrange/pyrange;
      hPix  = TMath::Max(gPad->GetAbsHNDC() * gPad->GetWh(), gPad->GetAbsWNDC() * gPad->GetWw());
      px1      = gPad->XtoAbsPixel(fX1);
      py1      = gPad->YtoAbsPixel(fY1);
      px2      = gPad->XtoAbsPixel(fX2);
      py2      = gPad->YtoAbsPixel(fY2);

      lengthPix = TMath::Sqrt((px2-px1)*(px2-px1) + (py1-py2)*(py1-py2));
      wavelengthPix = hPix*fWaveLength;
      amplitudePix  = hPix*fAmplitude;
   } else {
      wavelengthPix = fWaveLength;
      amplitudePix  = fAmplitude;
      px1           = fX1;
      py1           = fY1;
      px2           = fX2;
      py2           = fY2;
      lengthPix = TMath::Sqrt((px2-px1)*(px2-px1) + (py1-py2)*(py1-py2));
   }
   // construct the curly / wavy line in pixel coordinates at angle 0
   Double_t anglestep = 40;
   Double_t phimaxle  = TMath::Pi() * 2. / anglestep ;
   Double_t dx        = wavelengthPix / 40;
   Double_t len2pi    = dx * anglestep;

   // make sure there is a piece of straight line a both ends

   Double_t  lengthcycle = 0.5 * len2pi + 2 * amplitudePix;
   // if (fIsCurly) lengthcycle +=  amplitudePix;
   Int_t nperiods = (Int_t)((lengthPix - lengthcycle) / len2pi);
   Double_t restlength = 0.5 * (lengthPix - nperiods * len2pi - lengthcycle);
   fNsteps = (Int_t)(anglestep * nperiods + anglestep / 2 + 4);
   if (fNsteps < 1) fNsteps = 1;
   SetPolyLine(fNsteps);
   Double_t *xv = GetX();
   Double_t *yv = GetY();
   xv[0] = 0;          yv[0] = 0;
   xv[1] = restlength; yv[1] = 0;
   Double_t phase =  1.5 * TMath::Pi();
   Double_t x0 = amplitudePix + restlength;
   Int_t i;
   for(i = 2; i < fNsteps-1; i++){
   // distinguish between curly and wavy
      if (fIsCurly) xv[i] = x0 + amplitudePix * TMath::Sin(phase);
      else         xv[i] = x0;
      yv[i]  = amplitudePix*TMath::Cos(phase);
      phase += phimaxle;
      x0    += dx;
   }
   xv[fNsteps-1] = lengthPix; yv[fNsteps-1] = 0;

   if (InheritsFrom("TCurlyArc")) return;  // called by TCurlyArc

   // rotate object and transform back to user coordinates
   Double_t angle = TMath::ATan2(py2-py1, px2-px1);
   if (angle < 0) angle += 2*TMath::Pi();

   Double_t cosang = TMath::Cos(angle);
   Double_t sinang = TMath::Sin(angle);
   Double_t xx, yy;

   for(i = 0; i < fNsteps; i++){
      xx = xv[i] * cosang - yv[i] * sinang;
      yy = xv[i] * sinang + yv[i] * cosang;
      if (gPad) {
         xx *= pixeltoX;
         yy *= pixeltoY;
      }
      xv[i] = xx + fX1;
      yv[i] = yy + fY1;
   }
   if (gPad) gPad->Modified();
}


//______________________________________________________________________________
Int_t TCurlyLine::DistancetoPrimitive(Int_t px, Int_t py)
{
   // Compute distance from point px,py to a line.

   return DistancetoLine(px,py,fX1,fY1,fX2,fY2);
}


//______________________________________________________________________________
void TCurlyLine::ExecuteEvent(Int_t event, Int_t px, Int_t py)
{
   // Execute action corresponding to one event.
   //
   //  This member function is called when a  TCurlyLine is clicked with the locator
   //
   //  If Left button clicked on one of the line end points, this point
   //     follows the cursor until button is released.
   //
   //  if Middle button clicked, the line is moved parallel to itself
   //     until the button is released.
   //

   Int_t kMaxDiff = 20;
   static Int_t d1,d2,px1,px2,py1,py2;
   static Int_t pxold, pyold, px1old, py1old, px2old, py2old;
   static Bool_t p1, p2, pL;
   Int_t dx, dy;

   Bool_t opaque  = gPad->OpaqueMoving();

   switch (event) {

   case kArrowKeyPress:
   case kButton1Down:
      if (!opaque) {
         gVirtualX->SetLineColor(-1);
         TAttLine::Modify();  //Change line attributes only if necessary
      }

      // No break !!!

   case kMouseMotion:

      px1 = gPad->XtoAbsPixel(fX1);
      py1 = gPad->YtoAbsPixel(fY1);
      px2 = gPad->XtoAbsPixel(fX2);
      py2 = gPad->YtoAbsPixel(fY2);

      p1 = p2 = pL = kFALSE;

      d1  = TMath::Abs(px1 - px) + TMath::Abs(py1-py); //simply take sum of pixels differences
      if (d1 < kMaxDiff) { //*-*================>OK take point number 1
         px1old = px1; py1old = py1;
         p1 = kTRUE;
         gPad->SetCursor(kPointer);
         return;
      }
      d2  = TMath::Abs(px2 - px) + TMath::Abs(py2-py); //simply take sum of pixels differences
      if (d2 < kMaxDiff) { //*-*================>OK take point number 2
         px2old = px2; py2old = py2;
         p2 = kTRUE;
         gPad->SetCursor(kPointer);
         return;
      }

      pL = kTRUE;
      pxold = px; pyold = py;
      gPad->SetCursor(kMove);

      break;

   case kArrowKeyRelease:
   case kButton1Motion:

      if (p1) {
         if (!opaque) {
            gVirtualX->DrawLine(px1old, py1old, px2, py2);
            gVirtualX->DrawLine(px, py, px2, py2);
         }
         else this->SetStartPoint(gPad->AbsPixeltoX(px),gPad->AbsPixeltoY(py));
         px1old = px;
         py1old = py;
      }
      if (p2) {
         if (!opaque) {
            gVirtualX->DrawLine(px1, py1, px2old, py2old);
            gVirtualX->DrawLine(px1, py1, px, py);
         }
         else this->SetEndPoint(gPad->AbsPixeltoX(px), gPad->AbsPixeltoY(py));
         px2old = px;
         py2old = py;
      }
      if (pL) {
         if (!opaque) gVirtualX->DrawLine(px1, py1, px2, py2);
         dx = px-pxold;  dy = py-pyold;
         px1 += dx; py1 += dy; px2 += dx; py2 += dy;
         if (!opaque) gVirtualX->DrawLine(px1, py1, px2, py2);
         pxold = px;
         pyold = py;
         if (opaque) {
            this->SetStartPoint(gPad->AbsPixeltoX(px1),gPad->AbsPixeltoY(py1));
            this->SetEndPoint(gPad->AbsPixeltoX(px2), gPad->AbsPixeltoY(py2));
         }
      }

      if (opaque) {
         if (p1) {
            //check in which corner the BBox is eddited
            if (fX1>fX2) {
               if (fY1>fY2)
                  gPad->ShowGuidelines(this, event, '2', true);
               else
                  gPad->ShowGuidelines(this, event, '3', true);
            }
            else {
               if (fY1>fY2)
                  gPad->ShowGuidelines(this, event, '1', true);
               else
                  gPad->ShowGuidelines(this, event, '4', true);
            }
         }
         if (p2) {
            //check in which corner the BBox is eddited
            if (fX1>fX2) {
               if (fY1>fY2)
                  gPad->ShowGuidelines(this, event, '4', true);
               else
                  gPad->ShowGuidelines(this, event, '1', true);
            }
            else {
               if (fY1>fY2)
                  gPad->ShowGuidelines(this, event, '3', true);
               else
                  gPad->ShowGuidelines(this, event, '2', true);
            }
         }
         if (pL) {
            gPad->ShowGuidelines(this, event, 'i', true);
         }
         gPad->Modified(kTRUE);
         gPad->Update();
      }
      break;

   case kButton1Up:

      if (opaque) {
         gPad->ShowGuidelines(this, event);
      } else {   
         if (p1) {
            fX1 = gPad->AbsPixeltoX(px);
            fY1 = gPad->AbsPixeltoY(py);
         }
         if (p2) {
            fX2 = gPad->AbsPixeltoX(px);
            fY2 = gPad->AbsPixeltoY(py);
         }
         if (pL) {
            fX1 = gPad->AbsPixeltoX(px1);
            fY1 = gPad->AbsPixeltoY(py1);
            fX2 = gPad->AbsPixeltoX(px2);
            fY2 = gPad->AbsPixeltoY(py2);
         }
      }
      Build();
      gPad->Modified();
      if (!opaque) gVirtualX->SetLineColor(-1);
   }
}


//______________________________________________________________________________
void TCurlyLine::SavePrimitive(std::ostream &out, Option_t * /*= ""*/)
{
   // Save primitive as a C++ statement(s) on output stream out

   if (gROOT->ClassSaved(TCurlyLine::Class())) {
      out<<"   ";
   } else {
      out<<"   TCurlyLine *";
   }
   out<<"curlyline = new TCurlyLine("
     <<fX1<<","<<fY1<<","<<fX2<<","<<fY2<<","
     <<fWaveLength<<","<<fAmplitude<<");"<<std::endl;
   if (!fIsCurly) {
      out<<"   curlyline->SetWavy();"<<std::endl;
   }
   SaveLineAttributes(out,"curlyline",1,1,1);
   out<<"   curlyline->Draw();"<<std::endl;
}


//______________________________________________________________________________
void TCurlyLine::SetCurly()
{
   // Set curly.

   fIsCurly = kTRUE;
   Build();
}


//______________________________________________________________________________
void TCurlyLine::SetWavy()
{
   // Set wavy.

   fIsCurly = kFALSE;
   Build();
}


//______________________________________________________________________________
void TCurlyLine::SetWaveLength(Double_t x)
{
   // Set wave length.

   fWaveLength = x;
   Build();
}


//______________________________________________________________________________
void TCurlyLine::SetAmplitude(Double_t x)
{
   // Set amplitude.

   fAmplitude = x;
   Build();
}


//______________________________________________________________________________
void TCurlyLine::SetStartPoint(Double_t x, Double_t y)
{
   // Set start point.

   fX1 = x;
   fY1 = y;
   Build();
}


//______________________________________________________________________________
void TCurlyLine::SetEndPoint(Double_t x, Double_t y)
{
   // Set edn point.

   fX2 = x;
   fY2 = y;
   Build();
}


//______________________________________________________________________________
void TCurlyLine::SetDefaultWaveLength(Double_t WaveLength)
{
   // Set default wave length.

   fgDefaultWaveLength = WaveLength;
}


//______________________________________________________________________________
void TCurlyLine::SetDefaultAmplitude(Double_t Amplitude)
{
   // Set default amplitude.

   fgDefaultAmplitude  = Amplitude;
}


//______________________________________________________________________________
void TCurlyLine::SetDefaultIsCurly(Bool_t IsCurly)
{
   // Set defaul "IsCurly".

   fgDefaultIsCurly    = IsCurly;
}


//______________________________________________________________________________
Double_t TCurlyLine::GetDefaultWaveLength()
{
   // Get default wave length.

   return fgDefaultWaveLength;
}


//______________________________________________________________________________
Double_t TCurlyLine::GetDefaultAmplitude()
{
   // Get default amplitude.

   return fgDefaultAmplitude;
}


//______________________________________________________________________________
Bool_t TCurlyLine::GetDefaultIsCurly()
{
   // Get default "IsCurly".

   return fgDefaultIsCurly;
}

//______________________________________________________________________________
Rectangle_t TCurlyLine::GetBBox()
{
   // Return the bounding Box of the CurlyLine

   Rectangle_t BBox;
   Int_t px1, py1, px2, py2;
   px1 = gPad->XtoPixel(fX1);
   px2 = gPad->XtoPixel(fX2);
   py1 = gPad->YtoPixel(fY1);
   py2 = gPad->YtoPixel(fY2);
   
   Int_t tmp;
   if (px1>px2) { tmp = px1; px1 = px2; px2 = tmp;}
   if (py1>py2) { tmp = py1; py1 = py2; py2 = tmp;}
   
   BBox.fX = px1;
   BBox.fY = py1;
   BBox.fWidth = px2-px1; 
   BBox.fHeight = py2-py1;

   return (BBox);
}

//______________________________________________________________________________
TPoint TCurlyLine::GetBBoxCenter()
{
   // Return the center of the BoundingBox as TPoint in pixels

   TPoint p;
   p.SetX(gPad->XtoPixel(TMath::Min(fX1,fX2)+0.5*(TMath::Max(fX1, fX2)-TMath::Min(fX1, fX2))));
   p.SetY(gPad->YtoPixel(TMath::Min(fY1,fY2)+0.5*(TMath::Max(fY1, fY2)-TMath::Min(fY1, fY2))));
   return(p);
}

//______________________________________________________________________________
void TCurlyLine::SetBBoxCenter(const TPoint &p)
{
   // Set center of the BoundingBox

   Double_t w = TMath::Max(fX1, fX2)-TMath::Min(fX1, fX2);
   Double_t h = TMath::Max(fY1, fY2)-TMath::Min(fY1, fY2);
   Double_t x1, x2, y1, y2;
   x1 = x2 = y1 = y2 = 0;

   if (fX2>fX1) {
      x1 = gPad->PixeltoX(p.GetX())-0.5*w;
      x2 = gPad->PixeltoX(p.GetX())+0.5*w;
   }
   else {
      x2 = gPad->PixeltoX(p.GetX())-0.5*w;
      x1 = gPad->PixeltoX(p.GetX())+0.5*w;
   }
   if (fY2>fY1) {
      y1 = gPad->PixeltoY(p.GetY()-gPad->VtoPixel(0))-0.5*h;
      y2 = gPad->PixeltoY(p.GetY()-gPad->VtoPixel(0))+0.5*h;
   }
   else {
      y2 = gPad->PixeltoY(p.GetY()-gPad->VtoPixel(0))-0.5*h;
      y1 = gPad->PixeltoY(p.GetY()-gPad->VtoPixel(0))+0.5*h;
   }
   this->SetStartPoint(x1, y1);
   this->SetEndPoint(x2, y2);
}

//______________________________________________________________________________
void TCurlyLine::SetBBoxCenterX(const Int_t x)
{
   // Set X coordinate of the center of the BoundingBox

   Double_t w = TMath::Max(fX1, fX2)-TMath::Min(fX1, fX2);
   if (fX2>fX1) {
      this->SetStartPoint(gPad->PixeltoX(x)-0.5*w, fY1);
      this->SetEndPoint(gPad->PixeltoX(x)+0.5*w, fY2);
   }
   else {
      this->SetEndPoint(gPad->PixeltoX(x)-0.5*w, fY2);
      this->SetStartPoint(gPad->PixeltoX(x)+0.5*w, fY1);
   }
}

//______________________________________________________________________________
void TCurlyLine::SetBBoxCenterY(const Int_t y)
{
   // Set Y coordinate of the center of the BoundingBox

   Double_t h = TMath::Max(fY1, fY2)-TMath::Min(fY1, fY2);
   if (fY2>fY1) {
      this->SetStartPoint(fX1, gPad->PixeltoY(y-gPad->VtoPixel(0))-0.5*h);
      this->SetEndPoint(fX2, gPad->PixeltoY(y-gPad->VtoPixel(0))+0.5*h);
   }
   else {
      this->SetEndPoint(fX2, gPad->PixeltoY(y-gPad->VtoPixel(0))-0.5*h);
      this->SetStartPoint(fX1, gPad->PixeltoY(y-gPad->VtoPixel(0))+0.5*h);
   }
}

//______________________________________________________________________________
void TCurlyLine::SetBBoxX1(const Int_t x)
{
   // Set lefthandside of BoundingBox to a value
   // (resize in x direction on left)

   if (fX2>fX1)
      this->SetStartPoint(gPad->PixeltoX(x), fY1);
   else
      this->SetEndPoint(gPad->PixeltoX(x), fY2);
}

//______________________________________________________________________________
void TCurlyLine::SetBBoxX2(const Int_t x)
{
   // Set righthandside of BoundingBox to a value
   // (resize in x direction on right)

   if (fX2>fX1)
      this->SetEndPoint(gPad->PixeltoX(x), fY2);
   else
      this->SetStartPoint(gPad->PixeltoX(x), fY1);
}

//_______________________________________________________________________________
void TCurlyLine::SetBBoxY1(const Int_t y)
{
   // Set top of BoundingBox to a value (resize in y direction on top)

   if (fY2>fY1)
      this->SetEndPoint(fX2, gPad->PixeltoY(y - gPad->VtoPixel(0)));
   else
      this->SetStartPoint(fX1, gPad->PixeltoY(y - gPad->VtoPixel(0)));
}

//_______________________________________________________________________________
void TCurlyLine::SetBBoxY2(const Int_t y)
{
   // Set bottom of BoundingBox to a value
   // (resize in y direction on bottom)

   if (fY2>fY1)
      this->SetStartPoint(fX1, gPad->PixeltoY(y - gPad->VtoPixel(0)));
   else
      this->SetEndPoint(fX2, gPad->PixeltoY(y - gPad->VtoPixel(0)));
}
 TCurlyLine.cxx:1
 TCurlyLine.cxx:2
 TCurlyLine.cxx:3
 TCurlyLine.cxx:4
 TCurlyLine.cxx:5
 TCurlyLine.cxx:6
 TCurlyLine.cxx:7
 TCurlyLine.cxx:8
 TCurlyLine.cxx:9
 TCurlyLine.cxx:10
 TCurlyLine.cxx:11
 TCurlyLine.cxx:12
 TCurlyLine.cxx:13
 TCurlyLine.cxx:14
 TCurlyLine.cxx:15
 TCurlyLine.cxx:16
 TCurlyLine.cxx:17
 TCurlyLine.cxx:18
 TCurlyLine.cxx:19
 TCurlyLine.cxx:20
 TCurlyLine.cxx:21
 TCurlyLine.cxx:22
 TCurlyLine.cxx:23
 TCurlyLine.cxx:24
 TCurlyLine.cxx:25
 TCurlyLine.cxx:26
 TCurlyLine.cxx:27
 TCurlyLine.cxx:28
 TCurlyLine.cxx:29
 TCurlyLine.cxx:30
 TCurlyLine.cxx:31
 TCurlyLine.cxx:32
 TCurlyLine.cxx:33
 TCurlyLine.cxx:34
 TCurlyLine.cxx:35
 TCurlyLine.cxx:36
 TCurlyLine.cxx:37
 TCurlyLine.cxx:38
 TCurlyLine.cxx:39
 TCurlyLine.cxx:40
 TCurlyLine.cxx:41
 TCurlyLine.cxx:42
 TCurlyLine.cxx:43
 TCurlyLine.cxx:44
 TCurlyLine.cxx:45
 TCurlyLine.cxx:46
 TCurlyLine.cxx:47
 TCurlyLine.cxx:48
 TCurlyLine.cxx:49
 TCurlyLine.cxx:50
 TCurlyLine.cxx:51
 TCurlyLine.cxx:52
 TCurlyLine.cxx:53
 TCurlyLine.cxx:54
 TCurlyLine.cxx:55
 TCurlyLine.cxx:56
 TCurlyLine.cxx:57
 TCurlyLine.cxx:58
 TCurlyLine.cxx:59
 TCurlyLine.cxx:60
 TCurlyLine.cxx:61
 TCurlyLine.cxx:62
 TCurlyLine.cxx:63
 TCurlyLine.cxx:64
 TCurlyLine.cxx:65
 TCurlyLine.cxx:66
 TCurlyLine.cxx:67
 TCurlyLine.cxx:68
 TCurlyLine.cxx:69
 TCurlyLine.cxx:70
 TCurlyLine.cxx:71
 TCurlyLine.cxx:72
 TCurlyLine.cxx:73
 TCurlyLine.cxx:74
 TCurlyLine.cxx:75
 TCurlyLine.cxx:76
 TCurlyLine.cxx:77
 TCurlyLine.cxx:78
 TCurlyLine.cxx:79
 TCurlyLine.cxx:80
 TCurlyLine.cxx:81
 TCurlyLine.cxx:82
 TCurlyLine.cxx:83
 TCurlyLine.cxx:84
 TCurlyLine.cxx:85
 TCurlyLine.cxx:86
 TCurlyLine.cxx:87
 TCurlyLine.cxx:88
 TCurlyLine.cxx:89
 TCurlyLine.cxx:90
 TCurlyLine.cxx:91
 TCurlyLine.cxx:92
 TCurlyLine.cxx:93
 TCurlyLine.cxx:94
 TCurlyLine.cxx:95
 TCurlyLine.cxx:96
 TCurlyLine.cxx:97
 TCurlyLine.cxx:98
 TCurlyLine.cxx:99
 TCurlyLine.cxx:100
 TCurlyLine.cxx:101
 TCurlyLine.cxx:102
 TCurlyLine.cxx:103
 TCurlyLine.cxx:104
 TCurlyLine.cxx:105
 TCurlyLine.cxx:106
 TCurlyLine.cxx:107
 TCurlyLine.cxx:108
 TCurlyLine.cxx:109
 TCurlyLine.cxx:110
 TCurlyLine.cxx:111
 TCurlyLine.cxx:112
 TCurlyLine.cxx:113
 TCurlyLine.cxx:114
 TCurlyLine.cxx:115
 TCurlyLine.cxx:116
 TCurlyLine.cxx:117
 TCurlyLine.cxx:118
 TCurlyLine.cxx:119
 TCurlyLine.cxx:120
 TCurlyLine.cxx:121
 TCurlyLine.cxx:122
 TCurlyLine.cxx:123
 TCurlyLine.cxx:124
 TCurlyLine.cxx:125
 TCurlyLine.cxx:126
 TCurlyLine.cxx:127
 TCurlyLine.cxx:128
 TCurlyLine.cxx:129
 TCurlyLine.cxx:130
 TCurlyLine.cxx:131
 TCurlyLine.cxx:132
 TCurlyLine.cxx:133
 TCurlyLine.cxx:134
 TCurlyLine.cxx:135
 TCurlyLine.cxx:136
 TCurlyLine.cxx:137
 TCurlyLine.cxx:138
 TCurlyLine.cxx:139
 TCurlyLine.cxx:140
 TCurlyLine.cxx:141
 TCurlyLine.cxx:142
 TCurlyLine.cxx:143
 TCurlyLine.cxx:144
 TCurlyLine.cxx:145
 TCurlyLine.cxx:146
 TCurlyLine.cxx:147
 TCurlyLine.cxx:148
 TCurlyLine.cxx:149
 TCurlyLine.cxx:150
 TCurlyLine.cxx:151
 TCurlyLine.cxx:152
 TCurlyLine.cxx:153
 TCurlyLine.cxx:154
 TCurlyLine.cxx:155
 TCurlyLine.cxx:156
 TCurlyLine.cxx:157
 TCurlyLine.cxx:158
 TCurlyLine.cxx:159
 TCurlyLine.cxx:160
 TCurlyLine.cxx:161
 TCurlyLine.cxx:162
 TCurlyLine.cxx:163
 TCurlyLine.cxx:164
 TCurlyLine.cxx:165
 TCurlyLine.cxx:166
 TCurlyLine.cxx:167
 TCurlyLine.cxx:168
 TCurlyLine.cxx:169
 TCurlyLine.cxx:170
 TCurlyLine.cxx:171
 TCurlyLine.cxx:172
 TCurlyLine.cxx:173
 TCurlyLine.cxx:174
 TCurlyLine.cxx:175
 TCurlyLine.cxx:176
 TCurlyLine.cxx:177
 TCurlyLine.cxx:178
 TCurlyLine.cxx:179
 TCurlyLine.cxx:180
 TCurlyLine.cxx:181
 TCurlyLine.cxx:182
 TCurlyLine.cxx:183
 TCurlyLine.cxx:184
 TCurlyLine.cxx:185
 TCurlyLine.cxx:186
 TCurlyLine.cxx:187
 TCurlyLine.cxx:188
 TCurlyLine.cxx:189
 TCurlyLine.cxx:190
 TCurlyLine.cxx:191
 TCurlyLine.cxx:192
 TCurlyLine.cxx:193
 TCurlyLine.cxx:194
 TCurlyLine.cxx:195
 TCurlyLine.cxx:196
 TCurlyLine.cxx:197
 TCurlyLine.cxx:198
 TCurlyLine.cxx:199
 TCurlyLine.cxx:200
 TCurlyLine.cxx:201
 TCurlyLine.cxx:202
 TCurlyLine.cxx:203
 TCurlyLine.cxx:204
 TCurlyLine.cxx:205
 TCurlyLine.cxx:206
 TCurlyLine.cxx:207
 TCurlyLine.cxx:208
 TCurlyLine.cxx:209
 TCurlyLine.cxx:210
 TCurlyLine.cxx:211
 TCurlyLine.cxx:212
 TCurlyLine.cxx:213
 TCurlyLine.cxx:214
 TCurlyLine.cxx:215
 TCurlyLine.cxx:216
 TCurlyLine.cxx:217
 TCurlyLine.cxx:218
 TCurlyLine.cxx:219
 TCurlyLine.cxx:220
 TCurlyLine.cxx:221
 TCurlyLine.cxx:222
 TCurlyLine.cxx:223
 TCurlyLine.cxx:224
 TCurlyLine.cxx:225
 TCurlyLine.cxx:226
 TCurlyLine.cxx:227
 TCurlyLine.cxx:228
 TCurlyLine.cxx:229
 TCurlyLine.cxx:230
 TCurlyLine.cxx:231
 TCurlyLine.cxx:232
 TCurlyLine.cxx:233
 TCurlyLine.cxx:234
 TCurlyLine.cxx:235
 TCurlyLine.cxx:236
 TCurlyLine.cxx:237
 TCurlyLine.cxx:238
 TCurlyLine.cxx:239
 TCurlyLine.cxx:240
 TCurlyLine.cxx:241
 TCurlyLine.cxx:242
 TCurlyLine.cxx:243
 TCurlyLine.cxx:244
 TCurlyLine.cxx:245
 TCurlyLine.cxx:246
 TCurlyLine.cxx:247
 TCurlyLine.cxx:248
 TCurlyLine.cxx:249
 TCurlyLine.cxx:250
 TCurlyLine.cxx:251
 TCurlyLine.cxx:252
 TCurlyLine.cxx:253
 TCurlyLine.cxx:254
 TCurlyLine.cxx:255
 TCurlyLine.cxx:256
 TCurlyLine.cxx:257
 TCurlyLine.cxx:258
 TCurlyLine.cxx:259
 TCurlyLine.cxx:260
 TCurlyLine.cxx:261
 TCurlyLine.cxx:262
 TCurlyLine.cxx:263
 TCurlyLine.cxx:264
 TCurlyLine.cxx:265
 TCurlyLine.cxx:266
 TCurlyLine.cxx:267
 TCurlyLine.cxx:268
 TCurlyLine.cxx:269
 TCurlyLine.cxx:270
 TCurlyLine.cxx:271
 TCurlyLine.cxx:272
 TCurlyLine.cxx:273
 TCurlyLine.cxx:274
 TCurlyLine.cxx:275
 TCurlyLine.cxx:276
 TCurlyLine.cxx:277
 TCurlyLine.cxx:278
 TCurlyLine.cxx:279
 TCurlyLine.cxx:280
 TCurlyLine.cxx:281
 TCurlyLine.cxx:282
 TCurlyLine.cxx:283
 TCurlyLine.cxx:284
 TCurlyLine.cxx:285
 TCurlyLine.cxx:286
 TCurlyLine.cxx:287
 TCurlyLine.cxx:288
 TCurlyLine.cxx:289
 TCurlyLine.cxx:290
 TCurlyLine.cxx:291
 TCurlyLine.cxx:292
 TCurlyLine.cxx:293
 TCurlyLine.cxx:294
 TCurlyLine.cxx:295
 TCurlyLine.cxx:296
 TCurlyLine.cxx:297
 TCurlyLine.cxx:298
 TCurlyLine.cxx:299
 TCurlyLine.cxx:300
 TCurlyLine.cxx:301
 TCurlyLine.cxx:302
 TCurlyLine.cxx:303
 TCurlyLine.cxx:304
 TCurlyLine.cxx:305
 TCurlyLine.cxx:306
 TCurlyLine.cxx:307
 TCurlyLine.cxx:308
 TCurlyLine.cxx:309
 TCurlyLine.cxx:310
 TCurlyLine.cxx:311
 TCurlyLine.cxx:312
 TCurlyLine.cxx:313
 TCurlyLine.cxx:314
 TCurlyLine.cxx:315
 TCurlyLine.cxx:316
 TCurlyLine.cxx:317
 TCurlyLine.cxx:318
 TCurlyLine.cxx:319
 TCurlyLine.cxx:320
 TCurlyLine.cxx:321
 TCurlyLine.cxx:322
 TCurlyLine.cxx:323
 TCurlyLine.cxx:324
 TCurlyLine.cxx:325
 TCurlyLine.cxx:326
 TCurlyLine.cxx:327
 TCurlyLine.cxx:328
 TCurlyLine.cxx:329
 TCurlyLine.cxx:330
 TCurlyLine.cxx:331
 TCurlyLine.cxx:332
 TCurlyLine.cxx:333
 TCurlyLine.cxx:334
 TCurlyLine.cxx:335
 TCurlyLine.cxx:336
 TCurlyLine.cxx:337
 TCurlyLine.cxx:338
 TCurlyLine.cxx:339
 TCurlyLine.cxx:340
 TCurlyLine.cxx:341
 TCurlyLine.cxx:342
 TCurlyLine.cxx:343
 TCurlyLine.cxx:344
 TCurlyLine.cxx:345
 TCurlyLine.cxx:346
 TCurlyLine.cxx:347
 TCurlyLine.cxx:348
 TCurlyLine.cxx:349
 TCurlyLine.cxx:350
 TCurlyLine.cxx:351
 TCurlyLine.cxx:352
 TCurlyLine.cxx:353
 TCurlyLine.cxx:354
 TCurlyLine.cxx:355
 TCurlyLine.cxx:356
 TCurlyLine.cxx:357
 TCurlyLine.cxx:358
 TCurlyLine.cxx:359
 TCurlyLine.cxx:360
 TCurlyLine.cxx:361
 TCurlyLine.cxx:362
 TCurlyLine.cxx:363
 TCurlyLine.cxx:364
 TCurlyLine.cxx:365
 TCurlyLine.cxx:366
 TCurlyLine.cxx:367
 TCurlyLine.cxx:368
 TCurlyLine.cxx:369
 TCurlyLine.cxx:370
 TCurlyLine.cxx:371
 TCurlyLine.cxx:372
 TCurlyLine.cxx:373
 TCurlyLine.cxx:374
 TCurlyLine.cxx:375
 TCurlyLine.cxx:376
 TCurlyLine.cxx:377
 TCurlyLine.cxx:378
 TCurlyLine.cxx:379
 TCurlyLine.cxx:380
 TCurlyLine.cxx:381
 TCurlyLine.cxx:382
 TCurlyLine.cxx:383
 TCurlyLine.cxx:384
 TCurlyLine.cxx:385
 TCurlyLine.cxx:386
 TCurlyLine.cxx:387
 TCurlyLine.cxx:388
 TCurlyLine.cxx:389
 TCurlyLine.cxx:390
 TCurlyLine.cxx:391
 TCurlyLine.cxx:392
 TCurlyLine.cxx:393
 TCurlyLine.cxx:394
 TCurlyLine.cxx:395
 TCurlyLine.cxx:396
 TCurlyLine.cxx:397
 TCurlyLine.cxx:398
 TCurlyLine.cxx:399
 TCurlyLine.cxx:400
 TCurlyLine.cxx:401
 TCurlyLine.cxx:402
 TCurlyLine.cxx:403
 TCurlyLine.cxx:404
 TCurlyLine.cxx:405
 TCurlyLine.cxx:406
 TCurlyLine.cxx:407
 TCurlyLine.cxx:408
 TCurlyLine.cxx:409
 TCurlyLine.cxx:410
 TCurlyLine.cxx:411
 TCurlyLine.cxx:412
 TCurlyLine.cxx:413
 TCurlyLine.cxx:414
 TCurlyLine.cxx:415
 TCurlyLine.cxx:416
 TCurlyLine.cxx:417
 TCurlyLine.cxx:418
 TCurlyLine.cxx:419
 TCurlyLine.cxx:420
 TCurlyLine.cxx:421
 TCurlyLine.cxx:422
 TCurlyLine.cxx:423
 TCurlyLine.cxx:424
 TCurlyLine.cxx:425
 TCurlyLine.cxx:426
 TCurlyLine.cxx:427
 TCurlyLine.cxx:428
 TCurlyLine.cxx:429
 TCurlyLine.cxx:430
 TCurlyLine.cxx:431
 TCurlyLine.cxx:432
 TCurlyLine.cxx:433
 TCurlyLine.cxx:434
 TCurlyLine.cxx:435
 TCurlyLine.cxx:436
 TCurlyLine.cxx:437
 TCurlyLine.cxx:438
 TCurlyLine.cxx:439
 TCurlyLine.cxx:440
 TCurlyLine.cxx:441
 TCurlyLine.cxx:442
 TCurlyLine.cxx:443
 TCurlyLine.cxx:444
 TCurlyLine.cxx:445
 TCurlyLine.cxx:446
 TCurlyLine.cxx:447
 TCurlyLine.cxx:448
 TCurlyLine.cxx:449
 TCurlyLine.cxx:450
 TCurlyLine.cxx:451
 TCurlyLine.cxx:452
 TCurlyLine.cxx:453
 TCurlyLine.cxx:454
 TCurlyLine.cxx:455
 TCurlyLine.cxx:456
 TCurlyLine.cxx:457
 TCurlyLine.cxx:458
 TCurlyLine.cxx:459
 TCurlyLine.cxx:460
 TCurlyLine.cxx:461
 TCurlyLine.cxx:462
 TCurlyLine.cxx:463
 TCurlyLine.cxx:464
 TCurlyLine.cxx:465
 TCurlyLine.cxx:466
 TCurlyLine.cxx:467
 TCurlyLine.cxx:468
 TCurlyLine.cxx:469
 TCurlyLine.cxx:470
 TCurlyLine.cxx:471
 TCurlyLine.cxx:472
 TCurlyLine.cxx:473
 TCurlyLine.cxx:474
 TCurlyLine.cxx:475
 TCurlyLine.cxx:476
 TCurlyLine.cxx:477
 TCurlyLine.cxx:478
 TCurlyLine.cxx:479
 TCurlyLine.cxx:480
 TCurlyLine.cxx:481
 TCurlyLine.cxx:482
 TCurlyLine.cxx:483
 TCurlyLine.cxx:484
 TCurlyLine.cxx:485
 TCurlyLine.cxx:486
 TCurlyLine.cxx:487
 TCurlyLine.cxx:488
 TCurlyLine.cxx:489
 TCurlyLine.cxx:490
 TCurlyLine.cxx:491
 TCurlyLine.cxx:492
 TCurlyLine.cxx:493
 TCurlyLine.cxx:494
 TCurlyLine.cxx:495
 TCurlyLine.cxx:496
 TCurlyLine.cxx:497
 TCurlyLine.cxx:498
 TCurlyLine.cxx:499
 TCurlyLine.cxx:500
 TCurlyLine.cxx:501
 TCurlyLine.cxx:502
 TCurlyLine.cxx:503
 TCurlyLine.cxx:504
 TCurlyLine.cxx:505
 TCurlyLine.cxx:506
 TCurlyLine.cxx:507
 TCurlyLine.cxx:508
 TCurlyLine.cxx:509
 TCurlyLine.cxx:510
 TCurlyLine.cxx:511
 TCurlyLine.cxx:512
 TCurlyLine.cxx:513
 TCurlyLine.cxx:514
 TCurlyLine.cxx:515
 TCurlyLine.cxx:516
 TCurlyLine.cxx:517
 TCurlyLine.cxx:518
 TCurlyLine.cxx:519
 TCurlyLine.cxx:520
 TCurlyLine.cxx:521
 TCurlyLine.cxx:522
 TCurlyLine.cxx:523
 TCurlyLine.cxx:524
 TCurlyLine.cxx:525
 TCurlyLine.cxx:526
 TCurlyLine.cxx:527
 TCurlyLine.cxx:528
 TCurlyLine.cxx:529
 TCurlyLine.cxx:530
 TCurlyLine.cxx:531
 TCurlyLine.cxx:532
 TCurlyLine.cxx:533
 TCurlyLine.cxx:534
 TCurlyLine.cxx:535
 TCurlyLine.cxx:536
 TCurlyLine.cxx:537
 TCurlyLine.cxx:538
 TCurlyLine.cxx:539
 TCurlyLine.cxx:540
 TCurlyLine.cxx:541
 TCurlyLine.cxx:542
 TCurlyLine.cxx:543
 TCurlyLine.cxx:544
 TCurlyLine.cxx:545
 TCurlyLine.cxx:546
 TCurlyLine.cxx:547
 TCurlyLine.cxx:548
 TCurlyLine.cxx:549
 TCurlyLine.cxx:550
 TCurlyLine.cxx:551
 TCurlyLine.cxx:552
 TCurlyLine.cxx:553
 TCurlyLine.cxx:554
 TCurlyLine.cxx:555
 TCurlyLine.cxx:556
 TCurlyLine.cxx:557
 TCurlyLine.cxx:558
 TCurlyLine.cxx:559
 TCurlyLine.cxx:560
 TCurlyLine.cxx:561
 TCurlyLine.cxx:562
 TCurlyLine.cxx:563
 TCurlyLine.cxx:564
 TCurlyLine.cxx:565
 TCurlyLine.cxx:566
 TCurlyLine.cxx:567
 TCurlyLine.cxx:568
 TCurlyLine.cxx:569
 TCurlyLine.cxx:570
 TCurlyLine.cxx:571
 TCurlyLine.cxx:572
 TCurlyLine.cxx:573
 TCurlyLine.cxx:574
 TCurlyLine.cxx:575
 TCurlyLine.cxx:576
 TCurlyLine.cxx:577
 TCurlyLine.cxx:578
 TCurlyLine.cxx:579
 TCurlyLine.cxx:580
 TCurlyLine.cxx:581
 TCurlyLine.cxx:582
 TCurlyLine.cxx:583
 TCurlyLine.cxx:584
 TCurlyLine.cxx:585
 TCurlyLine.cxx:586
 TCurlyLine.cxx:587
 TCurlyLine.cxx:588
 TCurlyLine.cxx:589
 TCurlyLine.cxx:590
 TCurlyLine.cxx:591
 TCurlyLine.cxx:592
 TCurlyLine.cxx:593
 TCurlyLine.cxx:594
 TCurlyLine.cxx:595
 TCurlyLine.cxx:596
 TCurlyLine.cxx:597
 TCurlyLine.cxx:598
 TCurlyLine.cxx:599
 TCurlyLine.cxx:600
 TCurlyLine.cxx:601
 TCurlyLine.cxx:602
 TCurlyLine.cxx:603
 TCurlyLine.cxx:604
 TCurlyLine.cxx:605
 TCurlyLine.cxx:606
 TCurlyLine.cxx:607
 TCurlyLine.cxx:608
 TCurlyLine.cxx:609
 TCurlyLine.cxx:610
 TCurlyLine.cxx:611
 TCurlyLine.cxx:612
 TCurlyLine.cxx:613
 TCurlyLine.cxx:614
 TCurlyLine.cxx:615
 TCurlyLine.cxx:616
 TCurlyLine.cxx:617
 TCurlyLine.cxx:618
 TCurlyLine.cxx:619