mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0022913: Clean up source repository from unused files
Changes Removed unused files. Files in QAResources have been moved to DrawResources Removing unused files from NCollection (see #23041)
This commit is contained in:
parent
9d35f66806
commit
5fdb6d685b
10
adm/QA.tcl
10
adm/QA.tcl
@ -1,10 +0,0 @@
|
||||
global tcl_platform
|
||||
|
||||
if {[array get env QA_DUMP] != "" && $env(QA_DUMP) == "1"} {
|
||||
puts "QA commands have been loaded"
|
||||
set env(QADEFAULT) $env(CASROOT)/src/QAResources/QADrawAppliInit
|
||||
set env(QA_LD_LIBRARY_PATH) $env(CASROOT)/sun/lib/.
|
||||
set env(DRAWDEFAULTOLD) $env(DRAWDEFAULT)
|
||||
set env(DRAWDEFAULT) "$env(QADEFAULT)"
|
||||
set env(CSF_DrawPluginQADefaults) $env(CASROOT)/src/QAResources/.
|
||||
}
|
@ -1,22 +0,0 @@
|
||||
-- Copyright (c) 1998-1999 Matra Datavision
|
||||
-- Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
--
|
||||
-- The content of this file is subject to the Open CASCADE Technology Public
|
||||
-- License Version 6.5 (the "License"). You may not use the content of this file
|
||||
-- except in compliance with the License. Please obtain a copy of the License
|
||||
-- at http://www.opencascade.org and read it completely before using this file.
|
||||
--
|
||||
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
--
|
||||
-- The Original Code and all software distributed under the License is
|
||||
-- distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
-- Initial Developer hereby disclaims all such warranties, including without
|
||||
-- limitation, any warranties of merchantability, fitness for a particular
|
||||
-- purpose or non-infringement. Please see the License for the specific terms
|
||||
-- and conditions governing the rights and limitations under the License.
|
||||
|
||||
|
||||
@ifdefined ( %Draw_WOKSteps_EDL) then
|
||||
@set %WOKSteps_XcppGroup = " xcpp.fill xcpp.src xcpp.header obj.cgen obj.inc";
|
||||
@endif;
|
18
src/DrawResources/DrawAppliInit
Normal file
18
src/DrawResources/DrawAppliInit
Normal file
@ -0,0 +1,18 @@
|
||||
global tcl_platform
|
||||
|
||||
if {[array get env QA_DUMP] != "" && $env(QA_DUMP) == "1"} {
|
||||
set env(CSF_DrawPluginQADefaults) $env(CASROOT)/src/DrawResources/.
|
||||
###catch {pload ALL}
|
||||
catch {pload FULL}
|
||||
#catch {pload -DrawPluginProducts ALL}
|
||||
catch {pload -DrawPluginProducts OMF CANONICALRECOGNITION EMESH PARASOLID DXF SAT }
|
||||
catch {pload QAcommands}
|
||||
|
||||
###foreach h [array names Draw_Groups] {
|
||||
### foreach f $Draw_Groups($h) {
|
||||
### QARebuild $f
|
||||
### }
|
||||
###}
|
||||
|
||||
catch {source $env(CSF_DrawPluginQADefaults)/QARebuildCommands}
|
||||
}
|
@ -47,3 +47,4 @@ XSDRAW : TKXSDRAW
|
||||
XDEDRAW : TKXDEDRAW
|
||||
TOBJ : TKTObjDRAW
|
||||
DFBROWSER : TKDFBrowser
|
||||
QAcommands : TKQADraw
|
||||
|
@ -37,3 +37,6 @@ srcinc:::wing.brep
|
||||
srcinc:::VisualizationDemo.tcl
|
||||
srcinc:::OCAFDemo.tcl
|
||||
srcinc:::TKTopTest.tcl
|
||||
srcinc:::dftree.tcl
|
||||
srcinc:::QARebuildCommands
|
||||
srcinc:::DrawAppliInit
|
||||
|
0
src/QAResources/QARebuildCommands → src/DrawResources/QARebuildCommands
Executable file → Normal file
0
src/QAResources/QARebuildCommands → src/DrawResources/QARebuildCommands
Executable file → Normal file
@ -1,645 +0,0 @@
|
||||
-- Created on: 1993-03-31
|
||||
-- Created by: NW,JPB,CAL
|
||||
-- Copyright (c) 1993-1999 Matra Datavision
|
||||
-- Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
--
|
||||
-- The content of this file is subject to the Open CASCADE Technology Public
|
||||
-- License Version 6.5 (the "License"). You may not use the content of this file
|
||||
-- except in compliance with the License. Please obtain a copy of the License
|
||||
-- at http://www.opencascade.org and read it completely before using this file.
|
||||
--
|
||||
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
--
|
||||
-- The Original Code and all software distributed under the License is
|
||||
-- distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
-- Initial Developer hereby disclaims all such warranties, including without
|
||||
-- limitation, any warranties of merchantability, fitness for a particular
|
||||
-- purpose or non-infringement. Please see the License for the specific terms
|
||||
-- and conditions governing the rights and limitations under the License.
|
||||
|
||||
-- Package : Graphic3d
|
||||
-- Updated : Vendredi 2 Octobre 1992
|
||||
-- Mercredi 31 Mars 1993
|
||||
-- Mercredi 19 Janvier 1994
|
||||
-- 1/08/97 ; PCT : Ajout texture mapping
|
||||
-- 11/97 ; CAL : retrait de la dependance avec math
|
||||
-- 11/97 ; CAL : retrait des DataStructure
|
||||
-- 11/97 ; CAL : ajout pointer StructPtr
|
||||
-- 04/98 ; FGU : ajout champs 'TOR_EMISSION'
|
||||
-- 16-09-98; BGN: (S3819) Ajout TypeOfTriedronEcho,
|
||||
-- TypeOfTriedronPosition.
|
||||
-- 22-09-98; BGN: S3989 (anciennement S3819): report
|
||||
-- dans Aspect des TypeOfTriedron*
|
||||
-- 26-03-99 : FMN ; Compatibilite ascendante:
|
||||
-- Ajout des anciens noms de materiaux.
|
||||
-- 09-04-99 : GG ; Compatibilite ascendante:
|
||||
-- NameOfPhysicalMaterial disparait
|
||||
-- 23-11-99 : GG ; Add material name DEFAULT
|
||||
-- 16-06-2000 : ATS : Study G005: class ArrayOfPrimitives
|
||||
-- and derivated used for model presentation.
|
||||
-- Required: enumeration TypeOfPrimitive;
|
||||
-- imported PrimitiveArray; class PrimitiveList.
|
||||
-- 17-12-01 : GG ; IMP171201 : Add material name UserDefined
|
||||
-- Thanks to Stephane ROUTELOUS
|
||||
-- 20-01-2009 : ABD Integration support of system fonts (using FTGL and FreeType)
|
||||
-- Objective : Specifications definitives
|
||||
|
||||
package Graphic3d
|
||||
|
||||
---Version:
|
||||
|
||||
---Purpose: This package permits the creation of 3d graphic objects
|
||||
-- in a visualiser.
|
||||
-- These objects, called structures, are composed of groups of
|
||||
-- primitives and attributes.
|
||||
-- The group is the smallest editable element of a structure.
|
||||
-- A structure can be displayed, erased, high-lighted.
|
||||
-- A transformation can be applied to it.
|
||||
-- Structures can be connected to form a tree of structures,
|
||||
-- composed by transformations.
|
||||
-- The visualiser permits global manipulation of structures.
|
||||
|
||||
---Keywords: Structure, Group, Primitives, Line, Marker, Text,
|
||||
-- FillAreas, Vertex, Vector, Material, Font, Shading
|
||||
---Warning:
|
||||
---References:
|
||||
|
||||
uses
|
||||
|
||||
TCollection,
|
||||
TColStd,
|
||||
OSD,
|
||||
Quantity,
|
||||
Aspect,
|
||||
MMgt,
|
||||
Xw,
|
||||
WNT,
|
||||
AlienImage,
|
||||
gp
|
||||
is
|
||||
|
||||
-----------------------
|
||||
-- Category: Exceptions
|
||||
-----------------------
|
||||
|
||||
exception AspectTextDefinitionError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception CycleError inherits DomainError;
|
||||
---Category: Exceptions
|
||||
|
||||
exception GroupDefinitionError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception InitialisationError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception MaterialDefinitionError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception PickIdDefinitionError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception PlotterDefinitionError inherits OutOfRange;
|
||||
---Category: The exceptions
|
||||
|
||||
exception PriorityDefinitionError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception StructureDefinitionError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception TransformError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
exception VectorError inherits OutOfRange;
|
||||
---Category: Exceptions
|
||||
|
||||
-------------------------
|
||||
-- Category: Enumerations
|
||||
-------------------------
|
||||
|
||||
enumeration NameOfMaterial is
|
||||
NOM_BRASS, -- laiton (PHYSIC)
|
||||
NOM_BRONZE, -- bronze (PHYSIC)
|
||||
NOM_COPPER, -- cuivre (PHYSIC)
|
||||
NOM_GOLD, -- or (PHYSIC)
|
||||
|
||||
NOM_PEWTER, -- etain (PHYSIC)
|
||||
|
||||
NOM_PLASTER, -- platre (GENERIC)
|
||||
NOM_PLASTIC, -- plastic (GENERIC)
|
||||
|
||||
NOM_SILVER, -- argent (PHYSIC)
|
||||
|
||||
NOM_STEEL, -- acier (PHYSIC)
|
||||
|
||||
NOM_STONE, -- pierre (PHYSIC)
|
||||
|
||||
NOM_SHINY_PLASTIC, -- plastique brillant (GENERIC)
|
||||
NOM_SATIN, -- satin (GENERIC)
|
||||
NOM_METALIZED, -- metallise New (GENERIC)
|
||||
NOM_NEON_GNC, -- neon New (GENERIC)
|
||||
NOM_CHROME, -- chrome New (PHYSIC)
|
||||
NOM_ALUMINIUM, -- aluminium New (PHYSIC)
|
||||
NOM_OBSIDIAN, -- obsidian New (PHYSIC)
|
||||
NOM_NEON_PHC, -- neon New (PHYSIC)
|
||||
NOM_JADE, -- jade New (PHYSIC)
|
||||
NOM_DEFAULT,
|
||||
NOM_UserDefined -- owner material
|
||||
end NameOfMaterial;
|
||||
---Purpose: Types of aspect materials.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfMaterial is MATERIAL_ASPECT, -- Materiel generique
|
||||
MATERIAL_PHYSIC -- Materiel physique
|
||||
end TypeOfMaterial;
|
||||
---Purpose: Types of materials specifies if a material can change color.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration NameOfTexture1D is NOT_1D_ELEVATION,
|
||||
NOT_1D_UNKNOWN
|
||||
end NameOfTexture1D;
|
||||
---Purpose: Types of standard textures.
|
||||
---Category: Enumerations
|
||||
|
||||
|
||||
enumeration NameOfTexture2D is NOT_2D_MATRA,
|
||||
NOT_2D_ALIENSKIN,
|
||||
NOT_2D_BLUE_ROCK,
|
||||
NOT_2D_BLUEWHITE_PAPER,
|
||||
NOT_2D_BRUSHED,
|
||||
NOT_2D_BUBBLES,
|
||||
NOT_2D_BUMP,
|
||||
NOT_2D_CAST,
|
||||
NOT_2D_CHIPBD,
|
||||
NOT_2D_CLOUDS,
|
||||
NOT_2D_FLESH,
|
||||
NOT_2D_FLOOR,
|
||||
NOT_2D_GALVNISD,
|
||||
NOT_2D_GRASS,
|
||||
NOT_2D_ALUMINUM,
|
||||
NOT_2D_ROCK,
|
||||
NOT_2D_KNURL,
|
||||
NOT_2D_MAPLE,
|
||||
NOT_2D_MARBLE,
|
||||
NOT_2D_MOTTLED,
|
||||
NOT_2D_RAIN,
|
||||
NOT_2D_UNKNOWN
|
||||
end NameOfTexture2D;
|
||||
---Purpose: Types of standard textures.
|
||||
---Category: Enumerations
|
||||
|
||||
|
||||
enumeration NameOfTextureEnv is NOT_ENV_CLOUDS,
|
||||
NOT_ENV_CV,
|
||||
NOT_ENV_MEDIT,
|
||||
NOT_ENV_PEARL,
|
||||
NOT_ENV_SKY1,
|
||||
NOT_ENV_SKY2,
|
||||
NOT_ENV_LINES,
|
||||
NOT_ENV_ROAD,
|
||||
NOT_ENV_UNKNOWN
|
||||
end NameOfTextureEnv;
|
||||
---Purpose: Types of standard textures.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfTexture is TOT_1D,
|
||||
TOT_2D,
|
||||
TOT_2D_MIPMAP;
|
||||
---Purpose: Type of the texture file format.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfTextureMode is TOTM_OBJECT,
|
||||
TOTM_SPHERE,
|
||||
TOTM_EYE,
|
||||
TOTM_MANUAL;
|
||||
---Purpose: Type of the texture projection.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration NameOfTexturePlane is NOTP_XY,
|
||||
NOTP_YZ,
|
||||
NOTP_ZX,
|
||||
NOTP_UNKNOWN;
|
||||
---Purpose: Type of the texture projection plane for both S and T texture coordinate.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfComposition is TOC_REPLACE,
|
||||
TOC_POSTCONCATENATE
|
||||
end TypeOfComposition;
|
||||
---Purpose: To manage the transformation matrices of structures.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfConnection is TOC_ANCESTOR,
|
||||
TOC_DESCENDANT
|
||||
end TypeOfConnection;
|
||||
---Purpose: To manage the connections between the structures.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfPolygon is TOP_UNKNOWN,
|
||||
TOP_COMPLEX,
|
||||
TOP_CONCAVE,
|
||||
TOP_CONVEX
|
||||
end TypeOfPolygon;
|
||||
---Purpose: The type of polygon in a group in a structure.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfPrimitive is TOP_UNDEFINED,
|
||||
TOP_POLYLINE,
|
||||
TOP_POLYGON,
|
||||
TOP_TRIANGLEMESH,
|
||||
TOP_QUADRANGLEMESH,
|
||||
TOP_TEXT,
|
||||
TOP_MARKER,
|
||||
TOP_PARRAY
|
||||
end TypeOfPrimitive;
|
||||
---Purpose: The type of primitive in a group in a structure.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfPrimitiveArray is TOPA_UNDEFINED,
|
||||
TOPA_POINTS,
|
||||
TOPA_POLYLINES,
|
||||
TOPA_SEGMENTS,
|
||||
TOPA_POLYGONS,
|
||||
TOPA_TRIANGLES,
|
||||
TOPA_QUADRANGLES,
|
||||
TOPA_TRIANGLESTRIPS,
|
||||
TOPA_QUADRANGLESTRIPS,
|
||||
TOPA_TRIANGLEFANS
|
||||
end TypeOfPrimitiveArray;
|
||||
---Purpose: The type of primitive array in a group in a structure.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfReflection is TOR_AMBIENT,
|
||||
TOR_DIFFUSE,
|
||||
TOR_SPECULAR,
|
||||
TOR_EMISSION
|
||||
end TypeOfReflection;
|
||||
---Purpose: Nature of the reflection of a material.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TypeOfStructure is TOS_WIREFRAME,
|
||||
TOS_SHADING,
|
||||
TOS_COMPUTED,
|
||||
TOS_ALL
|
||||
end TypeOfStructure;
|
||||
---Purpose: Structural attribute indicating if it can be displayed
|
||||
-- in wireframe, shadow mode, or both.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration TextPath is TP_UP,
|
||||
TP_DOWN,
|
||||
TP_LEFT,
|
||||
TP_RIGHT
|
||||
end TextPath;
|
||||
---Purpose: Direction in which text is displayed.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration HorizontalTextAlignment is HTA_LEFT,
|
||||
HTA_CENTER,
|
||||
HTA_RIGHT
|
||||
end HorizontalTextAlignment;
|
||||
---Purpose: Defines the horizontal position of the text
|
||||
-- relative to its anchor.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration VerticalTextAlignment is VTA_BOTTOM,
|
||||
VTA_CENTER,
|
||||
VTA_TOP
|
||||
end VerticalTextAlignment;
|
||||
---Purpose: Defines the vertical position of the text
|
||||
-- relative to its anchor.
|
||||
---Category: Enumerations
|
||||
|
||||
enumeration GroupAspect is ASPECT_LINE,
|
||||
ASPECT_TEXT,
|
||||
ASPECT_MARKER,
|
||||
ASPECT_FILL_AREA
|
||||
end GroupAspect;
|
||||
---Purpose: Identifies primitives aspects defined per group.
|
||||
-- - ASPECT_LINE: aspect for line primitives;
|
||||
-- - ASPECT_TEXT: aspect for text primitives;
|
||||
-- - ASPECT_MARKER: aspect for marker primitives;
|
||||
-- - ASPECT_FILL_AREA: aspect for face primitives.
|
||||
|
||||
---------------------------
|
||||
-- Category: Imported types
|
||||
---------------------------
|
||||
|
||||
imported PrimitiveArray;
|
||||
|
||||
imported CBitFields20;
|
||||
---Purpose: Defines the C structure
|
||||
---Category: Imported types
|
||||
|
||||
imported CBitFields16;
|
||||
---Purpose: Defines the C structure
|
||||
---Category: Imported types
|
||||
|
||||
imported CBitFields8;
|
||||
---Purpose: Defines the C structure
|
||||
---Category: Imported types
|
||||
|
||||
imported CBitFields4;
|
||||
---Purpose: Defines the C structure
|
||||
---Category: Imported types
|
||||
|
||||
imported CGroup;
|
||||
---Purpose: Defines the C structure <agroup>
|
||||
---Category: Imported types
|
||||
|
||||
imported CStructure;
|
||||
---Purpose: Defines the C structure <astructure>
|
||||
---Category: Imported types
|
||||
|
||||
imported CLight;
|
||||
---Purpose: Defines the C structure <alight>
|
||||
---Category: Imported types
|
||||
|
||||
imported CPick;
|
||||
---Purpose: Defines the C structure <apick>
|
||||
---Category: Imported types
|
||||
|
||||
imported CPlane;
|
||||
---Purpose: Defines the C structure <aplane>
|
||||
---Category: Imported types
|
||||
|
||||
imported CBounds;
|
||||
---Purpose: Defines the C structure <abounds>
|
||||
---Category: Imported types
|
||||
|
||||
imported CUserDraw;
|
||||
---Purpose: Defines the C structure <auserdraw>
|
||||
---Category: Imported types
|
||||
|
||||
imported CView;
|
||||
---Purpose: Defines the C structure <aview>
|
||||
---Category: Imported types
|
||||
|
||||
imported CGraduatedTrihedron;
|
||||
---Purpose: Defines the C structure of a graduated trihedron.
|
||||
---Category: Imported types
|
||||
|
||||
imported CInitTexture;
|
||||
imported CTexture;
|
||||
|
||||
-- ABD 29/10/04 Transform Persistence of Presentation( pan, zoom, rotate )
|
||||
imported CTransPersStruct;
|
||||
imported TransModeFlags;
|
||||
-- ABD 29/10/04 Transform Persistence of Presentation( pan, zoom, rotate )
|
||||
|
||||
|
||||
--------------------
|
||||
-- Category: Classes
|
||||
--------------------
|
||||
|
||||
class Strips;
|
||||
---Purpose: Contains some static functions to strips treatment
|
||||
|
||||
deferred class ArrayOfPrimitives;
|
||||
---Purpose: Contains basic methods for array allocation and filling
|
||||
|
||||
class ArrayOfPoints;
|
||||
---Purpose: Contains points array definition
|
||||
|
||||
class ArrayOfPolylines;
|
||||
---Purpose: Contains polylines array definition
|
||||
|
||||
class ArrayOfSegments;
|
||||
---Purpose: Contains segments array definition
|
||||
|
||||
class ArrayOfPolygons;
|
||||
---Purpose: Contains polygons array definition
|
||||
|
||||
class ArrayOfTriangles;
|
||||
---Purpose: Contains triangles array definition
|
||||
|
||||
class ArrayOfTriangleStrips;
|
||||
---Purpose: Contains triangles strip array definition
|
||||
|
||||
class ArrayOfTriangleFans;
|
||||
---Purpose: Contains triangles fan array definition
|
||||
|
||||
class ArrayOfQuadrangles;
|
||||
---Purpose: Contains quatrangles array definition
|
||||
|
||||
class ArrayOfQuadrangleStrips;
|
||||
---Purpose: Contains quadrangles strip array definition
|
||||
|
||||
class AspectLine3d;
|
||||
---Purpose: Grouping line attributes
|
||||
---Category: Classes
|
||||
|
||||
class AspectFillArea3d;
|
||||
---Purpose: Grouping face attributes
|
||||
---Category: Classes
|
||||
|
||||
class AspectMarker3d;
|
||||
---Purpose: Grouping marker attributes
|
||||
---Category: Classes
|
||||
|
||||
class AspectText3d;
|
||||
---Purpose: Grouping text attributes.
|
||||
---Category: Classes
|
||||
|
||||
class Group;
|
||||
---Purpose: For grouping together primitives in a structure
|
||||
---Category: Classes
|
||||
|
||||
class GraphicDevice;
|
||||
---Purpose: Defines a physical graphic device allowing to
|
||||
-- shares graphical ressources.
|
||||
---Category: Classes
|
||||
|
||||
class WNTGraphicDevice;
|
||||
---Purpose: Defines a physical graphic device for Windows NT
|
||||
---Category: Classes
|
||||
|
||||
class MaterialAspect;
|
||||
---Purpose: Aspect attributes of a 3d face.
|
||||
---Category: Classes
|
||||
|
||||
class Structure;
|
||||
---Purpose: Graphic object.
|
||||
---Category: Classes
|
||||
|
||||
deferred class GraphicDriver;
|
||||
---Purpose: Defines a graphic driver for 3d interface
|
||||
|
||||
deferred class StructureManager;
|
||||
---Purpose: Visualiser with which the graphic objects are associated.
|
||||
---Category: Classes
|
||||
|
||||
deferred class DataStructureManager;
|
||||
---Purpose: Visualiser with which the graphic objects are associated.
|
||||
---Category: Classes
|
||||
|
||||
deferred class Plotter;
|
||||
---Purpose: Defines the minimal plotter.
|
||||
---Category: The classes
|
||||
|
||||
class Vector;
|
||||
---Purpose: 3d vector
|
||||
---Category: Classes
|
||||
|
||||
class Vertex;
|
||||
---Purpose: 3d vertex
|
||||
---Category: Classes
|
||||
|
||||
class VertexN;
|
||||
---Purpose: 3d vertex with a normal vector
|
||||
---Category: Classes
|
||||
|
||||
class VertexNT;
|
||||
---Purpose: 3d vertex with a normal vector and texture coordinate
|
||||
---Category: Classes
|
||||
|
||||
class VertexC;
|
||||
---Purpose: 3d vertex with a colour
|
||||
---Category: Classes
|
||||
|
||||
class VertexNC;
|
||||
---Purpose: 3d vertex with a normal and a colour
|
||||
---Category: Classes
|
||||
|
||||
---------------------
|
||||
-- Category: Pointers
|
||||
---------------------
|
||||
|
||||
pointer StructPtr to Structure from Graphic3d;
|
||||
---Category: Pointers
|
||||
|
||||
---------------------------------
|
||||
-- Category: Instantiated classes
|
||||
---------------------------------
|
||||
|
||||
class ListOfPArray instantiates
|
||||
List from TCollection (ArrayOfPrimitives from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class SequenceOfAddress instantiates
|
||||
Sequence from TCollection
|
||||
(Address from Standard);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class SetOfGroup instantiates
|
||||
Set from TCollection (Group from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class HSetOfGroup instantiates
|
||||
HSet from TCollection
|
||||
(Group from Graphic3d, SetOfGroup);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class SequenceOfGroup instantiates
|
||||
Sequence from TCollection (Group from Graphic3d);
|
||||
|
||||
---Category: Instantiated classes
|
||||
|
||||
class HSequenceOfGroup instantiates
|
||||
HSequence from TCollection
|
||||
(Group from Graphic3d, SequenceOfGroup from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class MapOfStructure instantiates
|
||||
Map from TCollection (Structure from Graphic3d,MapTransientHasher from TColStd);
|
||||
|
||||
|
||||
---Category: Instantiated classes
|
||||
|
||||
class SequenceOfStructure instantiates
|
||||
Sequence from TCollection
|
||||
(Structure from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class HSequenceOfStructure instantiates
|
||||
HSequence from TCollection
|
||||
(Structure from Graphic3d, SequenceOfStructure from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array1OfVector instantiates
|
||||
Array1 from TCollection (Vector from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array1OfVertex instantiates
|
||||
Array1 from TCollection (Vertex from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array2OfVertex instantiates
|
||||
Array2 from TCollection (Vertex from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array1OfVertexC instantiates
|
||||
Array1 from TCollection (VertexC from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array2OfVertexC instantiates
|
||||
Array2 from TCollection (VertexC from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array1OfVertexN instantiates
|
||||
Array1 from TCollection (VertexN from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array2OfVertexN instantiates
|
||||
Array2 from TCollection (VertexN from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array1OfVertexNT instantiates
|
||||
Array1 from TCollection (VertexNT from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array2OfVertexNT instantiates
|
||||
Array2 from TCollection (VertexNT from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array1OfVertexNC instantiates
|
||||
Array1 from TCollection (VertexNC from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class Array2OfVertexNC instantiates
|
||||
Array2 from TCollection (VertexNC from Graphic3d);
|
||||
---Category: Instantiated classes
|
||||
|
||||
class ListOfShortReal instantiates
|
||||
List from TCollection (ShortReal from Standard);
|
||||
---Category: Instantiated classes
|
||||
|
||||
--ABD Integration support of system fonts (using FTGL and FreeType)
|
||||
imported NListOfHAsciiString;
|
||||
---Category: Instantiated classes
|
||||
|
||||
|
||||
deferred class TextureRoot from Graphic3d;
|
||||
deferred class TextureMap from Graphic3d;
|
||||
deferred class Texture1D from Graphic3d;
|
||||
deferred class Texture2D from Graphic3d;
|
||||
|
||||
class TextureEnv from Graphic3d;
|
||||
class Texture1Dmanual from Graphic3d;
|
||||
class Texture1Dsegment from Graphic3d;
|
||||
class Texture2Dmanual from Graphic3d;
|
||||
class Texture2Dplane from Graphic3d;
|
||||
|
||||
|
||||
enumeration ExportFormat is
|
||||
|
||||
EF_PostScript,
|
||||
EF_EnhPostScript,
|
||||
EF_TEX,
|
||||
EF_PDF,
|
||||
EF_SVG,
|
||||
EF_PGF
|
||||
|
||||
end ExportFormat;
|
||||
|
||||
|
||||
enumeration SortType is
|
||||
|
||||
ST_Simple, -- sorting by depth of center point of primitive(fast)
|
||||
ST_BSP_Tree -- sorting by BSPTree (slow, but fine result )
|
||||
|
||||
end SortType;
|
||||
|
||||
end Graphic3d;
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1995-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
-- Copyright (c) 1995-1999 Matra Datavision
|
||||
-- Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
--
|
||||
-- The content of this file is subject to the Open CASCADE Technology Public
|
||||
-- License Version 6.5 (the "License"). You may not use the content of this file
|
||||
-- except in compliance with the License. Please obtain a copy of the License
|
||||
-- at http://www.opencascade.org and read it completely before using this file.
|
||||
--
|
||||
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
--
|
||||
-- The Original Code and all software distributed under the License is
|
||||
-- distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
-- Initial Developer hereby disclaims all such warranties, including without
|
||||
-- limitation, any warranties of merchantability, fitness for a particular
|
||||
-- purpose or non-infringement. Please see the License for the specific terms
|
||||
-- and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1995-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1995-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
-- Copyright (c) 1995-1999 Matra Datavision
|
||||
-- Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
--
|
||||
-- The content of this file is subject to the Open CASCADE Technology Public
|
||||
-- License Version 6.5 (the "License"). You may not use the content of this file
|
||||
-- except in compliance with the License. Please obtain a copy of the License
|
||||
-- at http://www.opencascade.org and read it completely before using this file.
|
||||
--
|
||||
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
--
|
||||
-- The Original Code and all software distributed under the License is
|
||||
-- distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
-- Initial Developer hereby disclaims all such warranties, including without
|
||||
-- limitation, any warranties of merchantability, fitness for a particular
|
||||
-- purpose or non-infringement. Please see the License for the specific terms
|
||||
-- and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1995-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1995-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1995-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
-- Copyright (c) 1995-1999 Matra Datavision
|
||||
-- Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
--
|
||||
-- The content of this file is subject to the Open CASCADE Technology Public
|
||||
-- License Version 6.5 (the "License"). You may not use the content of this file
|
||||
-- except in compliance with the License. Please obtain a copy of the License
|
||||
-- at http://www.opencascade.org and read it completely before using this file.
|
||||
--
|
||||
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
--
|
||||
-- The Original Code and all software distributed under the License is
|
||||
-- distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
-- Initial Developer hereby disclaims all such warranties, including without
|
||||
-- limitation, any warranties of merchantability, fitness for a particular
|
||||
-- purpose or non-infringement. Please see the License for the specific terms
|
||||
-- and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1995-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -61,8 +61,6 @@ NCollection_BaseVector.cxx
|
||||
NCollection_Vector.hxx
|
||||
NCollection_DefineVector.hxx
|
||||
NCollection_StdBase.hxx
|
||||
templates2macros.sh
|
||||
NCollection.mdl.gz
|
||||
|
||||
NCollection_EBTree.hxx
|
||||
NCollection_UBTree.hxx
|
||||
|
Binary file not shown.
@ -1,237 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
FILES='
|
||||
NCollection_Array1.hxx
|
||||
NCollection_Array2.hxx
|
||||
NCollection_List.hxx
|
||||
NCollection_Map.hxx
|
||||
NCollection_DataMap.hxx
|
||||
NCollection_DoubleMap.hxx
|
||||
NCollection_IndexedMap.hxx
|
||||
NCollection_IndexedDataMap.hxx
|
||||
NCollection_Queue.hxx
|
||||
NCollection_SList.hxx
|
||||
NCollection_Sequence.hxx
|
||||
NCollection_Set.hxx
|
||||
NCollection_Stack.hxx
|
||||
NCollection_Vector.hxx
|
||||
NCollection_BaseCollection.hxx
|
||||
NCollection_TListIterator.hxx
|
||||
NCollection_TListNode.hxx
|
||||
NCollection_HArray1.hxx
|
||||
NCollection_HArray2.hxx
|
||||
NCollection_HSequence.hxx
|
||||
NCollection_HSet.hxx'
|
||||
|
||||
#FILES=NCollection_Array2.hxx
|
||||
|
||||
for IN_FILE in $FILES; do
|
||||
### for IN_FILE in $*; do
|
||||
OUT_FILE=`echo $IN_FILE | sed 's/_/_Define/'`
|
||||
gawk '
|
||||
|
||||
# ------ Function: Print the backslash in the 79th position
|
||||
function PrintBSL(str) {
|
||||
str0 = " "
|
||||
len = length (str)
|
||||
if (len > 78) $0 = str " \\"
|
||||
else $0 = str substr(str0, 1, 79-len) "\\"
|
||||
}
|
||||
# -------------- Check and corect the file header -----------
|
||||
/\/\/ *Copyright *:/ {
|
||||
print "// Automatically created from " in_file " by GAWK"
|
||||
}
|
||||
/\/\/ *File *:/ ||
|
||||
/#(ifndef|define) *NCollection_/ {
|
||||
gsub ("NCollection_","NCollection_Define")
|
||||
}
|
||||
|
||||
# --------------- Modify the include statement for used templates ------
|
||||
/^ *\#include <NCollection_BaseCollection.hxx>/ {
|
||||
print "\#include <NCollection_DefineBaseCollection.hxx>"
|
||||
next
|
||||
}
|
||||
/^ *\#include <NCollection_T[A-Za-z]*\.hxx>/ {
|
||||
gsub ("NCollection_T","NCollection_DefineT")
|
||||
}
|
||||
/^ *\#include <NCollection_Array[12]\.hxx>/ {
|
||||
gsub ("NCollection_Array","NCollection_DefineArray")
|
||||
}
|
||||
/^ *\#include <NCollection_Sequence\.hxx>/ {
|
||||
gsub ("NCollection_Sequence","NCollection_DefineSequence")
|
||||
}
|
||||
/^ *\#include <NCollection_Set\.hxx>/ {
|
||||
gsub ("NCollection_Set","NCollection_DefineSet")
|
||||
}
|
||||
|
||||
# -------------- Replace line #define NCOLLECTION_H... -----------------
|
||||
/^ *#define NCOLLECTION_H.*\(.*\).*$/ {
|
||||
defh = $0
|
||||
do getline defcl; while (defcl ~ /^ *\\/)
|
||||
coll_type = gensub ("^.*public *NCollection_\([A-Za-z0-9_]*\) *<Type>.*$",
|
||||
"\\1", 1, defcl)
|
||||
gsub (", *Type\\)",", _" coll_type "Type_\)", defh)
|
||||
gsub (" *\\\\$","", defh)
|
||||
PrintBSL(gensub ("NCOLLECTION_","DEFINE_", 1, defh))
|
||||
print
|
||||
PrintBSL("")
|
||||
print
|
||||
gsub ("NCollection_" coll_type " *<Type>", "_" coll_type "Type_", defcl)
|
||||
PrintBSL(gensub ("^\(.*\) *\\\\$","\\1", 1, defcl))
|
||||
print
|
||||
flag = 10
|
||||
next
|
||||
}
|
||||
|
||||
# -------------- Replace the line "\#define ...." for "template ...." --
|
||||
/^ *template *< *class/,/^ *{ *$/ {
|
||||
if (flag == 0) {
|
||||
type = gensub ("^ *template.*NCollection_\([A-Za-z0-9]*\).*$","\\1","g")
|
||||
item_t = gensub("^ *template *< *class *\([A-Za-z0-9_]*\) *\(,|>\).*$",\
|
||||
"\\1",1)
|
||||
item_tt= gensub("^ *template.*, *class *\([A-Za-z0-9_]*\) *\(,|>\).*$",\
|
||||
"\\1",1)
|
||||
if (item_tt == $0) item_tt = ""
|
||||
if (type == "BaseCollection")
|
||||
PrintBSL("#define DEFINE_" toupper(type) "(_ClassName_, "item_t")")
|
||||
else if (item_tt == "")
|
||||
PrintBSL("#define DEFINE_" toupper(type) \
|
||||
"(_ClassName_, _BaseCollection_, " item_t ")")
|
||||
else
|
||||
PrintBSL("#define DEFINE_" toupper(type) \
|
||||
"(_ClassName_, _BaseCollection_, " item_t ", " item_tt ")")
|
||||
# Special addition for the Iterator
|
||||
if (type == "TListIterator")
|
||||
{
|
||||
print
|
||||
PrintBSL("DEFINE_TLISTNODE(TListNode, _BaseCollection_, " item_t ")")
|
||||
}
|
||||
flag = 1
|
||||
} else if (flag == 1) {
|
||||
gsub ("^ *", "class _ClassName_ ")
|
||||
flag = 2
|
||||
}
|
||||
}
|
||||
|
||||
# --------------- Detect the final line of the template class definition ----
|
||||
/^}; *$/{ flag = 0 }
|
||||
|
||||
# --------------- Replace C-style comments for C++-style ones ---------------
|
||||
/\/\// { if (flag == 2) $0=gensub ("// *\(.*\) *$","/\* \\1 \*/", "g") }
|
||||
|
||||
# --------------- Replace "Raise_if.." for "#ifdef DEB ..::Raise.. #endif" --
|
||||
/^\# *ifdef *DEB/ {
|
||||
nline = 0
|
||||
if (flag == 0) {
|
||||
while (1) {
|
||||
getline debl
|
||||
if (debl ~ /^\# *endif/) break;
|
||||
print debl
|
||||
}
|
||||
} else {
|
||||
getline debl;
|
||||
if (debl !~ /^ *if *\(/) {
|
||||
print "ERROR: in " in_file " cannot find if after \#ifdef DEB" \
|
||||
> "/dev/stderr"
|
||||
exit 1
|
||||
}
|
||||
if (debl ~ /^ *if *\(.*\) *$/)
|
||||
condl = gensub ("^ *if *\\( *(.*) *\\) *$", "\\1", 1, debl)
|
||||
else
|
||||
condl = gensub ("^ *if *\\( *(.*) *$", "\\1", 1, debl)
|
||||
while(1) {
|
||||
getline debl;
|
||||
if (debl ~ /^\# *endif/) break;
|
||||
if (debl !~ /Standard.*::Raise/)
|
||||
condl = gensub("^ *(.*[^\\)]) *($|\\) *$)", condl "\\1", 1, debl)
|
||||
else {
|
||||
PrintBSL(gensub ("^ \(.*\):: *Raise *\\(.*$",
|
||||
"\\1_Raise_if", 1, debl))
|
||||
print
|
||||
PrintBSL(gensub ("^ ( *)Standard.*Raise *\\( *\"NCollection_" \
|
||||
type "(.*)\" *\\) *\; *$",
|
||||
"\\1 (" condl ", #_ClassName_ \"\\2\")\;",
|
||||
1, debl))
|
||||
print
|
||||
}
|
||||
}
|
||||
}
|
||||
next
|
||||
}
|
||||
|
||||
# --------------- Remove #pragma warning (default:4291) from the output -----
|
||||
/^\# *ifdef WNT/ {
|
||||
defh = $0
|
||||
has_printed = 0
|
||||
while (1) {
|
||||
getline defcl
|
||||
if (defcl ~ /^[ \t]*$/) continue;
|
||||
if (defcl ~ /^\# *pragma +warning *\(default *: *4291 *\)/) continue;
|
||||
if (defcl ~ /^\# *endif/) {
|
||||
if (has_printed) print defcl
|
||||
break
|
||||
}
|
||||
if (has_printed == 0) {
|
||||
has_printed = 1
|
||||
print defh
|
||||
}
|
||||
print defcl
|
||||
}
|
||||
next
|
||||
}
|
||||
|
||||
# --------------- Replace "DEFINE_T.*..." for typedef ... -------------------
|
||||
# in classes List, Queue, Set, Stack
|
||||
/^ *typedef NCollection_T[A-Za-z]*<TheItemType>/ {
|
||||
if (flag > 1) {
|
||||
tsup = gensub("^ *typedef.*NCollection_\([A-Za-z0-9]*\).*$","\\1",1)
|
||||
tdef = gensub("^ *typedef.*<[A-Za-z0-9]*> *([A-Za-z0-9]*)\;.*$","\\1",1)
|
||||
gsub ("typedef.*$", "DEFINE_" toupper(tsup) "(" tdef \
|
||||
",_BaseCollection_," item_t ")")
|
||||
}
|
||||
}
|
||||
|
||||
# --------------- Replace public T* with DEFINE... --------------------------
|
||||
/^ *class.*: *public *NCollection_T[A-Za-z]*<.*>/ {
|
||||
if (flag > 1) {
|
||||
ttempl = gensub("^ *class.*: *public *(NCollection_T[A-Za-z0-9]*<.*>).*$","\\1",1)
|
||||
tshort = gensub("^ *class.*: *public *NCollection_(T[A-Za-z0-9]*)<.*$","\\1",1)
|
||||
spub = gensub("(^ *class.*: *public *)NCollection_(T[A-Za-z0-9]*)<.*($)",
|
||||
"\\1\\2\\3",1)
|
||||
tpara = gensub("^.*<(.*)>","\\1",1)
|
||||
PrintBSL(" DEFINE_" toupper(tshort) "(" tshort ",_BaseCollection_," tpara ")")
|
||||
print
|
||||
PrintBSL(spub)
|
||||
print
|
||||
next
|
||||
}
|
||||
}
|
||||
|
||||
# ------- General case: replace the macro parameter for class name and print -
|
||||
{ if (flag == 10) {
|
||||
nsub = gsub ("NCollection_" coll_type " *<Type>",
|
||||
"_" coll_type "Type_")
|
||||
if (nsub) {
|
||||
gsub (" *\\\\$","")
|
||||
PrintBSL($0)
|
||||
}
|
||||
} else if (flag > 1) {
|
||||
gsub ("NCollection_BaseCollection *< *\("item_t"|"item_tt"\) *>", \
|
||||
"_BaseCollection_")
|
||||
gsub ("NCollection_TListNode *< *\("item_t"|"item_tt"\) *>", \
|
||||
"TListNode")
|
||||
gsub ("NCollection_TListIterator *< *\("item_t"|"item_tt"\) *>", \
|
||||
"TListIterator")
|
||||
gsub (ttempl, tshort)
|
||||
gsub (":: *Raise *\\( *\"NCollection_" type,
|
||||
"::Raise (#_ClassName_ \"")
|
||||
PrintBSL(gensub ("NCollection_" type \
|
||||
"\(<"item_t">|<"item_tt">|\)\(\[^A-Za-z\]|$\)", \
|
||||
"_ClassName_\\2","g"))
|
||||
}
|
||||
print
|
||||
}
|
||||
|
||||
' in_file=$IN_FILE out_file=$OUT_FILE $IN_FILE > $OUT_FILE
|
||||
echo "\t$IN_FILE converted to $OUT_FILE"
|
||||
done
|
@ -1,17 +0,0 @@
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,17 +0,0 @@
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1 +0,0 @@
|
||||
QAcommands : TKQADraw
|
@ -1 +0,0 @@
|
||||
QAcommands : TKQADraw
|
@ -1,18 +0,0 @@
|
||||
global tcl_platform
|
||||
|
||||
source $env(DRAWDEFAULTOLD)
|
||||
|
||||
###catch {pload ALL}
|
||||
catch {pload FULL}
|
||||
#catch {pload -DrawPluginProducts ALL}
|
||||
catch {pload -DrawPluginProducts OMF CANONICALRECOGNITION EMESH PARASOLID DXF SAT }
|
||||
catch {pload -DrawPluginQA QAcommands}
|
||||
|
||||
###foreach h [array names Draw_Groups] {
|
||||
### foreach f $Draw_Groups($h) {
|
||||
### QARebuild $f
|
||||
### }
|
||||
###}
|
||||
|
||||
catch {source $env(CSF_DrawPluginQADefaults)/QARebuildCommands}
|
||||
|
@ -1,18 +0,0 @@
|
||||
// Copyright (c) 1998-1999 Matra Datavision
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -4,6 +4,5 @@ icon:::MDTV-Standard.xwd
|
||||
loginfile:::Plugin
|
||||
appresource:::XCAF
|
||||
appresource:::TObj
|
||||
srcinc:::dftree.tcl
|
||||
appresource:::StandardLite
|
||||
appresource:::MigrationSheet.txt
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1,74 +0,0 @@
|
||||
MASS: kg
|
||||
LENGTH: m
|
||||
TIME: s
|
||||
ELECTRIC CURRENT: A
|
||||
THERMODYNAMIC TEMPERATURE: °K
|
||||
AMOUNT OF SUBSTANCE: mol
|
||||
PLANE ANGLE: rad
|
||||
SOLID ANGLE: sr
|
||||
AREA: m²
|
||||
VOLUME: m³
|
||||
INERTIA: m**4
|
||||
ANGULAR SPEED: rad/s
|
||||
SPEED: m/s
|
||||
ACCELERATION: m/s²
|
||||
FREQUENCY: Hz
|
||||
VOLUMIC MASS: kg/m³
|
||||
MASS FLOW: kg/s
|
||||
VOLUME FLOW: m³/s
|
||||
CONSUMPTION: m²
|
||||
QUANTITY OF MOVEMENT: kg*m/s
|
||||
KINETIC MOMENT: kg*m²/s
|
||||
MOMENT OF INERTIA: kg*m²
|
||||
FORCE: N
|
||||
MOMENT OF A FORCE: N*m
|
||||
LINEIC FORCE: N/m
|
||||
PRESSURE: Pa
|
||||
DYNAMIC VISCOSITY: Pa/s
|
||||
KINETIC VISCOSITY: m²/s
|
||||
TENSION SUPERFICIELLE: m/s²
|
||||
ELECTRIC POTENTIAL: V
|
||||
ENERGY: J
|
||||
POWER: W
|
||||
LINEIC POWER: W/m
|
||||
SURFACIC POWER: W/m²
|
||||
VOLUMIC POWER: W/m³
|
||||
COEFFICIENT OF LINEAR INFLATION: 1./°K
|
||||
THERMICAL CONDUCTIVITY: W/m/°K
|
||||
THERMICAL CONVECTIVITY: W/m²/°K
|
||||
THERMICAL MASSIC CAPACITY: J/kg/°K
|
||||
ENTROPY: J/°K
|
||||
ENTHALPY: J
|
||||
LUMINOUS FLUX: Lu
|
||||
LUMINANCE: cd/m²
|
||||
EXITANCE: lx
|
||||
LUMINOUS INTENSITY: cd
|
||||
LUMINOUS EXPOSITION: lx*s
|
||||
LUMINOUS EFFICACITY: Lu/W
|
||||
LUMINOUS FLUX: Lu
|
||||
ILLUMINANCE: lx
|
||||
ELECTRIC CHARGE: C
|
||||
ELECTRIC FIELD: V/m
|
||||
ELECTRIC CAPACITANCE: F
|
||||
MAGNETIC FIELD: A/m
|
||||
MAGNETIC FLUX DENSITY: T
|
||||
MAGNETIC FLUX: Wb
|
||||
INDUCTANCE: H
|
||||
RELUCTANCE: 1./H
|
||||
ELECTRIC RESISTANCE: O
|
||||
ELECTRIC CONDUCTANCE: S
|
||||
RESISTIVITY: O*m
|
||||
CONDUCTIVITY: S/m
|
||||
MOLAR MASS: kg/mol
|
||||
MOLAR VOLUME: m³/mol
|
||||
CONCENTRATION: kg/m³
|
||||
MOLAR CONCENTRATION: mol/m³
|
||||
MOLARITY: mol/kg
|
||||
ACCOUSTIC INTENSITY: B
|
||||
DOSE EQUIVALENT: Si
|
||||
ABSORBED DOSE: Gr
|
||||
ACTIVITY (OF A RADIONUCLEIDE): Be
|
||||
FLUX OF MAGNETIC INDUCTION: kg*m²/s²/A
|
||||
ROTATION ACCELERATION: rad/s²
|
||||
TRANSLATION STIFFNESS: N/m
|
||||
ROTATION STIFFNESS: N*m/rad
|
@ -1,70 +0,0 @@
|
||||
MASS: kg
|
||||
LENGTH: mm
|
||||
TIME: s
|
||||
ELECTRIC CURRENT: A
|
||||
THERMODYNAMIC TEMPERATURE: °K
|
||||
AMOUNT OF SUBSTANCE: mol
|
||||
PLANE ANGLE: rad
|
||||
SOLID ANGLE: sr
|
||||
AREA: mm²
|
||||
VOLUME: mm³
|
||||
INERTIA: mm**4
|
||||
ANGULAR SPEED: rad/s
|
||||
SPEED: mm/s
|
||||
ACCELERATION: mm/s²
|
||||
FREQUENCY: Hz
|
||||
VOLUMIC MASS: kg/mm³
|
||||
MASS FLOW: kg/s
|
||||
VOLUME FLOW: mm³/s
|
||||
CONSUMPTION: mm²
|
||||
QUANTITY OF MOVEMENT: kg*mm/s
|
||||
KINETIC MOMENT: kg*mm²/s
|
||||
MOMENT OF INERTIA: kg*mm²
|
||||
FORCE: kg*mm/s²
|
||||
MOMENT OF A FORCE: kg*mm²/s²
|
||||
PRESSURE: kg/(mm*s²)
|
||||
DYNAMIC VISCOSITY: kg/(mm*s)
|
||||
KINETIC VISCOSITY: mm²/s
|
||||
TENSION SUPERFICIELLE: mm/s²
|
||||
ELECTRIC POTENTIAL: V
|
||||
ENERGY: kg*mm²/s²
|
||||
POWER: kg*mm²/s³
|
||||
LINEIC POWER: kg*mm/s³
|
||||
SURFACIC POWER: kg/s³
|
||||
VOLUMIC POWER: kg/(mm*s³)
|
||||
COEFFICIENT OF LINEAR INFLATION: 1./°K
|
||||
THERMICAL CONDUCTIVITY: kg*mm/(s³*°K)
|
||||
THERMICAL CONVECTIVITY: kg/(s³*°K)
|
||||
THERMICAL MASSIC CAPACITY: mm²/(s²*°K)
|
||||
ENTROPY: kg*mm²/(s²*°K)
|
||||
ENTHALPY: kg*mm²/s²
|
||||
LUMINOUS FLUX: Lu
|
||||
LUMINANCE: cd/mm²
|
||||
EXITANCE: lx
|
||||
LUMINOUS INTENSITY: cd
|
||||
LUMINOUS EXPOSITION: lx*s
|
||||
LUMINOUS EFFICACITY: s³*Lu/(kg*mm²)
|
||||
LUMINOUS FLUX: Lu
|
||||
ILLUMINANCE: lx
|
||||
ELECTRIC CHARGE: C
|
||||
ELECTRIC FIELD: V/mm
|
||||
ELECTRIC CAPACITANCE: s**4*A²/(kg*mm²)
|
||||
MAGNETIC FIELD: A/mm
|
||||
MAGNETIC FLUX DENSITY: T
|
||||
MAGNETIC FLUX: kg*mm²/(s²*A)
|
||||
INDUCTANCE: kg*mm²/(s²*A²)
|
||||
RELUCTANCE: s²*A²/(kg*mm²)
|
||||
ELECTRIC RESISTANCE: O
|
||||
ELECTRIC CONDUCTANCE: S
|
||||
RESISTIVITY: O*mm
|
||||
CONDUCTIVITY: S/mm
|
||||
MOLAR MASS: kg/mol
|
||||
MOLAR VOLUME: mm³/mol
|
||||
CONCENTRATION: kg/mm³
|
||||
MOLAR CONCENTRATION: mol/mm³
|
||||
MOLARITY: mol/kg
|
||||
ACCOUSTIC INTENSITY: mm/A²
|
||||
DOSE EQUIVALENT: mm²/s²
|
||||
ABSORBED DOSE: mm²/s²
|
||||
ACTIVITY (OF A RADIONUCLEIDE): Be
|
||||
FLUX OF MAGNETIC INDUCTION: kg*mm\062/(s\062*A)
|
@ -1,74 +0,0 @@
|
||||
MASS: kg
|
||||
LENGTH: mm
|
||||
TIME: s
|
||||
ELECTRIC CURRENT: A
|
||||
THERMODYNAMIC TEMPERATURE: °K
|
||||
AMOUNT OF SUBSTANCE: mol
|
||||
PLANE ANGLE: rad
|
||||
SOLID ANGLE: sr
|
||||
AREA: mm²
|
||||
VOLUME: mm³
|
||||
INERTIA: mm**4
|
||||
ANGULAR SPEED: rad/s
|
||||
SPEED: mm/s
|
||||
ACCELERATION: mm/s²
|
||||
FREQUENCY: Hz
|
||||
VOLUMIC MASS: kg/mm³
|
||||
MASS FLOW: kg/s
|
||||
VOLUME FLOW: mm³/s
|
||||
CONSUMPTION: mm²
|
||||
QUANTITY OF MOVEMENT: kg*mm/s
|
||||
KINETIC MOMENT: kg*mm²/s
|
||||
MOMENT OF INERTIA: kg*mm²
|
||||
FORCE: kg*mm/s²
|
||||
MOMENT OF A FORCE: kg*mm²/s²
|
||||
LINEIC FORCE: kg/s²
|
||||
PRESSURE: kg/(mm*s²)
|
||||
DYNAMIC VISCOSITY: kg/(mm*s)
|
||||
KINETIC VISCOSITY: mm²/s
|
||||
TENSION SUPERFICIELLE: mm/s²
|
||||
ELECTRIC POTENTIAL: V
|
||||
ENERGY: kg*mm²/s²
|
||||
POWER: kg*mm²/s³
|
||||
LINEIC POWER: kg*mm/s³
|
||||
SURFACIC POWER: kg/s³
|
||||
VOLUMIC POWER: kg/(mm*s³)
|
||||
COEFFICIENT OF LINEAR INFLATION: 1./°K
|
||||
THERMICAL CONDUCTIVITY: kg*mm/(s³*°K)
|
||||
THERMICAL CONVECTIVITY: kg/(s³*°K)
|
||||
THERMICAL MASSIC CAPACITY: mm²/(s²*°K)
|
||||
ENTROPY: kg*mm²/(s²*°K)
|
||||
ENTHALPY: kg*mm²/s²
|
||||
LUMINOUS FLUX: Lu
|
||||
LUMINANCE: cd/mm²
|
||||
EXITANCE: lx
|
||||
LUMINOUS INTENSITY: cd
|
||||
LUMINOUS EXPOSITION: lx*s
|
||||
LUMINOUS EFFICACITY: s³*Lu/(kg*mm²)
|
||||
LUMINOUS FLUX: Lu
|
||||
ILLUMINANCE: lx
|
||||
ELECTRIC CHARGE: C
|
||||
ELECTRIC FIELD: V/mm
|
||||
ELECTRIC CAPACITANCE: s**4*A²/(kg*mm²)
|
||||
MAGNETIC FIELD: A/mm
|
||||
MAGNETIC FLUX DENSITY: T
|
||||
MAGNETIC FLUX: kg*mm²/(s²*A)
|
||||
INDUCTANCE: kg*mm²/(s²*A²)
|
||||
RELUCTANCE: s²*A²/(kg*mm²)
|
||||
ELECTRIC RESISTANCE: O
|
||||
ELECTRIC CONDUCTANCE: S
|
||||
RESISTIVITY: O*mm
|
||||
CONDUCTIVITY: S/mm
|
||||
MOLAR MASS: kg/mol
|
||||
MOLAR VOLUME: mm³/mol
|
||||
CONCENTRATION: kg/mm³
|
||||
MOLAR CONCENTRATION: mol/mm³
|
||||
MOLARITY: mol/kg
|
||||
ACCOUSTIC INTENSITY: mm/A²
|
||||
DOSE EQUIVALENT: mm²/s²
|
||||
ABSORBED DOSE: mm²/s²
|
||||
ACTIVITY (OF A RADIONUCLEIDE): Be
|
||||
FLUX OF MAGNETIC INDUCTION: kg*mm²/(s²*A)
|
||||
ROTATION ACCELERATION: rad/s²
|
||||
TRANSLATION STIFFNESS: kg/s²
|
||||
ROTATION STIFFNESS: kg*mm²/(s²*rad)
|
@ -1,17 +0,0 @@
|
||||
-- Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
--
|
||||
-- The content of this file is subject to the Open CASCADE Technology Public
|
||||
-- License Version 6.5 (the "License"). You may not use the content of this file
|
||||
-- except in compliance with the License. Please obtain a copy of the License
|
||||
-- at http://www.opencascade.org and read it completely before using this file.
|
||||
--
|
||||
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
--
|
||||
-- The Original Code and all software distributed under the License is
|
||||
-- distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
-- Initial Developer hereby disclaims all such warranties, including without
|
||||
-- limitation, any warranties of merchantability, fitness for a particular
|
||||
-- purpose or non-infringement. Please see the License for the specific terms
|
||||
-- and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,17 +0,0 @@
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
@ -1,537 +0,0 @@
|
||||
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
||||
//
|
||||
// The content of this file is subject to the Open CASCADE Technology Public
|
||||
// License Version 6.5 (the "License"). You may not use the content of this file
|
||||
// except in compliance with the License. Please obtain a copy of the License
|
||||
// at http://www.opencascade.org and read it completely before using this file.
|
||||
//
|
||||
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
||||
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
||||
//
|
||||
// The Original Code and all software distributed under the License is
|
||||
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
||||
// Initial Developer hereby disclaims all such warranties, including without
|
||||
// limitation, any warranties of merchantability, fitness for a particular
|
||||
// purpose or non-infringement. Please see the License for the specific terms
|
||||
// and conditions governing the rights and limitations under the License.
|
||||
|
||||
#ifndef _gp_Quaternion_HeaderFile
|
||||
#define _gp_Quaternion_HeaderFile
|
||||
|
||||
/**
|
||||
* Initial sources based on free samples from
|
||||
* http://www.gamedev.ru/code/articles/?id=4215&page=3
|
||||
*/
|
||||
|
||||
#include <gp_Vec.hxx>
|
||||
#include <gp_Mat.hxx>
|
||||
#include <Precision.hxx>
|
||||
|
||||
//! General quaternion class (unit and nonunit),
|
||||
//! designed for 3d rotations and orientation representation <br>
|
||||
class gp_Quaternion
|
||||
{
|
||||
|
||||
public:
|
||||
|
||||
//! Creates an identity quaternion. <br>
|
||||
gp_Quaternion()
|
||||
: x (0.0), y (0.0), z (0.0), w (1.0) {}
|
||||
|
||||
gp_Quaternion (Standard_Real x, Standard_Real y, Standard_Real z, Standard_Real w)
|
||||
: x (x), y (y), z (z), w (w) {}
|
||||
|
||||
gp_Quaternion (const gp_Quaternion& theToCopy)
|
||||
: x (theToCopy.x), y (theToCopy.y), z (theToCopy.z), w (theToCopy.w) {}
|
||||
|
||||
gp_Quaternion (const gp_Vec& theVecFrom, const gp_Vec& theVecTo)
|
||||
: x (0.0), y (0.0), z (0.0), w (1.0)
|
||||
{
|
||||
Init (theVecFrom, theVecTo);
|
||||
}
|
||||
|
||||
gp_Quaternion (const gp_Vec& theVecFrom, const gp_Vec& theVecTo, const gp_Vec& theHelpCrossVec)
|
||||
: x (0.0), y (0.0), z (0.0), w (1.0)
|
||||
{
|
||||
Init (theVecFrom, theVecTo, theHelpCrossVec);
|
||||
}
|
||||
|
||||
//! Simple equal test without precision
|
||||
Standard_Boolean IsEqual (const gp_Quaternion& theOther) const
|
||||
{
|
||||
if (this == &theOther)
|
||||
{
|
||||
return Standard_True;
|
||||
}
|
||||
return Abs (x - theOther.x) <= gp::Resolution() &&
|
||||
Abs (y - theOther.y) <= gp::Resolution() &&
|
||||
Abs (z - theOther.z) <= gp::Resolution() &&
|
||||
Abs (w - theOther.w) <= gp::Resolution();
|
||||
}
|
||||
|
||||
/**
|
||||
* Shortest arc quaternion rotate one vector to another by shortest path.
|
||||
* Create rotation from -> to, for any length vectors.
|
||||
* If vectors theVecFrom and theVecTo are opposite then rotation axis computed as
|
||||
* theVecFrom * gp_Vec(1,0,0) or theVecFrom * gp_Vec(0,0,1).
|
||||
*/
|
||||
void Init (const gp_Vec& theVecFrom, const gp_Vec& theVecTo)
|
||||
{
|
||||
gp_Vec aVecCross (theVecFrom.Crossed (theVecTo));
|
||||
Set (aVecCross.X(), aVecCross.Y(), aVecCross.Z(), theVecFrom.Dot (theVecTo));
|
||||
Normalize(); // if "from" or "to" not unit, normalize quat
|
||||
w += 1.0; // reducing angle to halfangle
|
||||
if (w <= Precision::Confusion()) // angle close to PI
|
||||
{
|
||||
if ((theVecFrom.Z() * theVecFrom.Z()) > (theVecFrom.X() * theVecFrom.X()))
|
||||
Set ( 0.0, theVecFrom.Z(), -theVecFrom.Y(), w); // theVecFrom * gp_Vec(1,0,0)
|
||||
else
|
||||
Set (theVecFrom.Y(), -theVecFrom.X(), 0.0, w); // theVecFrom * gp_Vec(0,0,1)
|
||||
}
|
||||
Normalize();
|
||||
}
|
||||
|
||||
/**
|
||||
* Shortest arc quaternion rotate one vector to another by shortest path.
|
||||
* If vectors theVecFrom and theVecTo are opposite then rotation axis computed as
|
||||
* theVecFrom * theHelpCrossVec.
|
||||
*/
|
||||
void Init (const gp_Vec& theVecFrom, const gp_Vec& theVecTo, const gp_Vec& theHelpCrossVec)
|
||||
{
|
||||
gp_Vec aVecCross (theVecFrom.Crossed (theVecTo));
|
||||
Set (aVecCross.X(), aVecCross.Y(), aVecCross.Z(), theVecFrom.Dot (theVecTo));
|
||||
Normalize(); // if "from" or "to" not unit, normalize quat
|
||||
w += 1.0; // reducing angle to halfangle
|
||||
if (w <= Precision::Confusion()) // angle close to PI
|
||||
{
|
||||
gp_Vec theAxis = theVecFrom.Crossed (theHelpCrossVec);
|
||||
Set (theAxis.X(), theAxis.Y(), theAxis.Z(), w);
|
||||
}
|
||||
Normalize();
|
||||
}
|
||||
|
||||
gp_Quaternion (const gp_Vec& theAxis, const Standard_Real& theAngle)
|
||||
: x (0.0), y (0.0), z (0.0), w (1.0)
|
||||
{
|
||||
InitUnit (theAxis, theAngle);
|
||||
}
|
||||
|
||||
//! Create a unit quaternion from Axis+Angle representation
|
||||
void InitUnit (const gp_Vec& theAxis, const Standard_Real& theAngle)
|
||||
{
|
||||
gp_Vec anAxis = theAxis.Normalized();
|
||||
Standard_Real anAngleHalf = 0.5 * theAngle;
|
||||
Standard_Real sin_a = Sin (anAngleHalf);
|
||||
Set (anAxis.X() * sin_a, anAxis.Y() * sin_a, anAxis.Z() * sin_a, Cos (anAngleHalf));
|
||||
}
|
||||
|
||||
/**
|
||||
* Convert a quaternion to Axis+Angle representation,
|
||||
* preserve the axis direction and angle from -PI to +PI
|
||||
*/
|
||||
void GetAxisAngle (gp_Vec& theAxis, Standard_Real& theAngle) const
|
||||
{
|
||||
Standard_Real vl = Sqrt (x * x + y * y + z * z);
|
||||
if (vl > Precision::Confusion())
|
||||
{
|
||||
Standard_Real ivl = 1.0 / vl;
|
||||
theAxis.SetCoord (x * ivl, y * ivl, z * ivl);
|
||||
if (w < 0.0)
|
||||
{
|
||||
theAngle = 2.0 * ATan2 (-vl, -w); // [-PI, 0]
|
||||
}
|
||||
else
|
||||
{
|
||||
theAngle = 2.0 * ATan2 ( vl, w); // [ 0, PI]
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
theAxis.SetCoord (0.0, 0.0, 0.0);
|
||||
theAngle = 0.0;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a unit quaternion by rotation matrix
|
||||
* matrix must contain only rotation (not scale or shear)
|
||||
*
|
||||
* For numerical stability we find first the greatest component of quaternion
|
||||
* and than search others from this one
|
||||
*/
|
||||
void InitUnit (const gp_Mat& theMat)
|
||||
{
|
||||
Standard_Real tr = theMat (1, 1) + theMat (2, 2) + theMat(3, 3); // trace of martix
|
||||
if (tr > 0.0)
|
||||
{ // if trace positive than "w" is biggest component
|
||||
Set (theMat (3, 2) - theMat (2, 3),
|
||||
theMat (1, 3) - theMat (3, 1),
|
||||
theMat (2, 1) - theMat (1, 2),
|
||||
tr + 1.0);
|
||||
Scale (0.5 / Sqrt (w)); // "w" contain the "norm * 4"
|
||||
}
|
||||
else if ((theMat (1, 1) > theMat (2, 2)) && (theMat (1, 1) > theMat (3, 3)))
|
||||
{ // Some of vector components is bigger
|
||||
Set (1.0 + theMat (1, 1) - theMat (2, 2) - theMat (3, 3),
|
||||
theMat (1, 2) + theMat (2, 1),
|
||||
theMat (1, 3) + theMat (3, 1),
|
||||
theMat (3, 2) - theMat (2, 3));
|
||||
Scale (0.5 / Sqrt (x));
|
||||
}
|
||||
else if (theMat (2, 2) > theMat (3, 3))
|
||||
{
|
||||
Set (theMat (1, 2) + theMat (2, 1),
|
||||
1.0 + theMat (2, 2) - theMat (1, 1) - theMat (3, 3),
|
||||
theMat (2, 3) + theMat (3, 2),
|
||||
theMat (1, 3) - theMat (3, 1));
|
||||
Scale (0.5 / Sqrt (y));
|
||||
}
|
||||
else
|
||||
{
|
||||
Set (theMat (1, 3) + theMat (3, 1),
|
||||
theMat (2, 3) + theMat (3, 2),
|
||||
1.0 + theMat (3, 3) - theMat (1, 1) - theMat (2, 2),
|
||||
theMat (2, 1) - theMat (1, 2));
|
||||
Scale (0.5 / Sqrt (z));
|
||||
}
|
||||
}
|
||||
|
||||
gp_Quaternion (const gp_Mat& theMat)
|
||||
: x (0.0), y (0.0), z (0.0), w (1.0)
|
||||
{
|
||||
Init (theMat);
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a nonunit quaternion from rotation matrix
|
||||
* martix must contain only rotation (not scale or shear)
|
||||
* the result quaternion length is numerical stable
|
||||
*/
|
||||
void Init (const gp_Mat& theMat)
|
||||
{
|
||||
Standard_Real tr = theMat (1, 1) + theMat (2, 2) + theMat (3, 3); // trace of martix
|
||||
if (tr > 0.0)
|
||||
{ // if trace positive than "w" is biggest component
|
||||
Set (theMat (3, 2) - theMat (2, 3),
|
||||
theMat (1, 3) - theMat (3, 1),
|
||||
theMat (2, 1) - theMat (1, 2),
|
||||
tr + 1.0);
|
||||
}
|
||||
else if ((theMat (1, 1) > theMat (2, 2)) && (theMat (1, 1) > theMat (3, 3)))
|
||||
{ // Some of vector components is bigger
|
||||
Set (1.0 + theMat (1, 1) - theMat (2, 2) - theMat (3, 3),
|
||||
theMat (1, 2) + theMat (2, 1),
|
||||
theMat (1, 3) + theMat (3, 1),
|
||||
theMat (3, 2) - theMat (2, 3));
|
||||
}
|
||||
else if (theMat (2, 2) > theMat (3, 3))
|
||||
{
|
||||
Set (theMat (1, 2) + theMat (2, 1),
|
||||
1.0 + theMat (2, 2) - theMat (1, 1) - theMat (3, 3),
|
||||
theMat (2, 3) + theMat (3, 2),
|
||||
theMat (1, 3) - theMat (3, 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
Set (theMat (1, 3) + theMat (3, 1),
|
||||
theMat (2, 3) + theMat (3, 2),
|
||||
1.0 + theMat (3, 3) - theMat (1, 1) - theMat (2, 2),
|
||||
theMat (2, 1) - theMat (1, 2));
|
||||
}
|
||||
}
|
||||
|
||||
//! Set the rotation to matrix
|
||||
void GetRotateMatrix (gp_Mat& theMat) const
|
||||
{
|
||||
Standard_Real wx, wy, wz, xx, yy, yz, xy, xz, zz, x2, y2, z2;
|
||||
Standard_Real s = 2.0 / Norm();
|
||||
x2 = x * s; y2 = y * s; z2 = z * s;
|
||||
xx = x * x2; xy = x * y2; xz = x * z2;
|
||||
yy = y * y2; yz = y * z2; zz = z * z2;
|
||||
wx = w * x2; wy = w * y2; wz = w * z2;
|
||||
|
||||
theMat (1, 1) = 1.0 - (yy + zz);
|
||||
theMat (1, 2) = xy - wz;
|
||||
theMat (1, 3) = xz + wy;
|
||||
|
||||
theMat (2, 1) = xy + wz;
|
||||
theMat (2, 2) = 1.0 - (xx + zz);
|
||||
theMat (2, 3) = yz - wx;
|
||||
|
||||
theMat (3, 1) = xz - wy;
|
||||
theMat (3, 2) = yz + wx;
|
||||
theMat (3, 3) = 1.0 - (xx + yy);
|
||||
// 1 division 16 multiplications 15 addidtions 12 variables
|
||||
}
|
||||
|
||||
//! Set the rotation from unit quat to matrix
|
||||
void GetRotateMatrixFromUnit (gp_Mat& theMat) const
|
||||
{
|
||||
Standard_Real wx, wy, wz, xx, yy, yz, xy, xz, zz, x2, y2, z2;
|
||||
x2 = x + x; y2 = y + y; z2 = z + z;
|
||||
xx = x * x2; xy = x * y2; xz = x * z2;
|
||||
yy = y * y2; yz = y * z2; zz = z * z2;
|
||||
wx = w * x2; wy = w * y2; wz = w * z2;
|
||||
|
||||
theMat (1, 1) = 1.0 - (yy + zz);
|
||||
theMat (1, 2) = xy - wz;
|
||||
theMat (1, 3) = xz + wy;
|
||||
|
||||
theMat (2, 1) = xy + wz;
|
||||
theMat (2, 2) = 1.0 - (xx + zz);
|
||||
theMat (2, 3) = yz - wx;
|
||||
|
||||
theMat (3, 1) = xz - wy;
|
||||
theMat (3, 2) = yz + wx;
|
||||
theMat (3, 3) = 1.0 - (xx + yy);
|
||||
}
|
||||
|
||||
void Set (Standard_Real x, Standard_Real y, Standard_Real z, Standard_Real w)
|
||||
{
|
||||
this->x = x; this->y = y; this->z = z; this->w = w;
|
||||
}
|
||||
|
||||
void Set (const gp_Quaternion& theQuaternion)
|
||||
{
|
||||
x = theQuaternion.x; y = theQuaternion.y; z = theQuaternion.z; w = theQuaternion.w;
|
||||
}
|
||||
|
||||
Standard_Real X() const
|
||||
{
|
||||
return x;
|
||||
}
|
||||
|
||||
Standard_Real Y() const
|
||||
{
|
||||
return y;
|
||||
}
|
||||
|
||||
Standard_Real Z() const
|
||||
{
|
||||
return z;
|
||||
}
|
||||
|
||||
Standard_Real W() const
|
||||
{
|
||||
return w;
|
||||
}
|
||||
|
||||
//! Make identity quaternion (zero-rotation)
|
||||
void Ident()
|
||||
{
|
||||
x = 0.0; y = 0.0; z = 0.0; w = 1.0;
|
||||
}
|
||||
|
||||
//! Reverse rotation
|
||||
void Conjugate()
|
||||
{
|
||||
x = -x; y = -y; z = -z;
|
||||
}
|
||||
|
||||
//! Return reversed rotation
|
||||
gp_Quaternion Conjugated() const
|
||||
{
|
||||
return gp_Quaternion (-x, -y, -z, w);
|
||||
}
|
||||
|
||||
//! Rotation will not be changed by this operation (except 0-scaling)
|
||||
void Scale (Standard_Real theScale)
|
||||
{
|
||||
x *= theScale; y *= theScale; z *= theScale; w *= theScale;
|
||||
}
|
||||
|
||||
gp_Quaternion Scaled (const Standard_Real theScale) const
|
||||
{
|
||||
return gp_Quaternion (x * theScale, y * theScale, z * theScale, w * theScale);
|
||||
}
|
||||
|
||||
Standard_Real Norm() const
|
||||
{
|
||||
return x * x + y * y + z * z + w * w;
|
||||
}
|
||||
|
||||
Standard_Real Magnitude() const
|
||||
{
|
||||
return Sqrt (Norm());
|
||||
}
|
||||
|
||||
//! Invert quaternion q = q^-1
|
||||
void Invert()
|
||||
{
|
||||
Standard_Real in = 1.0 / Norm();
|
||||
Set (-x * in, -y * in, -z * in, w * in);
|
||||
}
|
||||
|
||||
//! Return inversed quaternion q^-1
|
||||
gp_Quaternion Inverted() const
|
||||
{
|
||||
Standard_Real in = 1.0 / Norm();
|
||||
return gp_Quaternion (-x * in, -y * in, -z * in, w * in);
|
||||
}
|
||||
|
||||
/**
|
||||
* Stabilize quaternion length within 1 - 1/4
|
||||
* This operation is a lot faster than normalization
|
||||
* and preserve length goes to 0 or infinity
|
||||
*/
|
||||
void StabilizeLength()
|
||||
{
|
||||
Standard_Real cs = Abs (x) + Abs (y) + Abs (z) + Abs (w);
|
||||
if (cs > 0.0)
|
||||
{
|
||||
x /= cs; y /= cs; z /= cs; w /= cs;
|
||||
}
|
||||
else
|
||||
{
|
||||
Ident();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Scale quaternion that its norm goes to 1
|
||||
* The appearing of 0 magnitude or near is a error,
|
||||
* so we can be sure that can divide by magnitude
|
||||
*/
|
||||
void Normalize()
|
||||
{
|
||||
Standard_Real aMagn = Magnitude();
|
||||
if (aMagn < Precision::Confusion())
|
||||
{
|
||||
StabilizeLength();
|
||||
aMagn = Magnitude();
|
||||
}
|
||||
Scale (1.0 / aMagn);
|
||||
}
|
||||
|
||||
gp_Quaternion Normalized() const
|
||||
{
|
||||
gp_Quaternion aNormilizedQ (*this);
|
||||
aNormilizedQ.Normalize();
|
||||
return aNormilizedQ;
|
||||
}
|
||||
|
||||
gp_Quaternion operator-() const
|
||||
{
|
||||
return gp_Quaternion (-x, -y, -z, -w);
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
gp_Quaternion Added (const gp_Quaternion& theQ) const
|
||||
{
|
||||
return gp_Quaternion (x + theQ.x, y + theQ.y, z + theQ.z, w + theQ.w);
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
gp_Quaternion operator+ (const gp_Quaternion& theQ) const
|
||||
{
|
||||
return Added(theQ);
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
gp_Quaternion Subtracted (const gp_Quaternion& theQ) const
|
||||
{
|
||||
return gp_Quaternion (x - theQ.x, y - theQ.y, z - theQ.z, w - theQ.w);
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
gp_Quaternion operator- (const gp_Quaternion& theQ) const
|
||||
{
|
||||
return Subtracted (theQ);
|
||||
}
|
||||
|
||||
//! Rotation will not be changed by this operation (except 0-scaling)
|
||||
gp_Quaternion operator* (const Standard_Real& theScale) const
|
||||
{
|
||||
return gp_Quaternion (x * theScale, y * theScale, z * theScale, w * theScale);
|
||||
}
|
||||
|
||||
/**
|
||||
* Multiply function - work the same as Matrices multiplying.
|
||||
* qq' = (cross(v,v') + wv' + w'v, ww' - dot(v,v'))
|
||||
* Result is rotation combination: q' than q (here q=this, q'=theQ).
|
||||
* Notices than:
|
||||
* qq' != q'q;
|
||||
* qq^-1 = q;
|
||||
*/
|
||||
gp_Quaternion operator* (const gp_Quaternion& theQ) const
|
||||
{
|
||||
return gp_Quaternion (w * theQ.x + x * theQ.w + y * theQ.z - z * theQ.y,
|
||||
w * theQ.y + y * theQ.w + z * theQ.x - x * theQ.z,
|
||||
w * theQ.z + z * theQ.w + x * theQ.y - y * theQ.x,
|
||||
w * theQ.w - x * theQ.x - y * theQ.y - z * theQ.z);
|
||||
// 16 multiplications 12 addidtions 0 variables
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
const gp_Quaternion& Add (const gp_Quaternion& theQ)
|
||||
{
|
||||
x += theQ.x; y += theQ.y; z += theQ.z; w += theQ.w;
|
||||
return *this;
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
const gp_Quaternion& operator+= (const gp_Quaternion& theQ)
|
||||
{
|
||||
return Add (theQ);
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
const gp_Quaternion& Subtract (const gp_Quaternion& theQ)
|
||||
{
|
||||
x -= theQ.x; y -= theQ.y; z -= theQ.z; w -= theQ.w;
|
||||
return *this;
|
||||
}
|
||||
|
||||
//! Result is "rotations mix"
|
||||
const gp_Quaternion& operator-= (const gp_Quaternion& theQ)
|
||||
{
|
||||
return Subtract(theQ);
|
||||
}
|
||||
|
||||
const gp_Quaternion& operator*= (const gp_Quaternion& theQ)
|
||||
{
|
||||
Set ((*this) * theQ); // have no optimization here
|
||||
return *this;
|
||||
}
|
||||
|
||||
//! Inner product / scalar product / Dot
|
||||
Standard_Real Dot (const gp_Quaternion& theQ)
|
||||
{
|
||||
return x * theQ.x + y * theQ.y + z * theQ.z + w * theQ.w;
|
||||
}
|
||||
|
||||
//! Return rotation angle from -PI to PI
|
||||
Standard_Real GetRotationAngle() const
|
||||
{
|
||||
if (w < 0.0)
|
||||
{
|
||||
return 2.0 * ATan2 (-Sqrt (x * x + y * y + z * z), -w);
|
||||
}
|
||||
else
|
||||
{
|
||||
return 2.0 * ATan2 ( Sqrt (x * x + y * y + z * z), w);
|
||||
}
|
||||
}
|
||||
|
||||
//! Return vector rotated by quaternion
|
||||
gp_Vec Rotated (const gp_Vec& theVec) const
|
||||
{
|
||||
gp_Quaternion theQ (theVec.X() * w + theVec.Z() * y - theVec.Y() * z,
|
||||
theVec.Y() * w + theVec.X() * z - theVec.Z() * x,
|
||||
theVec.Z() * w + theVec.Y() * x - theVec.X() * y,
|
||||
theVec.X() * x + theVec.Y() * y + theVec.Z() * z);
|
||||
return gp_Vec (w * theQ.x + x * theQ.w + y * theQ.z - z * theQ.y,
|
||||
w * theQ.y + y * theQ.w + z * theQ.x - x * theQ.z,
|
||||
w * theQ.z + z * theQ.w + x * theQ.y - y * theQ.x) * (1.0 / Norm());
|
||||
}
|
||||
|
||||
private:
|
||||
|
||||
Standard_Real x;
|
||||
Standard_Real y;
|
||||
Standard_Real z;
|
||||
Standard_Real w;
|
||||
|
||||
};
|
||||
|
||||
#endif //_gp_Quaternion_HeaderFile
|
Loading…
x
Reference in New Issue
Block a user