1
0
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:
dbv 2012-03-29 19:32:30 +04:00
parent 9d35f66806
commit 5fdb6d685b
34 changed files with 22 additions and 1959 deletions

View File

@ -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/.
}

View File

@ -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;

View 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}
}

View File

@ -47,3 +47,4 @@ XSDRAW : TKXSDRAW
XDEDRAW : TKXDEDRAW
TOBJ : TKTObjDRAW
DFBROWSER : TKDFBrowser
QAcommands : TKQADraw

View File

@ -37,3 +37,6 @@ srcinc:::wing.brep
srcinc:::VisualizationDemo.tcl
srcinc:::OCAFDemo.tcl
srcinc:::TKTopTest.tcl
srcinc:::dftree.tcl
srcinc:::QARebuildCommands
srcinc:::DrawAppliInit

View 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;

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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.

View File

@ -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

View File

@ -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.

View File

@ -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.

View File

@ -1 +0,0 @@
QAcommands : TKQADraw

View File

@ -1 +0,0 @@
QAcommands : TKQADraw

View File

@ -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}

View File

@ -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.

View File

@ -4,6 +4,5 @@ icon:::MDTV-Standard.xwd
loginfile:::Plugin
appresource:::XCAF
appresource:::TObj
srcinc:::dftree.tcl
appresource:::StandardLite
appresource:::MigrationSheet.txt

View File

@ -1 +0,0 @@

View File

@ -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

View File

@ -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)

View File

@ -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)

View File

@ -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.

View File

@ -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.

View File

@ -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