0023948: Wrong intersection between a surface of revolution and a plane.
[occt.git] / src / StepBasic / StepBasic_MeasureValueMember.cxx
1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
2 //
3 // This file is part of Open CASCADE Technology software library.
4 //
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
10 //
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
13
14 #include <StepBasic_MeasureValueMember.ixx>
15
16 //=======================================================================
17 //function : StepBasic_MeasureValueMember
18 //purpose  : 
19 //=======================================================================
20
21 StepBasic_MeasureValueMember::StepBasic_MeasureValueMember()
22 {
23   thecase = 0;
24 }
25
26
27 //=======================================================================
28 //function : HasName
29 //purpose  : 
30 //=======================================================================
31
32 Standard_Boolean StepBasic_MeasureValueMember::HasName () const
33 {
34   return (thecase > 0);
35 }
36
37
38 //=======================================================================
39 //function : Name
40 //purpose  : 
41 //=======================================================================
42
43 Standard_CString StepBasic_MeasureValueMember::Name () const
44 {
45   switch (thecase) {
46     case  0 : return "";
47     case  1 : return "LENGTH_MEASURE";
48     case  2 : return "TIME_MEASURE";
49     case  3 : return "PLANE_ANGLE_MEASURE";
50     case  4 : return "SOLID_ANGLE_MEASURE";
51     case  5 : return "RATIO_MEASURE";
52     case  6 : return "PARAMETER_VALUE";
53     case  7 : return "CONTEXT_DEPENDANT_MEASURE";
54     case  8 : return "POSITIVE_LENGTH_MEASURE";
55     case  9 : return "POSITIVE_PLANE_ANGLE_MEASURE";
56     case 10 : return "POSITIVE_RATIO_MEASURE";
57     case 11 : return "AREA_MEASURE"; 
58     case 12 : return "VOLUME_MEASURE"; 
59     case 13 : return "MASS_MEASURE"; 
60     case 14 : return "THERMODYNAMIC_TEMPERATURE_MEASURE"; 
61     default : break;
62   }
63   return "";
64 }
65
66
67 //=======================================================================
68 //function : SetName
69 //purpose  : 
70 //=======================================================================
71
72 Standard_Boolean  StepBasic_MeasureValueMember::SetName (const Standard_CString name)
73 {
74   if (!name || name[0] == '\0') thecase = 0;
75 //  prefiltrage par une lettre caracteristique (ne pas se tromper)
76   else if (name[0] == 'L' && !strcmp (name,"LENGTH_MEASURE"))      thecase = 1;
77   else if (name[1] == 'I' && !strcmp (name,"TIME_MEASURE"))        thecase = 2;
78   else if (name[1] == 'L' && !strcmp (name,"PLANE_ANGLE_MEASURE")) thecase = 3;
79   else if (name[0] == 'S' && !strcmp (name,"SOLID_ANGLE_MEASURE")) thecase = 4;
80   else if (name[2] == 'T' && !strcmp (name,"RATIO_MEASURE"))       thecase = 5;
81   else if (name[2] == 'R' && !strcmp (name,"PARAMETER_VALUE"))     thecase = 6;
82   else if (name[0] == 'C' && !strcmp (name,"CONTEXT_DEPENDANT_MEASURE"))    thecase = 7;
83   else if (name[9] == 'L' && !strcmp (name,"POSITIVE_LENGTH_MEASURE"))      thecase = 8;
84   else if (name[9] == 'P' && !strcmp (name,"POSITIVE_PLANE_ANGLE_MEASURE")) thecase = 9;
85   else if (name[9] == 'R' && !strcmp (name,"POSITIVE_RATIO_MEASURE"))       thecase = 10;
86   else if (name[0] == 'A' && !strcmp (name,"AREA_MEASURE"))        thecase = 11;
87   else if (name[0] == 'V' && !strcmp (name,"VOLUME_MEASURE"))      thecase = 12;
88   else if (name[0] == 'M' && !strcmp (name,"MASS_MEASURE"))        thecase = 13;
89   else if (name[1] == 'H' && !strcmp (name,"THERMODYNAMIC_TEMPERATURE_MEASURE")) thecase = 14;
90   else return Standard_False;
91
92   return Standard_True;
93 }