1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30from functools import cmp_to_key
31
32import manufacturingtoolkit.CadExMTK as mtk
33
34class Pair:
35 def __init__(self, theFirst: float, theSecond: float):
36 self.First = theFirst
37 self.Second = theSecond
38
39 def __repr__(self):
40 return f"Pair({self.First}, {self.Second})"
41
42 def __str__(self):
43 return f"{self.First:.5f} x {self.Second:.5f}"
44
45class Dimension:
46 def __init__(self, theX: float, theY: float, theZ: float):
47 self.X = theX
48 self.Y = theY
49 self.Z = theZ
50
51 def __repr__(self):
52 return f"Dimension({self.X}, {self.Y}, {self.Z})"
53
54 def __str__(self):
55 return f"{self.X:.5f} x {self.Y:.5f} x {self.Z:.5f}"
56
57class Direction:
58 def __init__(self, theX: float, theY: float, theZ: float):
59 self.X = theX
60 self.Y = theY
61 self.Z = theZ
62
63 def __repr__(self):
64 return f"Direction({self.X}, {self.Y}, {self.Z})"
65
66 def __str__(self):
67 return f"({self.X:.2f}, {self.Y:.2f}, {self.Z:.2f})"
68
69def CompareFeatures(theA: mtk.MTKBase_Feature, theB: mtk.MTKBase_Feature):
70 aComparator = mtk.MTKBase_FeatureComparator()
71 anALessThanB = aComparator(theA, theB)
72 if anALessThanB:
73 return -1
74
75 aBLessThanA = aComparator(theB, theA)
76 if aBLessThanA:
77 return 1
78
79 return 0
80
81class FeatureGroupManager:
82 def __init__(self):
83 self.__myGroups = []
84
85 def AddFeature(self, theGroupName: str, theSubgroupName: str, theHasParameters: bool, theFeature: mtk.MTKBase_Feature):
86
87 aRes = -1
88 for i in range(len(self.__myGroups)):
89 aGroup = self.__myGroups[i]
90 if aGroup.myName == theGroupName:
91 aRes = i
92 break
93
94 if aRes == -1:
95 self.__myGroups.append(self.FeatureGroup(theGroupName, theSubgroupName, theHasParameters))
96 aRes = len(self.__myGroups) - 1
97
98
99 aGroup = self.__myGroups[aRes]
100 aSubgroups = aGroup.myFeatureSubgroups
101 aSubgroups.Append(theFeature)
102
103 def Print(self, theFeatureType: str, thePrintFeatureParameters):
104 self.__myGroups.sort(key=cmp_to_key(self.__compare))
105
106 aTotalCount = 0
107 for i in self.__myGroups:
108 aFeatureCount = i.FeatureCount()
109 aTotalCount += aFeatureCount
110
111 print(" ", i.myName, ": ", aFeatureCount, sep="")
112
113 if not i.myHasParameters:
114 continue
115
116 aSubgroupName = i.mySubgroupName
117 for j in range(i.myFeatureSubgroups.Size()):
118 print(" ", i.myFeatureSubgroups.GetFeatureCount(j), " ", aSubgroupName, " with", sep="")
119 thePrintFeatureParameters(i.myFeatureSubgroups.GetFeature(j))
120
121 print("\n Total ", theFeatureType, ": ", aTotalCount, "\n", sep="")
122
123 @staticmethod
124 def PrintFeatureParameter(theName: str, theValue, theUnits: str):
125 print(" ", theName, ": ", theValue, " ", theUnits, sep = "")
126
127 class OrderedFeatureList:
128 def __init__(self):
129 self.__myList = []
130
131 def Append(self, theFeature: mtk.MTKBase_Feature):
132 anInsertIndex = 0
133 for i in self.__myList:
134 aRes = CompareFeatures(theFeature, i.Feature)
135 if aRes == 0:
136 i.Count += 1
137 anInsertIndex = -1
138 break
139 elif aRes < 0:
140 break
141
142 anInsertIndex += 1
143
144 if anInsertIndex >= 0:
145 self.__myList.insert(anInsertIndex, self.FeatureAndCountPair(theFeature))
146
147 def Size(self):
148 return len(self.__myList)
149
150 def GetFeature(self, theIndex: int):
151 return self.__GetFeatureAndCountPair(theIndex).Feature
152
153 def GetFeatureCount(self, theIndex: int):
154 return self.__GetFeatureAndCountPair(theIndex).Count
155
156 def __GetFeatureAndCountPair(self, theIndex: int):
157 return self.__myList[theIndex]
158
159 class FeatureAndCountPair:
160 def __init__(self, theFeature: mtk.MTKBase_Feature):
161 self.Feature = theFeature
162 self.Count = 1
163
164 class FeatureGroup:
165 def __init__(self, theName: str, theSubgroupName: str, theHasParameters: bool):
166 self.myName = theName
167 self.mySubgroupName = theSubgroupName
168 self.myHasParameters = theHasParameters
169 self.myFeatureSubgroups = FeatureGroupManager.OrderedFeatureList()
170
171 def FeatureCount(self):
172 aCount = 0
173 for i in range(self.myFeatureSubgroups.Size()):
174 aCount += self.myFeatureSubgroups.GetFeatureCount(i)
175 return aCount
176
177 @staticmethod
178 def __compare(theA: FeatureGroup, theB: FeatureGroup):
179 anAName = theA.myName
180 aBName = theB.myName
181 if anAName == aBName:
182 return 0
183
184 anAFeatureSubgroups = theA.myFeatureSubgroups
185 aBFeatureSubgroups = theB.myFeatureSubgroups
186 if (not anAFeatureSubgroups) or (not aBFeatureSubgroups):
187 if anAName < aBName:
188 return -1
189 else:
190 return 1
191
192 anAFeature = anAFeatureSubgroups.GetFeature(0)
193 aBFeature = aBFeatureSubgroups.GetFeature(0)
194 return CompareFeatures(anAFeature, aBFeature)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30import os
31import sys
32
33from pathlib import Path
34
35import manufacturingtoolkit.CadExMTK as mtk
36
37sys.path.append(os.path.abspath(os.path.dirname(Path(__file__).resolve()) + "/../../"))
38sys.path.append(os.path.abspath(os.path.dirname(Path(__file__).resolve()) + "/../../helpers/"))
39
40import mtk_license as license
41
42import feature_group
43import shape_processor
44
45def SmallDistanceIssueName(theIssue: mtk.DFMSheetMetal_SmallDistanceBetweenFeaturesIssue):
46 if mtk.DFMSheetMetal_SmallDistanceBetweenBendAndLouverIssue.CompareType(theIssue):
47 return "Small Distance Between Bend And Louver Issue(s)"
48 elif mtk.DFMSheetMetal_SmallDistanceBetweenExtrudedHoleAndBendIssue.CompareType(theIssue):
49 return "Small Distance Between Extruded Hole And Bend Issue(s)"
50 elif mtk.DFMSheetMetal_SmallDistanceBetweenExtrudedHoleAndEdgeIssue.CompareType(theIssue):
51 return "Small Distance Between Extruded Hole And Edge Issue(s)"
52 elif mtk.DFMSheetMetal_SmallDistanceBetweenExtrudedHolesIssue.CompareType(theIssue):
53 return "Small Distance Between Extruded Holes Issue(s)"
54 elif mtk.DFMSheetMetal_SmallDistanceBetweenHoleAndBendIssue.CompareType(theIssue):
55 return "Small Distance Between Hole And Bend Issue(s)"
56 elif mtk.DFMSheetMetal_SmallDistanceBetweenHoleAndCutoutIssue.CompareType(theIssue):
57 return "Small Distance Between Hole And Cutout Issue(s)"
58 elif mtk.DFMSheetMetal_SmallDistanceBetweenHoleAndEdgeIssue.CompareType(theIssue):
59 return "Small Distance Between Hole And Edge Issue(s)"
60 elif mtk.DFMSheetMetal_SmallDistanceBetweenHoleAndLouverIssue.CompareType(theIssue):
61 return "Small Distance Between Hole And Louver Issue(s)"
62 elif mtk.DFMSheetMetal_SmallDistanceBetweenHoleAndNotchIssue.CompareType(theIssue):
63 return "Small Distance Between Hole And Notch Issue(s)"
64 elif mtk.DFMSheetMetal_SmallDistanceBetweenHolesIssue.CompareType(theIssue):
65 return "Small Distance Between Holes Issue(s)"
66 elif mtk.DFMSheetMetal_SmallDistanceBetweenNotchAndBendIssue.CompareType(theIssue):
67 return "Small Distance Between Notch And Bend Issue(s)"
68 elif mtk.DFMSheetMetal_SmallDistanceBetweenNotchesIssue.CompareType(theIssue):
69 return "Small Distance Between Notches Issue(s)"
70 elif mtk.DFMSheetMetal_SmallDistanceBetweenTabsIssue.CompareType(theIssue):
71 return "Small Distance Between Tabs Issue(s)"
72 return "Small Distance Between Feature(s)"
73
74def PrintFeatureParameters(theIssue: mtk.MTKBase_Feature):
75 if mtk.DFMSheetMetal_SmallRadiusBendIssue.CompareType(theIssue):
76 aSRBIssue = mtk.DFMSheetMetal_SmallRadiusBendIssue.Cast(theIssue)
77 feature_group.FeatureGroupManager.PrintFeatureParameter("expected min radius", aSRBIssue.ExpectedMinRadius(), "mm")
78 feature_group.FeatureGroupManager.PrintFeatureParameter("actual radius", aSRBIssue.ActualRadius(), "mm")
79 elif mtk.DFMSheetMetal_SmallDiameterHoleIssue.CompareType(theIssue):
80 aSDHIssue = mtk.DFMSheetMetal_SmallDiameterHoleIssue.Cast(theIssue)
81 feature_group.FeatureGroupManager.PrintFeatureParameter("expected min diameter", aSDHIssue.ExpectedMinDiameter(), "mm")
82 feature_group.FeatureGroupManager.PrintFeatureParameter("actual diameter", aSDHIssue.ActualDiameter(), "mm")
83 elif mtk.DFMSheetMetal_SmallDistanceBetweenFeaturesIssue.CompareType(theIssue):
84 aSDBFIssue = mtk.DFMSheetMetal_SmallDistanceBetweenFeaturesIssue.Cast(theIssue)
85 feature_group.FeatureGroupManager.PrintFeatureParameter(
86 "expected min distance", aSDBFIssue.ExpectedMinDistanceBetweenFeatures(), "mm")
87 feature_group.FeatureGroupManager.PrintFeatureParameter(
88 "actual distance", aSDBFIssue.ActualDistanceBetweenFeatures(), "mm")
89 elif mtk.DFMSheetMetal_FlatPatternInterferenceIssue.CompareType(theIssue):
90 pass
91 elif mtk.DFMSheetMetal_IrregularCornerFilletRadiusNotchIssue.CompareType(theIssue):
92 aICFRNIssue = mtk.DFMSheetMetal_IrregularCornerFilletRadiusNotchIssue.Cast(theIssue)
93 feature_group.FeatureGroupManager.PrintFeatureParameter("expected corner fillet radius", aICFRNIssue.ExpectedCornerFilletRadius(), "mm")
94 feature_group.FeatureGroupManager.PrintFeatureParameter("actual corner fillet radius", aICFRNIssue.ActualCornerFilletRadius(), "mm")
95 elif mtk.DFMSheetMetal_IrregularDepthExtrudedHoleIssue.CompareType(theIssue):
96 aIDEHIssue = mtk.DFMSheetMetal_IrregularDepthExtrudedHoleIssue.Cast(theIssue)
97 feature_group.FeatureGroupManager.PrintFeatureParameter("expected min extruded height", aIDEHIssue.ExpectedMinExtrudedHeight(), "mm")
98 feature_group.FeatureGroupManager.PrintFeatureParameter("expected max extruded height", aIDEHIssue.ExpectedMaxExtrudedHeight(), "mm")
99 feature_group.FeatureGroupManager.PrintFeatureParameter("actual extruded height", aIDEHIssue.ActualExtrudedHeight(), "mm")
100 elif mtk.DFMSheetMetal_IrregularRadiusOpenHemBendIssue.CompareType(theIssue):
101 aIROHBIssue = mtk.DFMSheetMetal_IrregularRadiusOpenHemBendIssue.Cast(theIssue)
102 feature_group.FeatureGroupManager.PrintFeatureParameter("expected radius", aIROHBIssue.ExpectedRadius(), "mm")
103 feature_group.FeatureGroupManager.PrintFeatureParameter("actual radius", aIROHBIssue.ActualRadius(), "mm")
104 elif mtk.DFMSheetMetal_IrregularSizeBendReliefIssue.CompareType(theIssue):
105 aISBRIssue = mtk.DFMSheetMetal_IrregularSizeBendReliefIssue.Cast(theIssue)
106 anExpectedRelief = aISBRIssue.ExpectedMinBendRelief()
107 aFirstActualRelief = aISBRIssue.FirstActualRelief()
108 aSecondActualRelief = aISBRIssue.SecondActualRelief()
109
110 feature_group.FeatureGroupManager.PrintFeatureParameter (
111 "expected min relief size (LxW)",
112 feature_group.Pair (anExpectedRelief.Length(), anExpectedRelief.Width()),
113 "mm")
114 if (not aFirstActualRelief.IsNull()) and (not aSecondActualRelief.IsNull()):
115 feature_group.FeatureGroupManager.PrintFeatureParameter (
116 "first actual relief size (LxW)",
117 feature_group.Pair(aFirstActualRelief.Length(), aFirstActualRelief.Width()),
118 "mm")
119 feature_group.FeatureGroupManager.PrintFeatureParameter (
120 "second actual relief size (LxW)",
121 feature_group.Pair(aSecondActualRelief.Length(), aSecondActualRelief.Width()),
122 "mm")
123 elif aFirstActualRelief.IsNull():
124 feature_group.FeatureGroupManager.PrintFeatureParameter (
125 "actual relief size (LxW)",
126 feature_group.Pair(aSecondActualRelief.Length(), aSecondActualRelief.Width()),
127 "mm")
128 else:
129 feature_group.FeatureGroupManager.PrintFeatureParameter (
130 "actual relief size (LxW)",
131 feature_group.Pair(aFirstActualRelief.Length(), aFirstActualRelief.Width()),
132 "mm")
133 elif mtk.DFMSheetMetal_LargeDepthBeadIssue.CompareType(theIssue):
134 aLDBIssue = mtk.DFMSheetMetal_LargeDepthBeadIssue.Cast(theIssue)
135 feature_group.FeatureGroupManager.PrintFeatureParameter("expected max depth", aLDBIssue.ExpectedMaxDepth(), "mm")
136 feature_group.FeatureGroupManager.PrintFeatureParameter("actual depth", aLDBIssue.ActualDepth(), "mm")
137 elif mtk.DFMSheetMetal_SmallDepthLouverIssue.CompareType(theIssue):
138 aSDLIssue = mtk.DFMSheetMetal_SmallDepthLouverIssue.Cast(theIssue)
139 feature_group.FeatureGroupManager.PrintFeatureParameter("expected min depth", aSDLIssue.ExpectedMinDepth(), "mm")
140 feature_group.FeatureGroupManager.PrintFeatureParameter("actual depth", aSDLIssue.ActualDepth(), "mm")
141 elif mtk.DFMSheetMetal_InconsistentRadiusBendIssue.CompareType(theIssue):
142 aIRBIssue = mtk.DFMSheetMetal_InconsistentRadiusBendIssue.Cast(theIssue)
143 feature_group.FeatureGroupManager.PrintFeatureParameter("expected max radius", aIRBIssue.ExpectedRadius(), "mm")
144 feature_group.FeatureGroupManager.PrintFeatureParameter("actual radius", aIRBIssue.ActualRadius(), "mm")
145 elif mtk.DFMSheetMetal_SmallLengthFlangeIssue.CompareType(theIssue):
146 aSLFIssue = mtk.DFMSheetMetal_SmallLengthFlangeIssue.Cast(theIssue)
147 feature_group.FeatureGroupManager.PrintFeatureParameter("expected min length", aSLFIssue.ExpectedMinLength(), "mm")
148 feature_group.FeatureGroupManager.PrintFeatureParameter("actual length", aSLFIssue.ActualLength(), "mm")
149 elif mtk.DFMSheetMetal_SmallLengthHemBendFlangeIssue.CompareType(theIssue):
150 aSLHBFIssue = mtk.DFMSheetMetal_SmallLengthHemBendFlangeIssue.Cast(theIssue)
151 feature_group.FeatureGroupManager.PrintFeatureParameter("expected min length", aSLHBFIssue.ExpectedMinLength(), "mm")
152 feature_group.FeatureGroupManager.PrintFeatureParameter("actual length", aSLHBFIssue.ActualLength(), "mm")
153 elif mtk.DFMSheetMetal_IrregularSizeNotchIssue.CompareType(theIssue):
154 aISNIssue = mtk.DFMSheetMetal_IrregularSizeNotchIssue.Cast(theIssue)
155 feature_group.FeatureGroupManager.PrintFeatureParameter(
156 "expected size (LxW)",
157 feature_group.Pair(aISNIssue.ExpectedLength(), aISNIssue.ExpectedWidth()),
158 "mm")
159 feature_group.FeatureGroupManager.PrintFeatureParameter(
160 "actual size (LxW)",
161 feature_group.Pair(aISNIssue.ActualLength(), aISNIssue.ActualWidth()),
162 "mm")
163 elif mtk.DFMSheetMetal_IrregularSizeTabIssue.CompareType(theIssue):
164 aISTIssue = mtk.DFMSheetMetal_IrregularSizeTabIssue.Cast(theIssue)
165 feature_group.FeatureGroupManager.PrintFeatureParameter(
166 "expected size (LxW)",
167 feature_group.Pair(aISTIssue.ExpectedLength(), aISTIssue.ExpectedWidth()),
168 "mm")
169 feature_group.FeatureGroupManager.PrintFeatureParameter(
170 "actual size (LxW)",
171 feature_group.Pair(aISTIssue.ActualLength(), aISTIssue.ActualWidth()),
172 "mm")
173 elif mtk.DFMSheetMetal_NonStandardSheetThicknessIssue.CompareType(theIssue):
174 aNSSTIssue = mtk.DFMSheetMetal_NonStandardSheetThicknessIssue.Cast(theIssue)
175 feature_group.FeatureGroupManager.PrintFeatureParameter(
176 "nearest standard sheet thickness", aNSSTIssue.NearestStandardSheetThickness(), "mm")
177 feature_group.FeatureGroupManager.PrintFeatureParameter(
178 "actual sheet thickness", aNSSTIssue.ActualSheetThickness(), "mm")
179 elif mtk.DFMSheetMetal_NonStandardSheetSizeIssue.CompareType(theIssue):
180 aNSSSIssue = mtk.DFMSheetMetal_NonStandardSheetSizeIssue.Cast(theIssue)
181 aNearestStandardSize = aNSSSIssue.NearestStandardSheetSize()
182 anActualSize = aNSSSIssue.ActualSheetSize()
183 feature_group.FeatureGroupManager.PrintFeatureParameter(
184 "nearest standard sheet size (LxW)",
185 feature_group.Pair(aNearestStandardSize.Length(), aNearestStandardSize.Width()),
186 "mm")
187 feature_group.FeatureGroupManager.PrintFeatureParameter(
188 "actual sheet size (LxW)",
189 feature_group.Pair(anActualSize.Length(), anActualSize.Width()),
190 "mm")
191
192def PrintIssues(theIssueList: mtk.MTKBase_FeatureList):
193 aManager = feature_group.FeatureGroupManager()
194
195
196 for anIssue in theIssueList:
197 if mtk.DFMSheetMetal_SmallRadiusBendIssue.CompareType(anIssue):
198 aManager.AddFeature("Small Radius Bend Issue(s)", "Bend(s)", True, anIssue)
199 elif mtk.DFMSheetMetal_SmallDiameterHoleIssue.CompareType(anIssue):
200 aManager.AddFeature("Small Diameter Hole Issue(s)", "Hole(s)", True, anIssue)
201 elif mtk.DFMSheetMetal_FlatPatternInterferenceIssue.CompareType(anIssue):
202 aManager.AddFeature("Flat Pattern Interference Issue(s)", "", False, anIssue)
203 elif mtk.DFMSheetMetal_IrregularCornerFilletRadiusNotchIssue.CompareType(anIssue):
204 aManager.AddFeature("Irregular Corner Fillet Radius Notch Issue(s)", "Notch(es)", True, anIssue)
205 elif mtk.DFMSheetMetal_IrregularDepthExtrudedHoleIssue.CompareType(anIssue):
206 aManager.AddFeature("Irregular Depth Extruded Hole Issue(s)", "Hole(s)", True, anIssue)
207 elif mtk.DFMSheetMetal_IrregularRadiusOpenHemBendIssue.CompareType(anIssue):
208 aManager.AddFeature("Irregular Radius Open Hem Bend Issue(s)", "Bend(s)", True, anIssue)
209 elif mtk.DFMSheetMetal_IrregularSizeBendReliefIssue.CompareType(anIssue):
210 aManager.AddFeature("Irregular Size Bend Relief Issue(s)", "Bend(s)", True, anIssue)
211 elif mtk.DFMSheetMetal_LargeDepthBeadIssue.CompareType(anIssue):
212 aManager.AddFeature("Large Depth Bead Issue(s)", "Bead(s)", True, anIssue)
213 elif mtk.DFMSheetMetal_SmallDepthLouverIssue.CompareType(anIssue):
214 aManager.AddFeature("Small Depth Louver Issue(s)", "Louver(s)", True, anIssue)
215 elif mtk.DFMSheetMetal_InconsistentRadiusBendIssue.CompareType(anIssue):
216 aManager.AddFeature("Inconsistent Radius Bend Issue(s)", "Bend(s)", True, anIssue)
217 elif mtk.DFMSheetMetal_SmallLengthFlangeIssue.CompareType(anIssue):
218 aManager.AddFeature("Small Length Flange Issue(s)", "Flange(s)", True, anIssue)
219 elif mtk.DFMSheetMetal_SmallLengthHemBendFlangeIssue.CompareType(anIssue):
220 aManager.AddFeature("Small Length Hem Bend Flange Issue(s)", "Flange(s)", True, anIssue)
221 elif mtk.DFMSheetMetal_IrregularSizeNotchIssue.CompareType(anIssue):
222 aManager.AddFeature("Irregular Size Notch Issue(s)", "Notch(s)", True, anIssue)
223 elif mtk.DFMSheetMetal_IrregularSizeTabIssue.CompareType(anIssue):
224 aManager.AddFeature("Irregular Size Tab Issue(s)", "Tab(s)", True, anIssue)
225 elif mtk.DFMSheetMetal_SmallDistanceBetweenFeaturesIssue.CompareType(anIssue):
226 aSDBFIssue = mtk.DFMSheetMetal_SmallDistanceBetweenFeaturesIssue.Cast(anIssue)
227 aManager.AddFeature(SmallDistanceIssueName (aSDBFIssue), "Distance(s)", True, anIssue)
228 elif mtk.DFMSheetMetal_NonStandardSheetThicknessIssue.CompareType(anIssue):
229 aManager.AddFeature("Non Standard Sheet Thickness Issue(s)", "Sheet Thickness(s)", True, anIssue)
230 elif mtk.DFMSheetMetal_NonStandardSheetSizeIssue.CompareType(anIssue):
231 aManager.AddFeature("Non Standard Sheet Size Issue(s)", "Sheet Size(s)", True, anIssue)
232
233 aManager.Print ("issues", PrintFeatureParameters)
234
235class PartProcessor(shape_processor.ShapeProcessor):
236 def __init__(self):
237 super().__init__()
238 self.myAnalyzer = mtk.DFMSheetMetal_Analyzer()
239
240 def ProcessSolid(self, theSolid: mtk.ModelData_Solid):
241 anIssueList = self.myAnalyzer.Perform(theSolid)
242 PrintIssues(anIssueList)
243
244 def ProcessShell(self, theShell: mtk.ModelData_Shell):
245 anIssueList = self.myAnalyzer.Perform(theShell)
246 PrintIssues(anIssueList)
247
248def main(theSource: str):
249 aKey = license.Value()
250
251 if not mtk.LicenseManager.Activate(aKey):
252 print("Failed to activate Manufacturing Toolkit license.")
253 return 1
254
255 aModel = mtk.ModelData_Model()
256 aReader = mtk.ModelData_ModelReader()
257
258
259 if not aReader.Read(mtk.UTF16String(theSource), aModel):
260 print("Failed to open and convert the file " + theSource)
261 return 1
262
263 print("Model: ", aModel.Name(), "\n", sep="")
264
265
266 aPartProcessor = PartProcessor()
267 aVisitor = mtk.ModelData_ModelElementUniqueVisitor(aPartProcessor)
268 aModel.Accept(aVisitor)
269
270 return 0
271
272if __name__ == "__main__":
273 if len(sys.argv) != 2:
274 print( "Usage: <input_file>, where:")
275 print( " <input_file> is a name of the file to be read")
276 sys.exit()
277
278 aSource = os.path.abspath(sys.argv[1])
279
280 sys.exit(main(aSource))