// @(#)root/g3d:$Id$
// Author: Nenad Buncic   17/08/95

/*************************************************************************
 * 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.             *
 *************************************************************************/

#include "Riostream.h"
#include "TROOT.h"
#include "TPolyLine3D.h"
#include "TVirtualPad.h"
#include "TView.h"
#include "TVirtualViewer3D.h"
#include "TBuffer3D.h"
#include "TBuffer3DTypes.h"
#include "TGeometry.h"
#include "TMath.h"

#include <assert.h>

ClassImp(TPolyLine3D);

//______________________________________________________________________________
// PolyLine3D is a 3-dimensional polyline. It has 4 different constructors.
//
//   First one, without any parameters TPolyLine3D(), we call 'default
// constructor' and it's used in a case that just an initialisation is
// needed (i.e. pointer declaration).
//
//       Example:
//                 TPolyLine3D *pl1 = new TPolyLine3D;
//
//
//   Second one is 'normal constructor' with, usually, one parameter
// n (number of points), and it just allocates a space for the points.
//
//       Example:
//                 TPolyLine3D pl1(150);
//
//
//   Third one allocates a space for the points, and also makes
// initialisation from the given array.
//
//       Example:
//                 TPolyLine3D pl1(150, pointerToAnArray);
//
//
//   Fourth one is, almost, similar to the constructor above, except
// initialisation is provided with three independent arrays (array of
// x coordinates, y coordinates and z coordinates).
//
//       Example:
//                 TPolyLine3D pl1(150, xArray, yArray, zArray);
//
// Example:
//   void pl3() {
//      TCanvas *c1 = new TCanvas("c1");
//      TView *view = TView::CreateView(1);
//      view->SetRange(0,0,0,2,2,2);
//      const Int_t n = 100;
//      TPolyLine3D *l = new TPolyLine3D(n);
//      for (Int_t i=0;i<n;i++) {
//         Double_t x = 2*gRandom->Rndm();
//         Double_t y = 2*gRandom->Rndm();
//         Double_t z = 2*gRandom->Rndm();
//         l->SetPoint(i,x,y,z);
//      }
//      l->Draw();
//   }


//______________________________________________________________________________
TPolyLine3D::TPolyLine3D()
{
   // 3-D polyline default constructor.

   fN = 0;
   fP = 0;
   fLastPoint = -1;
}


//______________________________________________________________________________
TPolyLine3D::TPolyLine3D(Int_t n, Option_t *option)
{
   // 3-D polyline normal constructor with initialization to 0.
   // If n < 0 the default size (2 points) is set.

   fOption = option;
   SetBit(kCanDelete);
   fLastPoint = -1;
   if (n <= 0) {
      fN = 0;
      fP = 0;
      return;
   }

   fN = n;
   fP = new Float_t[3*fN];
   for (Int_t i=0; i<3*fN; i++) fP[i] = 0;
}


//______________________________________________________________________________
TPolyLine3D::TPolyLine3D(Int_t n, Float_t *p, Option_t *option)
{
   // 3-D polyline normal constructor. Polyline is intialized with p.
   // If n < 0 the default size (2 points) is set.

   fOption = option;
   SetBit(kCanDelete);
   fLastPoint = -1;
   if (n <= 0) {
      fN = 0;
      fP = 0;
      return;
   }

   fN = n;
   fP = new Float_t[3*fN];
   for (Int_t i=0; i<3*n; i++) {
      fP[i] = p[i];
   }
   fLastPoint = fN-1;
}


//______________________________________________________________________________
TPolyLine3D::TPolyLine3D(Int_t n, Double_t *p, Option_t *option)
{
   // 3-D polyline normal constructor. Polyline is initialized with p
   // (cast to float). If n < 0 the default size (2 points) is set.

   fOption = option;
   SetBit(kCanDelete);
   fLastPoint = -1;
   if (n <= 0) {
      fN = 0;
      fP = 0;
      return;
   }

   fN = n;
   fP = new Float_t[3*fN];
   for (Int_t i=0; i<3*n; i++) {
      fP[i] = (Float_t) p[i];
   }
   fLastPoint = fN-1;
}


//______________________________________________________________________________
TPolyLine3D::TPolyLine3D(Int_t n, Float_t *x, Float_t *y, Float_t *z, Option_t *option)
{
   // 3-D polyline normal constructor. Polyline is initialized withe the
   // x, y ,z arrays. If n < 0 the default size (2 points) is set.

   fOption = option;
   SetBit(kCanDelete);
   fLastPoint = -1;
   if (n <= 0) {
      fN = 0;
      fP = 0;
      return;
   }

   fN = n;
   fP = new Float_t[3*fN];
   Int_t j = 0;
   for (Int_t i=0; i<n;i++) {
      fP[j]   = x[i];
      fP[j+1] = y[i];
      fP[j+2] = z[i];
      j += 3;
   }
   fLastPoint = fN-1;
}


//______________________________________________________________________________
TPolyLine3D::TPolyLine3D(Int_t n, Double_t *x, Double_t *y, Double_t *z, Option_t *option)
{
   // 3-D polyline normal constructor. Polyline is initialized withe the
   // x, y, z arrays (which are cast to float).
   // If n < 0 the default size (2 points) is set.

   fOption = option;
   SetBit(kCanDelete);
   fLastPoint = -1;
   if (n <= 0) {
      fN = 0;
      fP = 0;
      return;
   }

   fN = n;
   fP = new Float_t[3*fN];
   Int_t j = 0;
   for (Int_t i=0; i<n;i++) {
      fP[j]   = (Float_t) x[i];
      fP[j+1] = (Float_t) y[i];
      fP[j+2] = (Float_t) z[i];
      j += 3;
   }
   fLastPoint = fN-1;
}

//______________________________________________________________________________
TPolyLine3D& TPolyLine3D::operator=(const TPolyLine3D& pl)
{
   //assignement operator
   if(this!=&pl) {
      TObject::operator=(pl);
      TAttLine::operator=(pl);
      TAtt3D::operator=(pl);
      fN=pl.fN;
      fP=pl.fP;
      fOption=pl.fOption;
      fLastPoint=pl.fLastPoint;
   }
   return *this;
}

//______________________________________________________________________________
TPolyLine3D::~TPolyLine3D()
{
   // 3-D polyline destructor.

   if (fP) delete [] fP;
}


//______________________________________________________________________________
TPolyLine3D::TPolyLine3D(const TPolyLine3D &polyline) : TObject(polyline), TAttLine(polyline), TAtt3D(polyline)
{
   // 3-D polyline copy ctor.

   fP         = 0;
   fLastPoint = 0;
   fN         = 0;
   ((TPolyLine3D&)polyline).TPolyLine3D::Copy(*this);
}


//______________________________________________________________________________
void TPolyLine3D::Copy(TObject &obj) const
{
   // Copy polyline to polyline obj.

   TObject::Copy(obj);
   TAttLine::Copy(((TPolyLine3D&)obj));
   ((TPolyLine3D&)obj).fN = fN;
   if (((TPolyLine3D&)obj).fP)
      delete [] ((TPolyLine3D&)obj).fP;
   if (fN > 0) {
      ((TPolyLine3D&)obj).fP = new Float_t[3*fN];
      for (Int_t i=0; i<3*fN;i++)  {((TPolyLine3D&)obj).fP[i] = fP[i];}
   } else {
      ((TPolyLine3D&)obj).fP = 0;
   }
   ((TPolyLine3D&)obj).fOption = fOption;
   ((TPolyLine3D&)obj).fLastPoint = fLastPoint;
}


//______________________________________________________________________________
Int_t TPolyLine3D::DistancetoPrimitive(Int_t px, Int_t py)
{
   // Compute distance from point px,py to a 3-D polyline.
   // Compute the closest distance of approach from point px,py to each segment
   // of the polyline.
   // Returns when the distance found is below DistanceMaximum.
   // The distance is computed in pixels units.

   const Int_t inaxis = 7;
   Int_t dist = 9999;

   Int_t puxmin = gPad->XtoAbsPixel(gPad->GetUxmin());
   Int_t puymin = gPad->YtoAbsPixel(gPad->GetUymin());
   Int_t puxmax = gPad->XtoAbsPixel(gPad->GetUxmax());
   Int_t puymax = gPad->YtoAbsPixel(gPad->GetUymax());

   // return if point is not in the user area
   if (px < puxmin - inaxis) return dist;
   if (py > puymin + inaxis) return dist;
   if (px > puxmax + inaxis) return dist;
   if (py < puymax - inaxis) return dist;

   TView *view = gPad->GetView();
   if (!view) return dist;

   Int_t i, dsegment;
   Double_t x1,y1,x2,y2;
   Float_t xndc[3];
   for (i=0;i<Size()-1;i++) {
      view->WCtoNDC(&fP[3*i], xndc);
      x1 = xndc[0];
      y1 = xndc[1];
      view->WCtoNDC(&fP[3*i+3], xndc);
      x2 = xndc[0];
      y2 = xndc[1];
      dsegment = DistancetoLine(px,py,x1,y1,x2,y2);
      if (dsegment < dist) dist = dsegment;
   }
   return dist;
}


//______________________________________________________________________________
void TPolyLine3D::Draw(Option_t *option)
{
   // Draw this 3-D polyline with its current attributes.

   AppendPad(option);
}


//______________________________________________________________________________
void TPolyLine3D::DrawOutlineCube(TList *outline, Double_t *rmin, Double_t *rmax)
{
   // Draw cube outline with 3d polylines.
   //
   //      xmin = fRmin[0]        xmax = fRmax[0]
   //      ymin = fRmin[1]        ymax = fRmax[1]
   //      zmin = fRmin[2]        zmax = fRmax[2]
   //
   //
   //    (xmin,ymax,zmax) +---------+ (xmax,ymax,zmax)
   //                    /         /|
   //                   /         / |
   //                  /         /  |
   //(xmin,ymin,zmax) +---------+   |
   //                 |         |   + (xmax,ymax,zmin)
   //                 |         |  /
   //                 |         | /
   //                 |         |/
   //                 +---------+
   //  (xmin,ymin,zmin)         (xmax,ymin,zmin)
   //

   Double_t xmin = rmin[0];     Double_t xmax = rmax[0];
   Double_t ymin = rmin[1];     Double_t ymax = rmax[1];
   Double_t zmin = rmin[2];     Double_t zmax = rmax[2];

   TPolyLine3D *pl3d = (TPolyLine3D *)outline->First();
   if (!pl3d) {
      TView *view = gPad->GetView();
      if (!view) return;
      TPolyLine3D *p1 = new TPolyLine3D(4);
      TPolyLine3D *p2 = new TPolyLine3D(4);
      TPolyLine3D *p3 = new TPolyLine3D(4);
      TPolyLine3D *p4 = new TPolyLine3D(4);
      p1->SetLineColor(view->GetLineColor());
      p1->SetLineStyle(view->GetLineStyle());
      p1->SetLineWidth(view->GetLineWidth());
      p1->Copy(*p2);
      p1->Copy(*p3);
      p1->Copy(*p4);
      outline->Add(p1);
      outline->Add(p2);
      outline->Add(p3);
      outline->Add(p4);
   }

   pl3d = (TPolyLine3D *)outline->First();

   if (pl3d) {
      pl3d->SetPoint(0, xmin, ymin, zmin);
      pl3d->SetPoint(1, xmax, ymin, zmin);
      pl3d->SetPoint(2, xmax, ymax, zmin);
      pl3d->SetPoint(3, xmin, ymax, zmin);
   }

   pl3d = (TPolyLine3D *)outline->After(pl3d);

   if (pl3d) {
      pl3d->SetPoint(0, xmax, ymin, zmin);
      pl3d->SetPoint(1, xmax, ymin, zmax);
      pl3d->SetPoint(2, xmax, ymax, zmax);
      pl3d->SetPoint(3, xmax, ymax, zmin);
   }

   pl3d = (TPolyLine3D *)outline->After(pl3d);

   if (pl3d) {
      pl3d->SetPoint(0, xmax, ymin, zmax);
      pl3d->SetPoint(1, xmin, ymin, zmax);
      pl3d->SetPoint(2, xmin, ymax, zmax);
      pl3d->SetPoint(3, xmax, ymax, zmax);
   }

   pl3d = (TPolyLine3D *)outline->After(pl3d);

   if (pl3d) {
      pl3d->SetPoint(0, xmin, ymin, zmax);
      pl3d->SetPoint(1, xmin, ymin, zmin);
      pl3d->SetPoint(2, xmin, ymax, zmin);
      pl3d->SetPoint(3, xmin, ymax, zmax);
   }
}


//______________________________________________________________________________
void TPolyLine3D::DrawPolyLine(Int_t n, Float_t *p, Option_t *option)
{
   // Draw 3-D polyline with new coordinates. Creates a new polyline which
   // will be adopted by the pad in which it is drawn. Does not change the
   // original polyline (should be static method).

   TPolyLine3D *newpolyline = new TPolyLine3D();
   Int_t size = 3*Size();
   newpolyline->fN =n;
   newpolyline->fP = new Float_t[size];
   for (Int_t i=0; i<size;i++) { newpolyline->fP[i] = p[i];}
   TAttLine::Copy(*newpolyline);
   newpolyline->fOption = fOption;
   newpolyline->fLastPoint = fLastPoint;
   newpolyline->SetBit(kCanDelete);
   newpolyline->AppendPad(option);
}


//______________________________________________________________________________
void TPolyLine3D::ExecuteEvent(Int_t event, Int_t px, Int_t py)
{
   // Execute action corresponding to one event.

   if (!gPad) return;
   if (gPad->GetView()) gPad->GetView()->ExecuteRotateView(event, px, py);
}


//______________________________________________________________________________
void TPolyLine3D::ls(Option_t *option) const
{
   // List this 3-D polyline.

   TROOT::IndentLevel();
   std::cout <<"PolyLine3D  N=" <<fN<<" Option="<<option<<std::endl;
}


//______________________________________________________________________________
Int_t TPolyLine3D::Merge(TCollection *li)
{
// Merge polylines in the collection in this polyline

   if (!li) return 0;
   TIter next(li);

   //first loop to count the number of entries
   TPolyLine3D *pl;
   Int_t npoints = 0;
   while ((pl = (TPolyLine3D*)next())) {
      if (!pl->InheritsFrom(TPolyLine3D::Class())) {
         Error("Add","Attempt to add object of class: %s to a %s",pl->ClassName(),this->ClassName());
         return -1;
      }
      npoints += pl->Size();
   }

   //extend this polyline to hold npoints
   SetPoint(npoints-1,0,0,0);

   //merge all polylines
   next.Reset();
   while ((pl = (TPolyLine3D*)next())) {
      Int_t np = pl->Size();
      Float_t *p = pl->GetP();
      for (Int_t i=0;i<np;i++) {
         SetPoint(i,p[3*i],p[3*i+1],p[3*i+2]);
      }
   }

   return npoints;
}


//______________________________________________________________________________
void TPolyLine3D::Paint(Option_t * /* option */ )
{
   // Paint a TPolyLine3D.

   UInt_t i;

   // No need to continue if there is nothing to paint
   if (Size() <= 0) return;

   static TBuffer3D buffer(TBuffer3DTypes::kLine);

   // TPolyLine3D can only be described by filling the TBuffer3D 'tesselation'
   // parts - so there are no 'optional' sections - we just fill everything.

   buffer.ClearSectionsValid();

   // Section kCore
   buffer.fID           = this;
   buffer.fColor        = GetLineColor();
   buffer.fTransparency = 0;
   buffer.fLocalFrame   = kFALSE;
   buffer.SetSectionsValid(TBuffer3D::kCore);

   // We fill kCore and kRawSizes on first pass and try with viewer
   TVirtualViewer3D * viewer3D = gPad->GetViewer3D();
   if (!viewer3D) return;
   Int_t reqSections = viewer3D->AddObject(buffer);
   if (reqSections == TBuffer3D::kNone) {
      return;
   }

   if (reqSections & TBuffer3D::kRawSizes) {
      Int_t nbPnts = Size();
      Int_t nbSegs = nbPnts-1;
      if (!buffer.SetRawSizes(nbPnts, 3*nbPnts, nbSegs, 3*nbSegs, 0, 0)) {
         return;
      }
      buffer.SetSectionsValid(TBuffer3D::kRawSizes);
   }

   if ((reqSections & TBuffer3D::kRaw) && buffer.SectionsValid(TBuffer3D::kRawSizes)) {
      // Points
      for (i=0; i<3*buffer.NbPnts(); i++) {
         buffer.fPnts[i] = (Double_t)fP[i];
      }

      // Transform points
      if (gGeometry && !buffer.fLocalFrame) {
         Double_t dlocal[3];
         Double_t dmaster[3];
         for (UInt_t j=0; j<buffer.NbPnts(); j++) {
            dlocal[0] = buffer.fPnts[3*j];
            dlocal[1] = buffer.fPnts[3*j+1];
            dlocal[2] = buffer.fPnts[3*j+2];
            gGeometry->Local2Master(&dlocal[0],&dmaster[0]);
            buffer.fPnts[3*j]   = dmaster[0];
            buffer.fPnts[3*j+1] = dmaster[1];
            buffer.fPnts[3*j+2] = dmaster[2];
         }
      }

      // Basic colors: 0, 1, ... 8
      Int_t c = (((GetLineColor()) %8) -1) * 4;
      if (c < 0) c = 0;

      // Segments
      for (i = 0; i < buffer.NbSegs(); i++) {
         buffer.fSegs[3*i  ] = c;
         buffer.fSegs[3*i+1] = i;
         buffer.fSegs[3*i+2] = i+1;
      }

      TAttLine::Modify();

      buffer.SetSectionsValid(TBuffer3D::kRaw);
   }

   viewer3D->AddObject(buffer);
}


//______________________________________________________________________________
void TPolyLine3D::Print(Option_t *option) const
{
   // Dump this 3-D polyline with its attributes on stdout.

   printf("    TPolyLine3D N=%d, Option=%s\n",fN,option);
   TString opt = option;
   opt.ToLower();
   if (opt.Contains("all")) {
      for (Int_t i=0;i<Size();i++) {
         printf(" x[%d]=%g, y[%d]=%g, z[%d]=%g\n",i,fP[3*i],i,fP[3*i+1],i,fP[3*i+2]);
      }
   }
}


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

   char quote = '"';
   out<<"   "<<std::endl;
   if (gROOT->ClassSaved(TPolyLine3D::Class())) {
      out<<"   ";
   } else {
      out<<"   TPolyLine3D *";
   }
   Int_t size=Size();
   out<<"pline3D = new TPolyLine3D("<<fN<<","<<quote<<fOption<<quote<<");"<<std::endl;

   SaveLineAttributes(out,"pline3D",1,1,1);

   if (size > 0) {
      for (Int_t i=0;i<size;i++)
         out<<"   pline3D->SetPoint("<<i<<","<<fP[3*i]<<","<<fP[3*i+1]<<","<<fP[3*i+2]<<");"<<std::endl;
   }
   out<<"   pline3D->Draw();"<<std::endl;
}


//______________________________________________________________________________
Int_t TPolyLine3D::SetNextPoint(Double_t x, Double_t y, Double_t z)
{
   // Set point following LastPoint to x, y, z.
   // Returns index of the point (new last point).

   fLastPoint++;
   SetPoint(fLastPoint, x, y, z);
   return fLastPoint;
}


//______________________________________________________________________________
void TPolyLine3D::SetPoint(Int_t n, Double_t x, Double_t y, Double_t z)
{
   // Set point n to x, y, z.
   // If n is more then the current TPolyLine3D size (n > fN) then
   // the polyline will be resized to contain at least n points.

   if (n < 0) return;
   if (!fP || n >= fN) {
      // re-allocate the object
      Int_t newN = TMath::Max(2*fN,n+1);
      Float_t *savepoint = new Float_t [3*newN];
      if (fP && fN){
         memcpy(savepoint,fP,3*fN*sizeof(Float_t));
         memset(&savepoint[3*fN],0,(newN-fN)*sizeof(Float_t));
         delete [] fP;
      }
      fP = savepoint;
      fN = newN;
   }
   fP[3*n  ] = x;
   fP[3*n+1] = y;
   fP[3*n+2] = z;
   fLastPoint = TMath::Max(fLastPoint,n);
}


//______________________________________________________________________________
void TPolyLine3D::SetPolyLine(Int_t n, Option_t *option)
{
   // Re-initialize polyline with n points (0,0,0).
   // if n <= 0 the current array of points is deleted.

   fOption = option;
   if (n <= 0) {
      fN = 0;
      fLastPoint = -1;
      delete [] fP;
      fP = 0;
      return;
   }
   fN = n;
   if (fP) delete [] fP;
   fP = new Float_t[3*fN];
   memset(fP,0,3*fN*sizeof(Float_t));
   fLastPoint = fN-1;
}


//______________________________________________________________________________
void TPolyLine3D::SetPolyLine(Int_t n, Float_t *p, Option_t *option)
{
   // Re-initialize polyline with n points from p. If p=0 initialize with 0.
   // if n <= 0 the current array of points is deleted.

   fOption = option;
   if (n <= 0) {
      fN = 0;
      fLastPoint = -1;
      delete [] fP;
      fP = 0;
      return;
   }
   fN = n;
   if (fP) delete [] fP;
   fP = new Float_t[3*fN];
   if (p) {
      for (Int_t i=0; i<fN;i++) {
         fP[3*i]   = p[3*i];
         fP[3*i+1] = p[3*i+1];
         fP[3*i+2] = p[3*i+2];
      }
   } else {
      memset(fP,0,3*fN*sizeof(Float_t));
   }
   fLastPoint = fN-1;
}


//______________________________________________________________________________
void TPolyLine3D::SetPolyLine(Int_t n, Double_t *p, Option_t *option)
{
   // Re-initialize polyline with n points from p. If p=0 initialize with 0.
   // if n <= 0 the current array of points is deleted.

   fOption = option;
   if (n <= 0) {
      fN = 0;
      fLastPoint = -1;
      delete [] fP;
      fP = 0;
      return;
   }
   fN = n;
   if (fP) delete [] fP;
   fP = new Float_t[3*fN];
   if (p) {
      for (Int_t i=0; i<fN;i++) {
         fP[3*i]   = (Float_t) p[3*i];
         fP[3*i+1] = (Float_t) p[3*i+1];
         fP[3*i+2] = (Float_t) p[3*i+2];
      }
   } else {
      memset(fP,0,3*fN*sizeof(Float_t));
   }
   fLastPoint = fN-1;
}


//______________________________________________________________________________
void TPolyLine3D::Streamer(TBuffer &b)
{
   // Stream a 3-D polyline object.

   UInt_t R__s, R__c;
   if (b.IsReading()) {
      b.ReadVersion(&R__s, &R__c);
      TObject::Streamer(b);
      TAttLine::Streamer(b);
      b >> fN;
      if (fN) {
         fP = new Float_t[3*fN];
         b.ReadFastArray(fP,3*fN);
      }
      fOption.Streamer(b);
      fLastPoint = fN-1;
      b.CheckByteCount(R__s, R__c, TPolyLine3D::IsA());
   } else {
      R__c = b.WriteVersion(TPolyLine3D::IsA(), kTRUE);
      TObject::Streamer(b);
      TAttLine::Streamer(b);
      Int_t size = Size();
      b << size;
      if (size) b.WriteFastArray(fP, 3*size);
      fOption.Streamer(b);
      b.SetByteCount(R__c, kTRUE);
   }
}
 TPolyLine3D.cxx:1
 TPolyLine3D.cxx:2
 TPolyLine3D.cxx:3
 TPolyLine3D.cxx:4
 TPolyLine3D.cxx:5
 TPolyLine3D.cxx:6
 TPolyLine3D.cxx:7
 TPolyLine3D.cxx:8
 TPolyLine3D.cxx:9
 TPolyLine3D.cxx:10
 TPolyLine3D.cxx:11
 TPolyLine3D.cxx:12
 TPolyLine3D.cxx:13
 TPolyLine3D.cxx:14
 TPolyLine3D.cxx:15
 TPolyLine3D.cxx:16
 TPolyLine3D.cxx:17
 TPolyLine3D.cxx:18
 TPolyLine3D.cxx:19
 TPolyLine3D.cxx:20
 TPolyLine3D.cxx:21
 TPolyLine3D.cxx:22
 TPolyLine3D.cxx:23
 TPolyLine3D.cxx:24
 TPolyLine3D.cxx:25
 TPolyLine3D.cxx:26
 TPolyLine3D.cxx:27
 TPolyLine3D.cxx:28
 TPolyLine3D.cxx:29
 TPolyLine3D.cxx:30
 TPolyLine3D.cxx:31
 TPolyLine3D.cxx:32
 TPolyLine3D.cxx:33
 TPolyLine3D.cxx:34
 TPolyLine3D.cxx:35
 TPolyLine3D.cxx:36
 TPolyLine3D.cxx:37
 TPolyLine3D.cxx:38
 TPolyLine3D.cxx:39
 TPolyLine3D.cxx:40
 TPolyLine3D.cxx:41
 TPolyLine3D.cxx:42
 TPolyLine3D.cxx:43
 TPolyLine3D.cxx:44
 TPolyLine3D.cxx:45
 TPolyLine3D.cxx:46
 TPolyLine3D.cxx:47
 TPolyLine3D.cxx:48
 TPolyLine3D.cxx:49
 TPolyLine3D.cxx:50
 TPolyLine3D.cxx:51
 TPolyLine3D.cxx:52
 TPolyLine3D.cxx:53
 TPolyLine3D.cxx:54
 TPolyLine3D.cxx:55
 TPolyLine3D.cxx:56
 TPolyLine3D.cxx:57
 TPolyLine3D.cxx:58
 TPolyLine3D.cxx:59
 TPolyLine3D.cxx:60
 TPolyLine3D.cxx:61
 TPolyLine3D.cxx:62
 TPolyLine3D.cxx:63
 TPolyLine3D.cxx:64
 TPolyLine3D.cxx:65
 TPolyLine3D.cxx:66
 TPolyLine3D.cxx:67
 TPolyLine3D.cxx:68
 TPolyLine3D.cxx:69
 TPolyLine3D.cxx:70
 TPolyLine3D.cxx:71
 TPolyLine3D.cxx:72
 TPolyLine3D.cxx:73
 TPolyLine3D.cxx:74
 TPolyLine3D.cxx:75
 TPolyLine3D.cxx:76
 TPolyLine3D.cxx:77
 TPolyLine3D.cxx:78
 TPolyLine3D.cxx:79
 TPolyLine3D.cxx:80
 TPolyLine3D.cxx:81
 TPolyLine3D.cxx:82
 TPolyLine3D.cxx:83
 TPolyLine3D.cxx:84
 TPolyLine3D.cxx:85
 TPolyLine3D.cxx:86
 TPolyLine3D.cxx:87
 TPolyLine3D.cxx:88
 TPolyLine3D.cxx:89
 TPolyLine3D.cxx:90
 TPolyLine3D.cxx:91
 TPolyLine3D.cxx:92
 TPolyLine3D.cxx:93
 TPolyLine3D.cxx:94
 TPolyLine3D.cxx:95
 TPolyLine3D.cxx:96
 TPolyLine3D.cxx:97
 TPolyLine3D.cxx:98
 TPolyLine3D.cxx:99
 TPolyLine3D.cxx:100
 TPolyLine3D.cxx:101
 TPolyLine3D.cxx:102
 TPolyLine3D.cxx:103
 TPolyLine3D.cxx:104
 TPolyLine3D.cxx:105
 TPolyLine3D.cxx:106
 TPolyLine3D.cxx:107
 TPolyLine3D.cxx:108
 TPolyLine3D.cxx:109
 TPolyLine3D.cxx:110
 TPolyLine3D.cxx:111
 TPolyLine3D.cxx:112
 TPolyLine3D.cxx:113
 TPolyLine3D.cxx:114
 TPolyLine3D.cxx:115
 TPolyLine3D.cxx:116
 TPolyLine3D.cxx:117
 TPolyLine3D.cxx:118
 TPolyLine3D.cxx:119
 TPolyLine3D.cxx:120
 TPolyLine3D.cxx:121
 TPolyLine3D.cxx:122
 TPolyLine3D.cxx:123
 TPolyLine3D.cxx:124
 TPolyLine3D.cxx:125
 TPolyLine3D.cxx:126
 TPolyLine3D.cxx:127
 TPolyLine3D.cxx:128
 TPolyLine3D.cxx:129
 TPolyLine3D.cxx:130
 TPolyLine3D.cxx:131
 TPolyLine3D.cxx:132
 TPolyLine3D.cxx:133
 TPolyLine3D.cxx:134
 TPolyLine3D.cxx:135
 TPolyLine3D.cxx:136
 TPolyLine3D.cxx:137
 TPolyLine3D.cxx:138
 TPolyLine3D.cxx:139
 TPolyLine3D.cxx:140
 TPolyLine3D.cxx:141
 TPolyLine3D.cxx:142
 TPolyLine3D.cxx:143
 TPolyLine3D.cxx:144
 TPolyLine3D.cxx:145
 TPolyLine3D.cxx:146
 TPolyLine3D.cxx:147
 TPolyLine3D.cxx:148
 TPolyLine3D.cxx:149
 TPolyLine3D.cxx:150
 TPolyLine3D.cxx:151
 TPolyLine3D.cxx:152
 TPolyLine3D.cxx:153
 TPolyLine3D.cxx:154
 TPolyLine3D.cxx:155
 TPolyLine3D.cxx:156
 TPolyLine3D.cxx:157
 TPolyLine3D.cxx:158
 TPolyLine3D.cxx:159
 TPolyLine3D.cxx:160
 TPolyLine3D.cxx:161
 TPolyLine3D.cxx:162
 TPolyLine3D.cxx:163
 TPolyLine3D.cxx:164
 TPolyLine3D.cxx:165
 TPolyLine3D.cxx:166
 TPolyLine3D.cxx:167
 TPolyLine3D.cxx:168
 TPolyLine3D.cxx:169
 TPolyLine3D.cxx:170
 TPolyLine3D.cxx:171
 TPolyLine3D.cxx:172
 TPolyLine3D.cxx:173
 TPolyLine3D.cxx:174
 TPolyLine3D.cxx:175
 TPolyLine3D.cxx:176
 TPolyLine3D.cxx:177
 TPolyLine3D.cxx:178
 TPolyLine3D.cxx:179
 TPolyLine3D.cxx:180
 TPolyLine3D.cxx:181
 TPolyLine3D.cxx:182
 TPolyLine3D.cxx:183
 TPolyLine3D.cxx:184
 TPolyLine3D.cxx:185
 TPolyLine3D.cxx:186
 TPolyLine3D.cxx:187
 TPolyLine3D.cxx:188
 TPolyLine3D.cxx:189
 TPolyLine3D.cxx:190
 TPolyLine3D.cxx:191
 TPolyLine3D.cxx:192
 TPolyLine3D.cxx:193
 TPolyLine3D.cxx:194
 TPolyLine3D.cxx:195
 TPolyLine3D.cxx:196
 TPolyLine3D.cxx:197
 TPolyLine3D.cxx:198
 TPolyLine3D.cxx:199
 TPolyLine3D.cxx:200
 TPolyLine3D.cxx:201
 TPolyLine3D.cxx:202
 TPolyLine3D.cxx:203
 TPolyLine3D.cxx:204
 TPolyLine3D.cxx:205
 TPolyLine3D.cxx:206
 TPolyLine3D.cxx:207
 TPolyLine3D.cxx:208
 TPolyLine3D.cxx:209
 TPolyLine3D.cxx:210
 TPolyLine3D.cxx:211
 TPolyLine3D.cxx:212
 TPolyLine3D.cxx:213
 TPolyLine3D.cxx:214
 TPolyLine3D.cxx:215
 TPolyLine3D.cxx:216
 TPolyLine3D.cxx:217
 TPolyLine3D.cxx:218
 TPolyLine3D.cxx:219
 TPolyLine3D.cxx:220
 TPolyLine3D.cxx:221
 TPolyLine3D.cxx:222
 TPolyLine3D.cxx:223
 TPolyLine3D.cxx:224
 TPolyLine3D.cxx:225
 TPolyLine3D.cxx:226
 TPolyLine3D.cxx:227
 TPolyLine3D.cxx:228
 TPolyLine3D.cxx:229
 TPolyLine3D.cxx:230
 TPolyLine3D.cxx:231
 TPolyLine3D.cxx:232
 TPolyLine3D.cxx:233
 TPolyLine3D.cxx:234
 TPolyLine3D.cxx:235
 TPolyLine3D.cxx:236
 TPolyLine3D.cxx:237
 TPolyLine3D.cxx:238
 TPolyLine3D.cxx:239
 TPolyLine3D.cxx:240
 TPolyLine3D.cxx:241
 TPolyLine3D.cxx:242
 TPolyLine3D.cxx:243
 TPolyLine3D.cxx:244
 TPolyLine3D.cxx:245
 TPolyLine3D.cxx:246
 TPolyLine3D.cxx:247
 TPolyLine3D.cxx:248
 TPolyLine3D.cxx:249
 TPolyLine3D.cxx:250
 TPolyLine3D.cxx:251
 TPolyLine3D.cxx:252
 TPolyLine3D.cxx:253
 TPolyLine3D.cxx:254
 TPolyLine3D.cxx:255
 TPolyLine3D.cxx:256
 TPolyLine3D.cxx:257
 TPolyLine3D.cxx:258
 TPolyLine3D.cxx:259
 TPolyLine3D.cxx:260
 TPolyLine3D.cxx:261
 TPolyLine3D.cxx:262
 TPolyLine3D.cxx:263
 TPolyLine3D.cxx:264
 TPolyLine3D.cxx:265
 TPolyLine3D.cxx:266
 TPolyLine3D.cxx:267
 TPolyLine3D.cxx:268
 TPolyLine3D.cxx:269
 TPolyLine3D.cxx:270
 TPolyLine3D.cxx:271
 TPolyLine3D.cxx:272
 TPolyLine3D.cxx:273
 TPolyLine3D.cxx:274
 TPolyLine3D.cxx:275
 TPolyLine3D.cxx:276
 TPolyLine3D.cxx:277
 TPolyLine3D.cxx:278
 TPolyLine3D.cxx:279
 TPolyLine3D.cxx:280
 TPolyLine3D.cxx:281
 TPolyLine3D.cxx:282
 TPolyLine3D.cxx:283
 TPolyLine3D.cxx:284
 TPolyLine3D.cxx:285
 TPolyLine3D.cxx:286
 TPolyLine3D.cxx:287
 TPolyLine3D.cxx:288
 TPolyLine3D.cxx:289
 TPolyLine3D.cxx:290
 TPolyLine3D.cxx:291
 TPolyLine3D.cxx:292
 TPolyLine3D.cxx:293
 TPolyLine3D.cxx:294
 TPolyLine3D.cxx:295
 TPolyLine3D.cxx:296
 TPolyLine3D.cxx:297
 TPolyLine3D.cxx:298
 TPolyLine3D.cxx:299
 TPolyLine3D.cxx:300
 TPolyLine3D.cxx:301
 TPolyLine3D.cxx:302
 TPolyLine3D.cxx:303
 TPolyLine3D.cxx:304
 TPolyLine3D.cxx:305
 TPolyLine3D.cxx:306
 TPolyLine3D.cxx:307
 TPolyLine3D.cxx:308
 TPolyLine3D.cxx:309
 TPolyLine3D.cxx:310
 TPolyLine3D.cxx:311
 TPolyLine3D.cxx:312
 TPolyLine3D.cxx:313
 TPolyLine3D.cxx:314
 TPolyLine3D.cxx:315
 TPolyLine3D.cxx:316
 TPolyLine3D.cxx:317
 TPolyLine3D.cxx:318
 TPolyLine3D.cxx:319
 TPolyLine3D.cxx:320
 TPolyLine3D.cxx:321
 TPolyLine3D.cxx:322
 TPolyLine3D.cxx:323
 TPolyLine3D.cxx:324
 TPolyLine3D.cxx:325
 TPolyLine3D.cxx:326
 TPolyLine3D.cxx:327
 TPolyLine3D.cxx:328
 TPolyLine3D.cxx:329
 TPolyLine3D.cxx:330
 TPolyLine3D.cxx:331
 TPolyLine3D.cxx:332
 TPolyLine3D.cxx:333
 TPolyLine3D.cxx:334
 TPolyLine3D.cxx:335
 TPolyLine3D.cxx:336
 TPolyLine3D.cxx:337
 TPolyLine3D.cxx:338
 TPolyLine3D.cxx:339
 TPolyLine3D.cxx:340
 TPolyLine3D.cxx:341
 TPolyLine3D.cxx:342
 TPolyLine3D.cxx:343
 TPolyLine3D.cxx:344
 TPolyLine3D.cxx:345
 TPolyLine3D.cxx:346
 TPolyLine3D.cxx:347
 TPolyLine3D.cxx:348
 TPolyLine3D.cxx:349
 TPolyLine3D.cxx:350
 TPolyLine3D.cxx:351
 TPolyLine3D.cxx:352
 TPolyLine3D.cxx:353
 TPolyLine3D.cxx:354
 TPolyLine3D.cxx:355
 TPolyLine3D.cxx:356
 TPolyLine3D.cxx:357
 TPolyLine3D.cxx:358
 TPolyLine3D.cxx:359
 TPolyLine3D.cxx:360
 TPolyLine3D.cxx:361
 TPolyLine3D.cxx:362
 TPolyLine3D.cxx:363
 TPolyLine3D.cxx:364
 TPolyLine3D.cxx:365
 TPolyLine3D.cxx:366
 TPolyLine3D.cxx:367
 TPolyLine3D.cxx:368
 TPolyLine3D.cxx:369
 TPolyLine3D.cxx:370
 TPolyLine3D.cxx:371
 TPolyLine3D.cxx:372
 TPolyLine3D.cxx:373
 TPolyLine3D.cxx:374
 TPolyLine3D.cxx:375
 TPolyLine3D.cxx:376
 TPolyLine3D.cxx:377
 TPolyLine3D.cxx:378
 TPolyLine3D.cxx:379
 TPolyLine3D.cxx:380
 TPolyLine3D.cxx:381
 TPolyLine3D.cxx:382
 TPolyLine3D.cxx:383
 TPolyLine3D.cxx:384
 TPolyLine3D.cxx:385
 TPolyLine3D.cxx:386
 TPolyLine3D.cxx:387
 TPolyLine3D.cxx:388
 TPolyLine3D.cxx:389
 TPolyLine3D.cxx:390
 TPolyLine3D.cxx:391
 TPolyLine3D.cxx:392
 TPolyLine3D.cxx:393
 TPolyLine3D.cxx:394
 TPolyLine3D.cxx:395
 TPolyLine3D.cxx:396
 TPolyLine3D.cxx:397
 TPolyLine3D.cxx:398
 TPolyLine3D.cxx:399
 TPolyLine3D.cxx:400
 TPolyLine3D.cxx:401
 TPolyLine3D.cxx:402
 TPolyLine3D.cxx:403
 TPolyLine3D.cxx:404
 TPolyLine3D.cxx:405
 TPolyLine3D.cxx:406
 TPolyLine3D.cxx:407
 TPolyLine3D.cxx:408
 TPolyLine3D.cxx:409
 TPolyLine3D.cxx:410
 TPolyLine3D.cxx:411
 TPolyLine3D.cxx:412
 TPolyLine3D.cxx:413
 TPolyLine3D.cxx:414
 TPolyLine3D.cxx:415
 TPolyLine3D.cxx:416
 TPolyLine3D.cxx:417
 TPolyLine3D.cxx:418
 TPolyLine3D.cxx:419
 TPolyLine3D.cxx:420
 TPolyLine3D.cxx:421
 TPolyLine3D.cxx:422
 TPolyLine3D.cxx:423
 TPolyLine3D.cxx:424
 TPolyLine3D.cxx:425
 TPolyLine3D.cxx:426
 TPolyLine3D.cxx:427
 TPolyLine3D.cxx:428
 TPolyLine3D.cxx:429
 TPolyLine3D.cxx:430
 TPolyLine3D.cxx:431
 TPolyLine3D.cxx:432
 TPolyLine3D.cxx:433
 TPolyLine3D.cxx:434
 TPolyLine3D.cxx:435
 TPolyLine3D.cxx:436
 TPolyLine3D.cxx:437
 TPolyLine3D.cxx:438
 TPolyLine3D.cxx:439
 TPolyLine3D.cxx:440
 TPolyLine3D.cxx:441
 TPolyLine3D.cxx:442
 TPolyLine3D.cxx:443
 TPolyLine3D.cxx:444
 TPolyLine3D.cxx:445
 TPolyLine3D.cxx:446
 TPolyLine3D.cxx:447
 TPolyLine3D.cxx:448
 TPolyLine3D.cxx:449
 TPolyLine3D.cxx:450
 TPolyLine3D.cxx:451
 TPolyLine3D.cxx:452
 TPolyLine3D.cxx:453
 TPolyLine3D.cxx:454
 TPolyLine3D.cxx:455
 TPolyLine3D.cxx:456
 TPolyLine3D.cxx:457
 TPolyLine3D.cxx:458
 TPolyLine3D.cxx:459
 TPolyLine3D.cxx:460
 TPolyLine3D.cxx:461
 TPolyLine3D.cxx:462
 TPolyLine3D.cxx:463
 TPolyLine3D.cxx:464
 TPolyLine3D.cxx:465
 TPolyLine3D.cxx:466
 TPolyLine3D.cxx:467
 TPolyLine3D.cxx:468
 TPolyLine3D.cxx:469
 TPolyLine3D.cxx:470
 TPolyLine3D.cxx:471
 TPolyLine3D.cxx:472
 TPolyLine3D.cxx:473
 TPolyLine3D.cxx:474
 TPolyLine3D.cxx:475
 TPolyLine3D.cxx:476
 TPolyLine3D.cxx:477
 TPolyLine3D.cxx:478
 TPolyLine3D.cxx:479
 TPolyLine3D.cxx:480
 TPolyLine3D.cxx:481
 TPolyLine3D.cxx:482
 TPolyLine3D.cxx:483
 TPolyLine3D.cxx:484
 TPolyLine3D.cxx:485
 TPolyLine3D.cxx:486
 TPolyLine3D.cxx:487
 TPolyLine3D.cxx:488
 TPolyLine3D.cxx:489
 TPolyLine3D.cxx:490
 TPolyLine3D.cxx:491
 TPolyLine3D.cxx:492
 TPolyLine3D.cxx:493
 TPolyLine3D.cxx:494
 TPolyLine3D.cxx:495
 TPolyLine3D.cxx:496
 TPolyLine3D.cxx:497
 TPolyLine3D.cxx:498
 TPolyLine3D.cxx:499
 TPolyLine3D.cxx:500
 TPolyLine3D.cxx:501
 TPolyLine3D.cxx:502
 TPolyLine3D.cxx:503
 TPolyLine3D.cxx:504
 TPolyLine3D.cxx:505
 TPolyLine3D.cxx:506
 TPolyLine3D.cxx:507
 TPolyLine3D.cxx:508
 TPolyLine3D.cxx:509
 TPolyLine3D.cxx:510
 TPolyLine3D.cxx:511
 TPolyLine3D.cxx:512
 TPolyLine3D.cxx:513
 TPolyLine3D.cxx:514
 TPolyLine3D.cxx:515
 TPolyLine3D.cxx:516
 TPolyLine3D.cxx:517
 TPolyLine3D.cxx:518
 TPolyLine3D.cxx:519
 TPolyLine3D.cxx:520
 TPolyLine3D.cxx:521
 TPolyLine3D.cxx:522
 TPolyLine3D.cxx:523
 TPolyLine3D.cxx:524
 TPolyLine3D.cxx:525
 TPolyLine3D.cxx:526
 TPolyLine3D.cxx:527
 TPolyLine3D.cxx:528
 TPolyLine3D.cxx:529
 TPolyLine3D.cxx:530
 TPolyLine3D.cxx:531
 TPolyLine3D.cxx:532
 TPolyLine3D.cxx:533
 TPolyLine3D.cxx:534
 TPolyLine3D.cxx:535
 TPolyLine3D.cxx:536
 TPolyLine3D.cxx:537
 TPolyLine3D.cxx:538
 TPolyLine3D.cxx:539
 TPolyLine3D.cxx:540
 TPolyLine3D.cxx:541
 TPolyLine3D.cxx:542
 TPolyLine3D.cxx:543
 TPolyLine3D.cxx:544
 TPolyLine3D.cxx:545
 TPolyLine3D.cxx:546
 TPolyLine3D.cxx:547
 TPolyLine3D.cxx:548
 TPolyLine3D.cxx:549
 TPolyLine3D.cxx:550
 TPolyLine3D.cxx:551
 TPolyLine3D.cxx:552
 TPolyLine3D.cxx:553
 TPolyLine3D.cxx:554
 TPolyLine3D.cxx:555
 TPolyLine3D.cxx:556
 TPolyLine3D.cxx:557
 TPolyLine3D.cxx:558
 TPolyLine3D.cxx:559
 TPolyLine3D.cxx:560
 TPolyLine3D.cxx:561
 TPolyLine3D.cxx:562
 TPolyLine3D.cxx:563
 TPolyLine3D.cxx:564
 TPolyLine3D.cxx:565
 TPolyLine3D.cxx:566
 TPolyLine3D.cxx:567
 TPolyLine3D.cxx:568
 TPolyLine3D.cxx:569
 TPolyLine3D.cxx:570
 TPolyLine3D.cxx:571
 TPolyLine3D.cxx:572
 TPolyLine3D.cxx:573
 TPolyLine3D.cxx:574
 TPolyLine3D.cxx:575
 TPolyLine3D.cxx:576
 TPolyLine3D.cxx:577
 TPolyLine3D.cxx:578
 TPolyLine3D.cxx:579
 TPolyLine3D.cxx:580
 TPolyLine3D.cxx:581
 TPolyLine3D.cxx:582
 TPolyLine3D.cxx:583
 TPolyLine3D.cxx:584
 TPolyLine3D.cxx:585
 TPolyLine3D.cxx:586
 TPolyLine3D.cxx:587
 TPolyLine3D.cxx:588
 TPolyLine3D.cxx:589
 TPolyLine3D.cxx:590
 TPolyLine3D.cxx:591
 TPolyLine3D.cxx:592
 TPolyLine3D.cxx:593
 TPolyLine3D.cxx:594
 TPolyLine3D.cxx:595
 TPolyLine3D.cxx:596
 TPolyLine3D.cxx:597
 TPolyLine3D.cxx:598
 TPolyLine3D.cxx:599
 TPolyLine3D.cxx:600
 TPolyLine3D.cxx:601
 TPolyLine3D.cxx:602
 TPolyLine3D.cxx:603
 TPolyLine3D.cxx:604
 TPolyLine3D.cxx:605
 TPolyLine3D.cxx:606
 TPolyLine3D.cxx:607
 TPolyLine3D.cxx:608
 TPolyLine3D.cxx:609
 TPolyLine3D.cxx:610
 TPolyLine3D.cxx:611
 TPolyLine3D.cxx:612
 TPolyLine3D.cxx:613
 TPolyLine3D.cxx:614
 TPolyLine3D.cxx:615
 TPolyLine3D.cxx:616
 TPolyLine3D.cxx:617
 TPolyLine3D.cxx:618
 TPolyLine3D.cxx:619
 TPolyLine3D.cxx:620
 TPolyLine3D.cxx:621
 TPolyLine3D.cxx:622
 TPolyLine3D.cxx:623
 TPolyLine3D.cxx:624
 TPolyLine3D.cxx:625
 TPolyLine3D.cxx:626
 TPolyLine3D.cxx:627
 TPolyLine3D.cxx:628
 TPolyLine3D.cxx:629
 TPolyLine3D.cxx:630
 TPolyLine3D.cxx:631
 TPolyLine3D.cxx:632
 TPolyLine3D.cxx:633
 TPolyLine3D.cxx:634
 TPolyLine3D.cxx:635
 TPolyLine3D.cxx:636
 TPolyLine3D.cxx:637
 TPolyLine3D.cxx:638
 TPolyLine3D.cxx:639
 TPolyLine3D.cxx:640
 TPolyLine3D.cxx:641
 TPolyLine3D.cxx:642
 TPolyLine3D.cxx:643
 TPolyLine3D.cxx:644
 TPolyLine3D.cxx:645
 TPolyLine3D.cxx:646
 TPolyLine3D.cxx:647
 TPolyLine3D.cxx:648
 TPolyLine3D.cxx:649
 TPolyLine3D.cxx:650
 TPolyLine3D.cxx:651
 TPolyLine3D.cxx:652
 TPolyLine3D.cxx:653
 TPolyLine3D.cxx:654
 TPolyLine3D.cxx:655
 TPolyLine3D.cxx:656
 TPolyLine3D.cxx:657
 TPolyLine3D.cxx:658
 TPolyLine3D.cxx:659
 TPolyLine3D.cxx:660
 TPolyLine3D.cxx:661
 TPolyLine3D.cxx:662
 TPolyLine3D.cxx:663
 TPolyLine3D.cxx:664
 TPolyLine3D.cxx:665
 TPolyLine3D.cxx:666
 TPolyLine3D.cxx:667
 TPolyLine3D.cxx:668
 TPolyLine3D.cxx:669
 TPolyLine3D.cxx:670
 TPolyLine3D.cxx:671
 TPolyLine3D.cxx:672
 TPolyLine3D.cxx:673
 TPolyLine3D.cxx:674
 TPolyLine3D.cxx:675
 TPolyLine3D.cxx:676
 TPolyLine3D.cxx:677
 TPolyLine3D.cxx:678
 TPolyLine3D.cxx:679
 TPolyLine3D.cxx:680
 TPolyLine3D.cxx:681
 TPolyLine3D.cxx:682
 TPolyLine3D.cxx:683
 TPolyLine3D.cxx:684
 TPolyLine3D.cxx:685
 TPolyLine3D.cxx:686
 TPolyLine3D.cxx:687
 TPolyLine3D.cxx:688
 TPolyLine3D.cxx:689
 TPolyLine3D.cxx:690
 TPolyLine3D.cxx:691
 TPolyLine3D.cxx:692
 TPolyLine3D.cxx:693
 TPolyLine3D.cxx:694
 TPolyLine3D.cxx:695
 TPolyLine3D.cxx:696
 TPolyLine3D.cxx:697
 TPolyLine3D.cxx:698
 TPolyLine3D.cxx:699
 TPolyLine3D.cxx:700
 TPolyLine3D.cxx:701
 TPolyLine3D.cxx:702
 TPolyLine3D.cxx:703
 TPolyLine3D.cxx:704
 TPolyLine3D.cxx:705
 TPolyLine3D.cxx:706
 TPolyLine3D.cxx:707
 TPolyLine3D.cxx:708
 TPolyLine3D.cxx:709
 TPolyLine3D.cxx:710
 TPolyLine3D.cxx:711
 TPolyLine3D.cxx:712
 TPolyLine3D.cxx:713
 TPolyLine3D.cxx:714
 TPolyLine3D.cxx:715
 TPolyLine3D.cxx:716
 TPolyLine3D.cxx:717
 TPolyLine3D.cxx:718
 TPolyLine3D.cxx:719
 TPolyLine3D.cxx:720
 TPolyLine3D.cxx:721
 TPolyLine3D.cxx:722
 TPolyLine3D.cxx:723
 TPolyLine3D.cxx:724
 TPolyLine3D.cxx:725
 TPolyLine3D.cxx:726
 TPolyLine3D.cxx:727
 TPolyLine3D.cxx:728
 TPolyLine3D.cxx:729
 TPolyLine3D.cxx:730
 TPolyLine3D.cxx:731
 TPolyLine3D.cxx:732
 TPolyLine3D.cxx:733
 TPolyLine3D.cxx:734
 TPolyLine3D.cxx:735
 TPolyLine3D.cxx:736
 TPolyLine3D.cxx:737
 TPolyLine3D.cxx:738
 TPolyLine3D.cxx:739
 TPolyLine3D.cxx:740
 TPolyLine3D.cxx:741
 TPolyLine3D.cxx:742
 TPolyLine3D.cxx:743
 TPolyLine3D.cxx:744
 TPolyLine3D.cxx:745
 TPolyLine3D.cxx:746
 TPolyLine3D.cxx:747
 TPolyLine3D.cxx:748
 TPolyLine3D.cxx:749
 TPolyLine3D.cxx:750
 TPolyLine3D.cxx:751
 TPolyLine3D.cxx:752
 TPolyLine3D.cxx:753
 TPolyLine3D.cxx:754
 TPolyLine3D.cxx:755