sketchup-api-stubs 0.7.4 → 0.7.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (150) hide show
  1. checksums.yaml +4 -4
  2. data/lib/sketchup-api-stubs.rb +1 -1
  3. data/lib/sketchup-api-stubs/sketchup.rb +147 -145
  4. data/lib/sketchup-api-stubs/stubs/Geom/BoundingBox.rb +322 -318
  5. data/lib/sketchup-api-stubs/stubs/Geom/Bounds2d.rb +172 -172
  6. data/lib/sketchup-api-stubs/stubs/Geom/LatLong.rb +126 -126
  7. data/lib/sketchup-api-stubs/stubs/Geom/OrientedBounds2d.rb +102 -102
  8. data/lib/sketchup-api-stubs/stubs/Geom/Point2d.rb +400 -400
  9. data/lib/sketchup-api-stubs/stubs/Geom/Point3d.rb +661 -661
  10. data/lib/sketchup-api-stubs/stubs/Geom/PolygonMesh.rb +498 -492
  11. data/lib/sketchup-api-stubs/stubs/Geom/Transformation.rb +478 -478
  12. data/lib/sketchup-api-stubs/stubs/Geom/Transformation2d.rb +263 -263
  13. data/lib/sketchup-api-stubs/stubs/Geom/UTM.rb +141 -141
  14. data/lib/sketchup-api-stubs/stubs/Geom/Vector2d.rb +522 -522
  15. data/lib/sketchup-api-stubs/stubs/Geom/Vector3d.rb +691 -691
  16. data/lib/sketchup-api-stubs/stubs/Layout.rb +25 -25
  17. data/lib/sketchup-api-stubs/stubs/Layout/AngularDimension.rb +573 -573
  18. data/lib/sketchup-api-stubs/stubs/Layout/AutoTextDefinition.rb +411 -411
  19. data/lib/sketchup-api-stubs/stubs/Layout/AutoTextDefinitions.rb +179 -174
  20. data/lib/sketchup-api-stubs/stubs/Layout/ConnectionPoint.rb +70 -70
  21. data/lib/sketchup-api-stubs/stubs/Layout/Document.rb +515 -514
  22. data/lib/sketchup-api-stubs/stubs/Layout/Ellipse.rb +29 -29
  23. data/lib/sketchup-api-stubs/stubs/Layout/Entities.rb +148 -143
  24. data/lib/sketchup-api-stubs/stubs/Layout/Entity.rb +353 -353
  25. data/lib/sketchup-api-stubs/stubs/Layout/FormattedText.rb +349 -349
  26. data/lib/sketchup-api-stubs/stubs/Layout/Grid.rb +311 -311
  27. data/lib/sketchup-api-stubs/stubs/Layout/Group.rb +261 -261
  28. data/lib/sketchup-api-stubs/stubs/Layout/Image.rb +91 -91
  29. data/lib/sketchup-api-stubs/stubs/Layout/Label.rb +370 -371
  30. data/lib/sketchup-api-stubs/stubs/Layout/Layer.rb +218 -218
  31. data/lib/sketchup-api-stubs/stubs/Layout/LayerInstance.rb +128 -128
  32. data/lib/sketchup-api-stubs/stubs/Layout/Layers.rb +225 -220
  33. data/lib/sketchup-api-stubs/stubs/Layout/LinearDimension.rb +567 -567
  34. data/lib/sketchup-api-stubs/stubs/Layout/LockedEntityError.rb +10 -10
  35. data/lib/sketchup-api-stubs/stubs/Layout/LockedLayerError.rb +11 -11
  36. data/lib/sketchup-api-stubs/stubs/Layout/Page.rb +183 -183
  37. data/lib/sketchup-api-stubs/stubs/Layout/PageInfo.rb +387 -387
  38. data/lib/sketchup-api-stubs/stubs/Layout/Pages.rb +209 -204
  39. data/lib/sketchup-api-stubs/stubs/Layout/Path.rb +344 -344
  40. data/lib/sketchup-api-stubs/stubs/Layout/Rectangle.rb +174 -174
  41. data/lib/sketchup-api-stubs/stubs/Layout/SketchUpModel.rb +694 -694
  42. data/lib/sketchup-api-stubs/stubs/Layout/Style.rb +1519 -1519
  43. data/lib/sketchup-api-stubs/stubs/Layout/Table.rb +290 -290
  44. data/lib/sketchup-api-stubs/stubs/Layout/TableCell.rb +149 -149
  45. data/lib/sketchup-api-stubs/stubs/Layout/TableColumn.rb +139 -139
  46. data/lib/sketchup-api-stubs/stubs/Layout/TableRow.rb +135 -135
  47. data/lib/sketchup-api-stubs/stubs/Sketchup/Animation.rb +144 -140
  48. data/lib/sketchup-api-stubs/stubs/Sketchup/AppObserver.rb +157 -157
  49. data/lib/sketchup-api-stubs/stubs/Sketchup/ArcCurve.rb +209 -209
  50. data/lib/sketchup-api-stubs/stubs/Sketchup/AttributeDictionaries.rb +152 -152
  51. data/lib/sketchup-api-stubs/stubs/Sketchup/AttributeDictionary.rb +286 -281
  52. data/lib/sketchup-api-stubs/stubs/Sketchup/Axes.rb +149 -149
  53. data/lib/sketchup-api-stubs/stubs/Sketchup/Behavior.rb +302 -328
  54. data/lib/sketchup-api-stubs/stubs/Sketchup/Camera.rb +478 -577
  55. data/lib/sketchup-api-stubs/stubs/Sketchup/ClassificationSchema.rb +63 -63
  56. data/lib/sketchup-api-stubs/stubs/Sketchup/Classifications.rb +122 -122
  57. data/lib/sketchup-api-stubs/stubs/Sketchup/Color.rb +294 -281
  58. data/lib/sketchup-api-stubs/stubs/Sketchup/ComponentDefinition.rb +577 -562
  59. data/lib/sketchup-api-stubs/stubs/Sketchup/ComponentInstance.rb +604 -593
  60. data/lib/sketchup-api-stubs/stubs/Sketchup/Console.rb +76 -76
  61. data/lib/sketchup-api-stubs/stubs/Sketchup/ConstructionLine.rb +257 -257
  62. data/lib/sketchup-api-stubs/stubs/Sketchup/ConstructionPoint.rb +32 -32
  63. data/lib/sketchup-api-stubs/stubs/Sketchup/Curve.rb +201 -194
  64. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionList.rb +362 -329
  65. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionObserver.rb +74 -72
  66. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionsObserver.rb +104 -102
  67. data/lib/sketchup-api-stubs/stubs/Sketchup/Dimension.rb +165 -165
  68. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionLinear.rb +306 -312
  69. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionObserver.rb +42 -38
  70. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionRadial.rb +87 -87
  71. data/lib/sketchup-api-stubs/stubs/Sketchup/Drawingelement.rb +396 -390
  72. data/lib/sketchup-api-stubs/stubs/Sketchup/Edge.rb +502 -508
  73. data/lib/sketchup-api-stubs/stubs/Sketchup/EdgeUse.rb +211 -211
  74. data/lib/sketchup-api-stubs/stubs/Sketchup/Entities.rb +1126 -1119
  75. data/lib/sketchup-api-stubs/stubs/Sketchup/EntitiesObserver.rb +127 -125
  76. data/lib/sketchup-api-stubs/stubs/Sketchup/Entity.rb +545 -544
  77. data/lib/sketchup-api-stubs/stubs/Sketchup/EntityObserver.rb +60 -59
  78. data/lib/sketchup-api-stubs/stubs/Sketchup/ExtensionsManager.rb +126 -125
  79. data/lib/sketchup-api-stubs/stubs/Sketchup/Face.rb +751 -750
  80. data/lib/sketchup-api-stubs/stubs/Sketchup/FrameChangeObserver.rb +104 -104
  81. data/lib/sketchup-api-stubs/stubs/Sketchup/Group.rb +699 -697
  82. data/lib/sketchup-api-stubs/stubs/Sketchup/Http.rb +27 -27
  83. data/lib/sketchup-api-stubs/stubs/Sketchup/Http/Request.rb +285 -285
  84. data/lib/sketchup-api-stubs/stubs/Sketchup/Http/Response.rb +62 -62
  85. data/lib/sketchup-api-stubs/stubs/Sketchup/Image.rb +417 -409
  86. data/lib/sketchup-api-stubs/stubs/Sketchup/ImageRep.rb +266 -226
  87. data/lib/sketchup-api-stubs/stubs/Sketchup/Importer.rb +189 -190
  88. data/lib/sketchup-api-stubs/stubs/Sketchup/InputPoint.rb +405 -393
  89. data/lib/sketchup-api-stubs/stubs/Sketchup/InstanceObserver.rb +84 -82
  90. data/lib/sketchup-api-stubs/stubs/Sketchup/InstancePath.rb +306 -303
  91. data/lib/sketchup-api-stubs/stubs/Sketchup/Layer.rb +327 -285
  92. data/lib/sketchup-api-stubs/stubs/Sketchup/LayerFolder.rb +422 -0
  93. data/lib/sketchup-api-stubs/stubs/Sketchup/Layers.rb +427 -244
  94. data/lib/sketchup-api-stubs/stubs/Sketchup/LayersObserver.rb +249 -136
  95. data/lib/sketchup-api-stubs/stubs/Sketchup/Licensing.rb +48 -48
  96. data/lib/sketchup-api-stubs/stubs/Sketchup/Licensing/ExtensionLicense.rb +86 -86
  97. data/lib/sketchup-api-stubs/stubs/Sketchup/LineStyle.rb +24 -24
  98. data/lib/sketchup-api-stubs/stubs/Sketchup/LineStyles.rb +112 -112
  99. data/lib/sketchup-api-stubs/stubs/Sketchup/Loop.rb +137 -137
  100. data/lib/sketchup-api-stubs/stubs/Sketchup/Material.rb +414 -416
  101. data/lib/sketchup-api-stubs/stubs/Sketchup/Materials.rb +318 -311
  102. data/lib/sketchup-api-stubs/stubs/Sketchup/MaterialsObserver.rb +142 -141
  103. data/lib/sketchup-api-stubs/stubs/Sketchup/Menu.rb +93 -95
  104. data/lib/sketchup-api-stubs/stubs/Sketchup/Model.rb +1651 -1638
  105. data/lib/sketchup-api-stubs/stubs/Sketchup/ModelObserver.rb +357 -356
  106. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsManager.rb +131 -132
  107. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsProvider.rb +284 -284
  108. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsProviderObserver.rb +58 -58
  109. data/lib/sketchup-api-stubs/stubs/Sketchup/Page.rb +797 -770
  110. data/lib/sketchup-api-stubs/stubs/Sketchup/Pages.rb +363 -353
  111. data/lib/sketchup-api-stubs/stubs/Sketchup/PagesObserver.rb +77 -76
  112. data/lib/sketchup-api-stubs/stubs/Sketchup/PickHelper.rb +478 -456
  113. data/lib/sketchup-api-stubs/stubs/Sketchup/RegionalSettings.rb +43 -43
  114. data/lib/sketchup-api-stubs/stubs/Sketchup/RenderingOptions.rb +364 -364
  115. data/lib/sketchup-api-stubs/stubs/Sketchup/RenderingOptionsObserver.rb +45 -44
  116. data/lib/sketchup-api-stubs/stubs/Sketchup/SectionPlane.rb +150 -150
  117. data/lib/sketchup-api-stubs/stubs/Sketchup/Selection.rb +459 -454
  118. data/lib/sketchup-api-stubs/stubs/Sketchup/SelectionObserver.rb +115 -115
  119. data/lib/sketchup-api-stubs/stubs/Sketchup/Set.rb +212 -212
  120. data/lib/sketchup-api-stubs/stubs/Sketchup/ShadowInfo.rb +257 -257
  121. data/lib/sketchup-api-stubs/stubs/Sketchup/ShadowInfoObserver.rb +59 -57
  122. data/lib/sketchup-api-stubs/stubs/Sketchup/Skp.rb +40 -0
  123. data/lib/sketchup-api-stubs/stubs/Sketchup/Style.rb +69 -69
  124. data/lib/sketchup-api-stubs/stubs/Sketchup/Styles.rb +217 -211
  125. data/lib/sketchup-api-stubs/stubs/Sketchup/Text.rb +262 -262
  126. data/lib/sketchup-api-stubs/stubs/Sketchup/Texture.rb +217 -225
  127. data/lib/sketchup-api-stubs/stubs/Sketchup/TextureWriter.rb +237 -237
  128. data/lib/sketchup-api-stubs/stubs/Sketchup/Tool.rb +835 -829
  129. data/lib/sketchup-api-stubs/stubs/Sketchup/Tools.rb +132 -132
  130. data/lib/sketchup-api-stubs/stubs/Sketchup/ToolsObserver.rb +156 -154
  131. data/lib/sketchup-api-stubs/stubs/Sketchup/UVHelper.rb +71 -61
  132. data/lib/sketchup-api-stubs/stubs/Sketchup/Vertex.rb +142 -142
  133. data/lib/sketchup-api-stubs/stubs/Sketchup/View.rb +1307 -1301
  134. data/lib/sketchup-api-stubs/stubs/Sketchup/ViewObserver.rb +45 -43
  135. data/lib/sketchup-api-stubs/stubs/UI/Command.rb +317 -310
  136. data/lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb +387 -356
  137. data/lib/sketchup-api-stubs/stubs/UI/Notification.rb +255 -229
  138. data/lib/sketchup-api-stubs/stubs/UI/Toolbar.rb +240 -240
  139. data/lib/sketchup-api-stubs/stubs/UI/WebDialog.rb +633 -633
  140. data/lib/sketchup-api-stubs/stubs/_top_level.rb +311 -311
  141. data/lib/sketchup-api-stubs/stubs/array.rb +741 -741
  142. data/lib/sketchup-api-stubs/stubs/geom.rb +351 -348
  143. data/lib/sketchup-api-stubs/stubs/languagehandler.rb +92 -92
  144. data/lib/sketchup-api-stubs/stubs/length.rb +278 -278
  145. data/lib/sketchup-api-stubs/stubs/numeric.rb +249 -249
  146. data/lib/sketchup-api-stubs/stubs/sketchup.rb +1342 -1310
  147. data/lib/sketchup-api-stubs/stubs/sketchupextension.rb +353 -353
  148. data/lib/sketchup-api-stubs/stubs/string.rb +24 -24
  149. data/lib/sketchup-api-stubs/stubs/ui.rb +668 -667
  150. metadata +4 -2
@@ -1,82 +1,84 @@
1
- # Copyright:: Copyright 2020 Trimble Inc.
2
- # License:: The MIT License (MIT)
3
-
4
- # This observer interface is implemented to react to component instance
5
- # events. To implement this observer, create a Ruby class of this type,
6
- # override the desired methods, and add an instance of the observer to the
7
- # objects of interests.
8
- #
9
- # Note that you may also attach {Sketchup::InstanceObserver}s to
10
- # {Sketchup::Group}s.
11
- #
12
- # @example
13
- # # This is an example of an observer that watches a specific instance
14
- # # for open edit actions and shows a messagebox.
15
- # class MyInstanceObserver < Sketchup::InstanceObserver
16
- # def onOpen(instance)
17
- # puts "onOpen: #{instance}"
18
- # end
19
- #
20
- # def onClose(instance)
21
- # puts "onClose: #{instance}"
22
- # end
23
- # end
24
- #
25
- # # Attach the observer. (This example assumes that your first definition
26
- # # in the model contains an instance to attach the observer to. This
27
- # # example should work with a model where Sang or Bryce are present in
28
- # # the template.)
29
- # model = Sketchup.active_model
30
- # model.definitions[0].instances[0].add_observer(MyInstanceObserver.new)
31
- #
32
- # @version SketchUp 6.0
33
- class Sketchup::InstanceObserver < Sketchup::EntityObserver
34
-
35
- # Instance Methods
36
-
37
- # The {#onClose} method is called when an instance is "closed," meaning an end
38
- # user was editing a component's geometry and then exited back into the
39
- # parent's editing space.
40
- #
41
- # @example
42
- # def onClose(instance)
43
- # puts "onClose: #{instance}"
44
- # end
45
- #
46
- # @param [Sketchup::ComponentInstance] instance
47
- # The instance that was just
48
- # closed
49
- #
50
- # @return [nil]
51
- #
52
- # @version SketchUp 6.0
53
- def onClose(instance)
54
- end
55
-
56
- # The {#onOpen} method is called when an instance is "opened," meaning an end
57
- # user has double clicked on it to edit its geometry. This is particularly
58
- # useful if your plugin is dynamically drawing geometry or performing
59
- # transformations in global space, since when in "edit component" mode all
60
- # transformations and positions are returned in relation to the current
61
- # component's origin.
62
- #
63
- # This method will tell you when a user has entered edit mode, and you can
64
- # then use {Sketchup::Model#active_path} and {Sketchup::Model#edit_transform}
65
- # methods to determine any corrections you need to make to your
66
- # transformations.
67
- #
68
- # @example
69
- # def onOpen(instance)
70
- # puts "onOpen: #{instance}"
71
- # end
72
- #
73
- # @param [Sketchup::ComponentInstance] instance
74
- # The instance that was opened
75
- #
76
- # @return [nil]
77
- #
78
- # @version SketchUp 6.0
79
- def onOpen(instance)
80
- end
81
-
82
- end
1
+ # Copyright:: Copyright 2020 Trimble Inc.
2
+ # License:: The MIT License (MIT)
3
+
4
+ # This observer interface is implemented to react to component instance
5
+ # events.
6
+ #
7
+ # Note that you may also attach {Sketchup::InstanceObserver}s to
8
+ # {Sketchup::Group}s.
9
+ #
10
+ # @abstract To implement this observer, create a Ruby class of this type,
11
+ # override the desired methods, and add an instance of the observer to the
12
+ # objects of interests.
13
+ #
14
+ # @example
15
+ # # This is an example of an observer that watches a specific instance
16
+ # # for open edit actions and shows a messagebox.
17
+ # class MyInstanceObserver < Sketchup::InstanceObserver
18
+ # def onOpen(instance)
19
+ # puts "onOpen: #{instance}"
20
+ # end
21
+ #
22
+ # def onClose(instance)
23
+ # puts "onClose: #{instance}"
24
+ # end
25
+ # end
26
+ #
27
+ # # Attach the observer. (This example assumes that your first definition
28
+ # # in the model contains an instance to attach the observer to. This
29
+ # # example should work with a model where Sang or Bryce are present in
30
+ # # the template.)
31
+ # model = Sketchup.active_model
32
+ # model.definitions[0].instances[0].add_observer(MyInstanceObserver.new)
33
+ #
34
+ # @version SketchUp 6.0
35
+ class Sketchup::InstanceObserver < Sketchup::EntityObserver
36
+
37
+ # Instance Methods
38
+
39
+ # The {#onClose} method is called when an instance is "closed," meaning an end
40
+ # user was editing a component's geometry and then exited back into the
41
+ # parent's editing space.
42
+ #
43
+ # @example
44
+ # def onClose(instance)
45
+ # puts "onClose: #{instance}"
46
+ # end
47
+ #
48
+ # @param [Sketchup::ComponentInstance] instance
49
+ # The instance that was just
50
+ # closed
51
+ #
52
+ # @return [nil]
53
+ #
54
+ # @version SketchUp 6.0
55
+ def onClose(instance)
56
+ end
57
+
58
+ # The {#onOpen} method is called when an instance is "opened," meaning an end
59
+ # user has double clicked on it to edit its geometry. This is particularly
60
+ # useful if your plugin is dynamically drawing geometry or performing
61
+ # transformations in global space, since when in "edit component" mode all
62
+ # transformations and positions are returned in relation to the current
63
+ # component's origin.
64
+ #
65
+ # This method will tell you when a user has entered edit mode, and you can
66
+ # then use {Sketchup::Model#active_path} and {Sketchup::Model#edit_transform}
67
+ # methods to determine any corrections you need to make to your
68
+ # transformations.
69
+ #
70
+ # @example
71
+ # def onOpen(instance)
72
+ # puts "onOpen: #{instance}"
73
+ # end
74
+ #
75
+ # @param [Sketchup::ComponentInstance] instance
76
+ # The instance that was opened
77
+ #
78
+ # @return [nil]
79
+ #
80
+ # @version SketchUp 6.0
81
+ def onOpen(instance)
82
+ end
83
+
84
+ end
@@ -1,303 +1,306 @@
1
- # Copyright:: Copyright 2020 Trimble Inc.
2
- # License:: The MIT License (MIT)
3
-
4
- # The {Sketchup::InstancePath} class represent the instance path to a given
5
- # entity within the model hierarchy.
6
- #
7
- # @version SketchUp 2017
8
- class Sketchup::InstancePath
9
-
10
- # Includes
11
-
12
- include Enumerable
13
-
14
- # Instance Methods
15
-
16
- #
17
- # @example
18
- # model = Sketchup.active_model
19
- # group = model.entities.add_group
20
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
21
- # path = Sketchup::InstancePath.new([group, edge])
22
- # if path.size > 1
23
- # # do something
24
- # end
25
- #
26
- # @return [Boolean] `true` if the instances paths represent the same set of
27
- # entities.
28
- #
29
- # @version SketchUp 2017
30
- def ==(other)
31
- end
32
-
33
- # The elements of an instance path can be accessed like an array.
34
- #
35
- # @example
36
- # model = Sketchup.active_model
37
- # group = model.entities.add_group
38
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
39
- # path = Sketchup::InstancePath.new([group, edge])
40
- # path[0] == group # returns true
41
- # path[1] == edge # returns true
42
- #
43
- # @param [Integer] index
44
- #
45
- # @raise [IndexError] if the given index is out of bounds
46
- #
47
- # @raise [TypeError] if the index is not of integer type
48
- #
49
- # @raise [TypeError] if the instance path refer to deleted entities.
50
- #
51
- # @return [Sketchup::Entity]
52
- #
53
- # @version SketchUp 2017
54
- def [](index)
55
- end
56
-
57
- # The yielded entities will start with the root and end with the leaf.
58
- #
59
- # @example
60
- # model = Sketchup.active_model
61
- # group = model.entities.add_group
62
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
63
- # path = Sketchup::InstancePath.new([group, edge])
64
- # path.each { |entity|
65
- # # do something
66
- # }
67
- #
68
- # @raise [TypeError] if the instance path refer to deleted entities.
69
- #
70
- # @return [nil]
71
- #
72
- # @version SketchUp 2017
73
- #
74
- # @yield [Sketchup::Entity] entity
75
- def each
76
- end
77
-
78
- #
79
- # @example
80
- # model = Sketchup.active_model
81
- # group = model.entities.add_group
82
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
83
- # path = Sketchup::InstancePath.new([group, edge])
84
- # if path.empty?
85
- # # do something...
86
- # end
87
- #
88
- # @raise [TypeError] if the instance path refer to deleted entities.
89
- #
90
- # @return [Boolean]
91
- #
92
- # @version SketchUp 2017
93
- def empty?
94
- end
95
-
96
- # Returns `true` if the instance path contain the given object.
97
- #
98
- # @example
99
- # model = Sketchup.active_model
100
- # group = model.entities.add_group
101
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
102
- # path = Sketchup::InstancePath.new([group, edge])
103
- # if path.include?(edge)
104
- # # do something...
105
- # end
106
- #
107
- # @param [Object] object
108
- #
109
- # @raise [TypeError] if the instance path refer to deleted entities.
110
- #
111
- # @return [Boolean]
112
- #
113
- # @version SketchUp 2017
114
- def include?(object)
115
- end
116
-
117
- #
118
- # @example
119
- # model = Sketchup.active_model
120
- # group = model.entities.add_group
121
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
122
- # path = Sketchup::InstancePath.new([group, edge])
123
- #
124
- # @param [Array<Sketchup::Entity>] path
125
- # The leaf can be any entity, but the
126
- # rest must be a group or component instance.
127
- #
128
- # @raise [ArgumentError] if the instance path isn't composed of instances and
129
- # an optional leaf entity.
130
- #
131
- # @return [Sketchup::InstancePath]
132
- #
133
- # @version SketchUp 2017
134
- def initialize(path)
135
- end
136
-
137
- # The leaf of an instance path is the last element which can be any entity
138
- # that can be represented in the model. This is normally a
139
- # {Sketchup::Drawingelement}, but could be a {Sketchup::Vertex}.
140
- #
141
- # An instance can also be a leaf.
142
- #
143
- # @example
144
- # model = Sketchup.active_model
145
- # group = model.entities.add_group
146
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
147
- # path = Sketchup::InstancePath.new([group, edge])
148
- # path.leaf == edge # returns true
149
- #
150
- # @raise [TypeError] if the instance path refer to deleted entities.
151
- #
152
- # @return [Sketchup::Entity]
153
- #
154
- # @version SketchUp 2017
155
- def leaf
156
- end
157
-
158
- # {#length} is an alias of {#size}.
159
- #
160
- # @example
161
- # model = Sketchup.active_model
162
- # group = model.entities.add_group
163
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
164
- # path = Sketchup::InstancePath.new([group, edge])
165
- # if path.length > 1
166
- # # do something
167
- # end
168
- #
169
- # @raise [TypeError] if the instance path refer to deleted entities.
170
- #
171
- # @return [Integer]
172
- #
173
- # @see #size
174
- #
175
- # @version SketchUp 2017
176
- def length
177
- end
178
-
179
- # The serialized version of an instance path is the persistent ids of its
180
- # entities concatenated with a period.
181
- #
182
- # @example
183
- # model = Sketchup.active_model
184
- # group = model.entities.add_group
185
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
186
- # path = Sketchup::InstancePath.new([group, edge])
187
- # pid_path = path.persistent_id_path # something like "342.345"
188
- #
189
- # @raise [TypeError] if the instance path refer to deleted entities.
190
- #
191
- # @return [String]
192
- #
193
- # @see Sketchup::Model#instance_path_from_pid_path
194
- #
195
- # @version SketchUp 2017
196
- def persistent_id_path
197
- end
198
-
199
- # The root of an instance path is the element located closest to the model
200
- # root. This will be a group or component instance. If you have a non-instance
201
- # as a leaf with no other parent component this will return `nil`.
202
- #
203
- # @example
204
- # model = Sketchup.active_model
205
- # group = model.entities.add_group
206
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
207
- # path = Sketchup::InstancePath.new([group, edge])
208
- # path.root == group # returns true
209
- #
210
- # @raise [TypeError] if the instance path refer to deleted entities.
211
- #
212
- # @return [Sketchup::Group, Sketchup::ComponentInstance, nil]
213
- #
214
- # @version SketchUp 2017
215
- def root
216
- end
217
-
218
- #
219
- # @example
220
- # model = Sketchup.active_model
221
- # group = model.entities.add_group
222
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
223
- # path = Sketchup::InstancePath.new([group, edge])
224
- # if path.size > 1
225
- # # do something
226
- # end
227
- #
228
- # @raise [TypeError] if the instance path refer to deleted entities.
229
- #
230
- # @return [Integer]
231
- #
232
- # @see #length
233
- #
234
- # @version SketchUp 2017
235
- def size
236
- end
237
-
238
- #
239
- # @example
240
- # model = Sketchup.active_model
241
- # group = model.entities.add_group
242
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
243
- # path = Sketchup::InstancePath.new([group, edge])
244
- # pid_string = path.to_a.join('.')
245
- #
246
- # @raise [TypeError] if the instance path refer to deleted entities.
247
- #
248
- # @return [Array] an array representing the instance path.
249
- #
250
- # @version SketchUp 2017
251
- def to_a
252
- end
253
-
254
- #
255
- # @example
256
- # model = Sketchup.active_model
257
- # group = model.entities.add_group
258
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
259
- # path = Sketchup::InstancePath.new([group, edge])
260
- # tr = path.transformation
261
- #
262
- # @overload transformation
263
- #
264
- # @return [Geom::Transformation] the combined transformation up to the
265
- # the leaf entity.
266
- #
267
- # @overload transformation(index)
268
- #
269
- # @param [Integer] index
270
- # @return [Geom::Transformation] the combined transformation up to the
271
- # the given index.
272
- #
273
- # @raise [IndexError] if the given index is out of bounds
274
- #
275
- # @raise [TypeError] if the index is not of integer type
276
- #
277
- # @raise [TypeError] if the instance path refer to deleted entities.
278
- #
279
- # @version SketchUp 2017
280
- def transformation(*args)
281
- end
282
-
283
- # An instance path is valid if it has at least one element and consist of
284
- # groups and instances with exception of the leaf which can be any entity.
285
- #
286
- # This method doesn't check if the path can actually be looked up in the model.
287
- #
288
- # @example
289
- # model = Sketchup.active_model
290
- # group = model.entities.add_group
291
- # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
292
- # path = Sketchup::InstancePath.new([group, edge])
293
- # if path.valid?
294
- # # do something...
295
- # end
296
- #
297
- # @return [Boolean]
298
- #
299
- # @version SketchUp 2017
300
- def valid?
301
- end
302
-
303
- end
1
+ # Copyright:: Copyright 2020 Trimble Inc.
2
+ # License:: The MIT License (MIT)
3
+
4
+ # The {Sketchup::InstancePath} class represent the instance path to a given
5
+ # entity within the model hierarchy.
6
+ #
7
+ # @version SketchUp 2017
8
+ class Sketchup::InstancePath
9
+
10
+ # Includes
11
+
12
+ include Enumerable
13
+
14
+ # Instance Methods
15
+
16
+ #
17
+ # @example
18
+ # model = Sketchup.active_model
19
+ # group = model.entities.add_group
20
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
21
+ # path = Sketchup::InstancePath.new([group, edge])
22
+ # if path.size > 1
23
+ # # do something
24
+ # end
25
+ #
26
+ # @return [Boolean] `true` if the instances paths represent the same set of
27
+ # entities.
28
+ #
29
+ # @version SketchUp 2017
30
+ def ==(other)
31
+ end
32
+
33
+ # The elements of an instance path can be accessed similarly to an array.
34
+ #
35
+ # @example
36
+ # model = Sketchup.active_model
37
+ # group = model.entities.add_group
38
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
39
+ # path = Sketchup::InstancePath.new([group, edge])
40
+ # path[0] == group # returns true
41
+ # path[1] == edge # returns true
42
+ #
43
+ # @note This method does not accept negative indices. For the exact behavior
44
+ # of an array, use +{#to_a}+.
45
+ #
46
+ # @param [Integer] index
47
+ #
48
+ # @raise [IndexError] if the given index is out of bounds
49
+ #
50
+ # @raise [TypeError] if the index is not of integer type
51
+ #
52
+ # @raise [TypeError] if the instance path refer to deleted entities.
53
+ #
54
+ # @return [Sketchup::Entity]
55
+ #
56
+ # @version SketchUp 2017
57
+ def [](index)
58
+ end
59
+
60
+ # The yielded entities will start with the root and end with the leaf.
61
+ #
62
+ # @example
63
+ # model = Sketchup.active_model
64
+ # group = model.entities.add_group
65
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
66
+ # path = Sketchup::InstancePath.new([group, edge])
67
+ # path.each { |entity|
68
+ # # do something
69
+ # }
70
+ #
71
+ # @raise [TypeError] if the instance path refer to deleted entities.
72
+ #
73
+ # @return [nil]
74
+ #
75
+ # @version SketchUp 2017
76
+ #
77
+ # @yield [Sketchup::Entity] entity
78
+ def each
79
+ end
80
+
81
+ #
82
+ # @example
83
+ # model = Sketchup.active_model
84
+ # group = model.entities.add_group
85
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
86
+ # path = Sketchup::InstancePath.new([group, edge])
87
+ # if path.empty?
88
+ # # do something...
89
+ # end
90
+ #
91
+ # @raise [TypeError] if the instance path refer to deleted entities.
92
+ #
93
+ # @return [Boolean]
94
+ #
95
+ # @version SketchUp 2017
96
+ def empty?
97
+ end
98
+
99
+ # Returns `true` if the instance path contain the given object.
100
+ #
101
+ # @example
102
+ # model = Sketchup.active_model
103
+ # group = model.entities.add_group
104
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
105
+ # path = Sketchup::InstancePath.new([group, edge])
106
+ # if path.include?(edge)
107
+ # # do something...
108
+ # end
109
+ #
110
+ # @param [Object] object
111
+ #
112
+ # @raise [TypeError] if the instance path refer to deleted entities.
113
+ #
114
+ # @return [Boolean]
115
+ #
116
+ # @version SketchUp 2017
117
+ def include?(object)
118
+ end
119
+
120
+ #
121
+ # @example
122
+ # model = Sketchup.active_model
123
+ # group = model.entities.add_group
124
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
125
+ # path = Sketchup::InstancePath.new([group, edge])
126
+ #
127
+ # @param [Array<Sketchup::Entity>] path
128
+ # The leaf can be any entity, but the
129
+ # rest must be a group or component instance.
130
+ #
131
+ # @raise [ArgumentError] if the instance path isn't composed of instances and
132
+ # an optional leaf entity.
133
+ #
134
+ # @return [Sketchup::InstancePath]
135
+ #
136
+ # @version SketchUp 2017
137
+ def initialize(path)
138
+ end
139
+
140
+ # The leaf of an instance path is the last element which can be any entity
141
+ # that can be represented in the model. This is normally a
142
+ # {Sketchup::Drawingelement}, but could be a {Sketchup::Vertex}.
143
+ #
144
+ # An instance can also be a leaf.
145
+ #
146
+ # @example
147
+ # model = Sketchup.active_model
148
+ # group = model.entities.add_group
149
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
150
+ # path = Sketchup::InstancePath.new([group, edge])
151
+ # path.leaf == edge # returns true
152
+ #
153
+ # @raise [TypeError] if the instance path refer to deleted entities.
154
+ #
155
+ # @return [Sketchup::Entity]
156
+ #
157
+ # @version SketchUp 2017
158
+ def leaf
159
+ end
160
+
161
+ # {#length} is an alias of {#size}.
162
+ #
163
+ # @example
164
+ # model = Sketchup.active_model
165
+ # group = model.entities.add_group
166
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
167
+ # path = Sketchup::InstancePath.new([group, edge])
168
+ # if path.length > 1
169
+ # # do something
170
+ # end
171
+ #
172
+ # @raise [TypeError] if the instance path refer to deleted entities.
173
+ #
174
+ # @return [Integer]
175
+ #
176
+ # @see #size
177
+ #
178
+ # @version SketchUp 2017
179
+ def length
180
+ end
181
+
182
+ # The serialized version of an instance path is the persistent ids of its
183
+ # entities concatenated with a period.
184
+ #
185
+ # @example
186
+ # model = Sketchup.active_model
187
+ # group = model.entities.add_group
188
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
189
+ # path = Sketchup::InstancePath.new([group, edge])
190
+ # pid_path = path.persistent_id_path # something like "342.345"
191
+ #
192
+ # @raise [TypeError] if the instance path refer to deleted entities.
193
+ #
194
+ # @return [String]
195
+ #
196
+ # @see Sketchup::Model#instance_path_from_pid_path
197
+ #
198
+ # @version SketchUp 2017
199
+ def persistent_id_path
200
+ end
201
+
202
+ # The root of an instance path is the element located closest to the model
203
+ # root. This will be a group or component instance. If you have a non-instance
204
+ # as a leaf with no other parent component this will return `nil`.
205
+ #
206
+ # @example
207
+ # model = Sketchup.active_model
208
+ # group = model.entities.add_group
209
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
210
+ # path = Sketchup::InstancePath.new([group, edge])
211
+ # path.root == group # returns true
212
+ #
213
+ # @raise [TypeError] if the instance path refer to deleted entities.
214
+ #
215
+ # @return [Sketchup::Group, Sketchup::ComponentInstance, nil]
216
+ #
217
+ # @version SketchUp 2017
218
+ def root
219
+ end
220
+
221
+ #
222
+ # @example
223
+ # model = Sketchup.active_model
224
+ # group = model.entities.add_group
225
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
226
+ # path = Sketchup::InstancePath.new([group, edge])
227
+ # if path.size > 1
228
+ # # do something
229
+ # end
230
+ #
231
+ # @raise [TypeError] if the instance path refer to deleted entities.
232
+ #
233
+ # @return [Integer]
234
+ #
235
+ # @see #length
236
+ #
237
+ # @version SketchUp 2017
238
+ def size
239
+ end
240
+
241
+ #
242
+ # @example
243
+ # model = Sketchup.active_model
244
+ # group = model.entities.add_group
245
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
246
+ # path = Sketchup::InstancePath.new([group, edge])
247
+ # pid_string = path.to_a.join('.')
248
+ #
249
+ # @raise [TypeError] if the instance path refer to deleted entities.
250
+ #
251
+ # @return [Array] an array representing the instance path.
252
+ #
253
+ # @version SketchUp 2017
254
+ def to_a
255
+ end
256
+
257
+ #
258
+ # @example
259
+ # model = Sketchup.active_model
260
+ # group = model.entities.add_group
261
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
262
+ # path = Sketchup::InstancePath.new([group, edge])
263
+ # tr = path.transformation
264
+ #
265
+ # @overload transformation
266
+ #
267
+ # @return [Geom::Transformation] the combined transformation up to the
268
+ # the leaf entity.
269
+ #
270
+ # @overload transformation(index)
271
+ #
272
+ # @param [Integer] index
273
+ # @return [Geom::Transformation] the combined transformation up to the
274
+ # the given index.
275
+ #
276
+ # @raise [IndexError] if the given index is out of bounds
277
+ #
278
+ # @raise [TypeError] if the index is not of integer type
279
+ #
280
+ # @raise [TypeError] if the instance path refer to deleted entities.
281
+ #
282
+ # @version SketchUp 2017
283
+ def transformation(*args)
284
+ end
285
+
286
+ # An instance path is valid if it has at least one element and consist of
287
+ # groups and instances with exception of the leaf which can be any entity.
288
+ #
289
+ # This method doesn't check if the path can actually be looked up in the model.
290
+ #
291
+ # @example
292
+ # model = Sketchup.active_model
293
+ # group = model.entities.add_group
294
+ # edge = group.entities.add_line([10, 10, 10], [20, 20, 20])
295
+ # path = Sketchup::InstancePath.new([group, edge])
296
+ # if path.valid?
297
+ # # do something...
298
+ # end
299
+ #
300
+ # @return [Boolean]
301
+ #
302
+ # @version SketchUp 2017
303
+ def valid?
304
+ end
305
+
306
+ end