sketchup-api-stubs 0.7.9 → 0.7.11

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 (160) hide show
  1. checksums.yaml +4 -4
  2. data/lib/sketchup-api-stubs/sketchup.rb +157 -151
  3. data/lib/sketchup-api-stubs/stubs/Array.rb +741 -741
  4. data/lib/sketchup-api-stubs/stubs/Geom/BoundingBox.rb +322 -322
  5. data/lib/sketchup-api-stubs/stubs/Geom/Bounds2d.rb +182 -172
  6. data/lib/sketchup-api-stubs/stubs/Geom/LatLong.rb +111 -126
  7. data/lib/sketchup-api-stubs/stubs/Geom/OrientedBounds2d.rb +102 -102
  8. data/lib/sketchup-api-stubs/stubs/Geom/Point2d.rb +423 -400
  9. data/lib/sketchup-api-stubs/stubs/Geom/Point3d.rb +693 -661
  10. data/lib/sketchup-api-stubs/stubs/Geom/PolygonMesh.rb +535 -509
  11. data/lib/sketchup-api-stubs/stubs/Geom/Transformation.rb +500 -476
  12. data/lib/sketchup-api-stubs/stubs/Geom/Transformation2d.rb +267 -263
  13. data/lib/sketchup-api-stubs/stubs/Geom/UTM.rb +133 -141
  14. data/lib/sketchup-api-stubs/stubs/Geom/Vector2d.rb +547 -522
  15. data/lib/sketchup-api-stubs/stubs/Geom/Vector3d.rb +678 -693
  16. data/lib/sketchup-api-stubs/stubs/Geom.rb +351 -351
  17. data/lib/sketchup-api-stubs/stubs/LanguageHandler.rb +93 -93
  18. data/lib/sketchup-api-stubs/stubs/Layout/AngularDimension.rb +595 -595
  19. data/lib/sketchup-api-stubs/stubs/Layout/AutoTextDefinition.rb +751 -747
  20. data/lib/sketchup-api-stubs/stubs/Layout/AutoTextDefinitions.rb +183 -183
  21. data/lib/sketchup-api-stubs/stubs/Layout/ConnectionPoint.rb +70 -70
  22. data/lib/sketchup-api-stubs/stubs/Layout/Dictionary.rb +234 -0
  23. data/lib/sketchup-api-stubs/stubs/Layout/Document.rb +683 -517
  24. data/lib/sketchup-api-stubs/stubs/Layout/Ellipse.rb +29 -29
  25. data/lib/sketchup-api-stubs/stubs/Layout/Entities.rb +148 -148
  26. data/lib/sketchup-api-stubs/stubs/Layout/Entity.rb +464 -353
  27. data/lib/sketchup-api-stubs/stubs/Layout/FormattedText.rb +354 -354
  28. data/lib/sketchup-api-stubs/stubs/Layout/Grid.rb +311 -311
  29. data/lib/sketchup-api-stubs/stubs/Layout/Group.rb +261 -261
  30. data/lib/sketchup-api-stubs/stubs/Layout/Image.rb +91 -91
  31. data/lib/sketchup-api-stubs/stubs/Layout/Label.rb +370 -370
  32. data/lib/sketchup-api-stubs/stubs/Layout/Layer.rb +218 -218
  33. data/lib/sketchup-api-stubs/stubs/Layout/LayerInstance.rb +128 -128
  34. data/lib/sketchup-api-stubs/stubs/Layout/Layers.rb +225 -225
  35. data/lib/sketchup-api-stubs/stubs/Layout/LinearDimension.rb +614 -567
  36. data/lib/sketchup-api-stubs/stubs/Layout/LockedEntityError.rb +10 -10
  37. data/lib/sketchup-api-stubs/stubs/Layout/LockedLayerError.rb +11 -11
  38. data/lib/sketchup-api-stubs/stubs/Layout/Page.rb +282 -183
  39. data/lib/sketchup-api-stubs/stubs/Layout/PageInfo.rb +458 -387
  40. data/lib/sketchup-api-stubs/stubs/Layout/Pages.rb +209 -209
  41. data/lib/sketchup-api-stubs/stubs/Layout/Path.rb +346 -344
  42. data/lib/sketchup-api-stubs/stubs/Layout/Rectangle.rb +174 -174
  43. data/lib/sketchup-api-stubs/stubs/Layout/ReferenceEntity.rb +82 -82
  44. data/lib/sketchup-api-stubs/stubs/Layout/SketchUpModel.rb +714 -692
  45. data/lib/sketchup-api-stubs/stubs/Layout/Style.rb +1565 -1519
  46. data/lib/sketchup-api-stubs/stubs/Layout/Table.rb +290 -290
  47. data/lib/sketchup-api-stubs/stubs/Layout/TableCell.rb +149 -149
  48. data/lib/sketchup-api-stubs/stubs/Layout/TableColumn.rb +139 -139
  49. data/lib/sketchup-api-stubs/stubs/Layout/TableRow.rb +135 -135
  50. data/lib/sketchup-api-stubs/stubs/Layout.rb +25 -25
  51. data/lib/sketchup-api-stubs/stubs/Length.rb +286 -278
  52. data/lib/sketchup-api-stubs/stubs/Numeric.rb +249 -249
  53. data/lib/sketchup-api-stubs/stubs/Sketchup/Animation.rb +196 -144
  54. data/lib/sketchup-api-stubs/stubs/Sketchup/AppObserver.rb +169 -169
  55. data/lib/sketchup-api-stubs/stubs/Sketchup/ArcCurve.rb +226 -209
  56. data/lib/sketchup-api-stubs/stubs/Sketchup/AttributeDictionaries.rb +145 -150
  57. data/lib/sketchup-api-stubs/stubs/Sketchup/AttributeDictionary.rb +294 -281
  58. data/lib/sketchup-api-stubs/stubs/Sketchup/Axes.rb +149 -149
  59. data/lib/sketchup-api-stubs/stubs/Sketchup/Behavior.rb +296 -302
  60. data/lib/sketchup-api-stubs/stubs/Sketchup/Camera.rb +473 -478
  61. data/lib/sketchup-api-stubs/stubs/Sketchup/ClassificationSchema.rb +63 -63
  62. data/lib/sketchup-api-stubs/stubs/Sketchup/Classifications.rb +121 -121
  63. data/lib/sketchup-api-stubs/stubs/Sketchup/Color.rb +294 -294
  64. data/lib/sketchup-api-stubs/stubs/Sketchup/ComponentDefinition.rb +673 -659
  65. data/lib/sketchup-api-stubs/stubs/Sketchup/ComponentInstance.rb +600 -593
  66. data/lib/sketchup-api-stubs/stubs/Sketchup/Console.rb +76 -76
  67. data/lib/sketchup-api-stubs/stubs/Sketchup/ConstructionLine.rb +252 -257
  68. data/lib/sketchup-api-stubs/stubs/Sketchup/ConstructionPoint.rb +32 -32
  69. data/lib/sketchup-api-stubs/stubs/Sketchup/Curve.rb +201 -201
  70. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionList.rb +443 -449
  71. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionObserver.rb +74 -74
  72. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionsObserver.rb +104 -104
  73. data/lib/sketchup-api-stubs/stubs/Sketchup/Dimension.rb +167 -165
  74. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionLinear.rb +306 -306
  75. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionObserver.rb +42 -42
  76. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionRadial.rb +87 -87
  77. data/lib/sketchup-api-stubs/stubs/Sketchup/Drawingelement.rb +403 -406
  78. data/lib/sketchup-api-stubs/stubs/Sketchup/Edge.rb +397 -397
  79. data/lib/sketchup-api-stubs/stubs/Sketchup/EdgeUse.rb +211 -211
  80. data/lib/sketchup-api-stubs/stubs/Sketchup/Entities.rb +1282 -1239
  81. data/lib/sketchup-api-stubs/stubs/Sketchup/EntitiesBuilder.rb +261 -261
  82. data/lib/sketchup-api-stubs/stubs/Sketchup/EntitiesObserver.rb +127 -127
  83. data/lib/sketchup-api-stubs/stubs/Sketchup/Entity.rb +519 -545
  84. data/lib/sketchup-api-stubs/stubs/Sketchup/EntityObserver.rb +60 -60
  85. data/lib/sketchup-api-stubs/stubs/Sketchup/Environment.rb +406 -0
  86. data/lib/sketchup-api-stubs/stubs/Sketchup/Environments.rb +185 -0
  87. data/lib/sketchup-api-stubs/stubs/Sketchup/EnvironmentsObserver.rb +113 -0
  88. data/lib/sketchup-api-stubs/stubs/Sketchup/ExtensionsManager.rb +122 -125
  89. data/lib/sketchup-api-stubs/stubs/Sketchup/Face.rb +1006 -937
  90. data/lib/sketchup-api-stubs/stubs/Sketchup/FrameChangeObserver.rb +102 -102
  91. data/lib/sketchup-api-stubs/stubs/Sketchup/Group.rb +740 -750
  92. data/lib/sketchup-api-stubs/stubs/Sketchup/Http/Request.rb +289 -282
  93. data/lib/sketchup-api-stubs/stubs/Sketchup/Http/Response.rb +64 -62
  94. data/lib/sketchup-api-stubs/stubs/Sketchup/Http.rb +27 -27
  95. data/lib/sketchup-api-stubs/stubs/Sketchup/Image.rb +405 -468
  96. data/lib/sketchup-api-stubs/stubs/Sketchup/ImageRep.rb +266 -266
  97. data/lib/sketchup-api-stubs/stubs/Sketchup/Importer.rb +189 -189
  98. data/lib/sketchup-api-stubs/stubs/Sketchup/InputPoint.rb +432 -406
  99. data/lib/sketchup-api-stubs/stubs/Sketchup/InstanceObserver.rb +84 -84
  100. data/lib/sketchup-api-stubs/stubs/Sketchup/InstancePath.rb +307 -306
  101. data/lib/sketchup-api-stubs/stubs/Sketchup/Layer.rb +332 -326
  102. data/lib/sketchup-api-stubs/stubs/Sketchup/LayerFolder.rb +380 -422
  103. data/lib/sketchup-api-stubs/stubs/Sketchup/Layers.rb +409 -427
  104. data/lib/sketchup-api-stubs/stubs/Sketchup/LayersObserver.rb +241 -249
  105. data/lib/sketchup-api-stubs/stubs/Sketchup/Licensing/ExtensionLicense.rb +86 -86
  106. data/lib/sketchup-api-stubs/stubs/Sketchup/Licensing.rb +55 -48
  107. data/lib/sketchup-api-stubs/stubs/Sketchup/LineStyle.rb +24 -24
  108. data/lib/sketchup-api-stubs/stubs/Sketchup/LineStyles.rb +114 -114
  109. data/lib/sketchup-api-stubs/stubs/Sketchup/LoadHandler.rb +70 -0
  110. data/lib/sketchup-api-stubs/stubs/Sketchup/Loop.rb +137 -137
  111. data/lib/sketchup-api-stubs/stubs/Sketchup/Material.rb +1115 -414
  112. data/lib/sketchup-api-stubs/stubs/Sketchup/Materials.rb +330 -317
  113. data/lib/sketchup-api-stubs/stubs/Sketchup/MaterialsObserver.rb +142 -142
  114. data/lib/sketchup-api-stubs/stubs/Sketchup/Menu.rb +93 -93
  115. data/lib/sketchup-api-stubs/stubs/Sketchup/Model.rb +1714 -1652
  116. data/lib/sketchup-api-stubs/stubs/Sketchup/ModelObserver.rb +372 -357
  117. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsManager.rb +133 -130
  118. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsProvider.rb +271 -271
  119. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsProviderObserver.rb +58 -58
  120. data/lib/sketchup-api-stubs/stubs/Sketchup/Overlay.rb +463 -490
  121. data/lib/sketchup-api-stubs/stubs/Sketchup/OverlaysManager.rb +104 -116
  122. data/lib/sketchup-api-stubs/stubs/Sketchup/Page.rb +939 -797
  123. data/lib/sketchup-api-stubs/stubs/Sketchup/Pages.rb +388 -361
  124. data/lib/sketchup-api-stubs/stubs/Sketchup/PagesObserver.rb +77 -77
  125. data/lib/sketchup-api-stubs/stubs/Sketchup/PickHelper.rb +501 -478
  126. data/lib/sketchup-api-stubs/stubs/Sketchup/RegionalSettings.rb +43 -43
  127. data/lib/sketchup-api-stubs/stubs/Sketchup/RenderingOptions.rb +385 -361
  128. data/lib/sketchup-api-stubs/stubs/Sketchup/RenderingOptionsObserver.rb +45 -45
  129. data/lib/sketchup-api-stubs/stubs/Sketchup/SectionPlane.rb +150 -150
  130. data/lib/sketchup-api-stubs/stubs/Sketchup/Selection.rb +451 -458
  131. data/lib/sketchup-api-stubs/stubs/Sketchup/SelectionObserver.rb +115 -115
  132. data/lib/sketchup-api-stubs/stubs/Sketchup/Set.rb +211 -212
  133. data/lib/sketchup-api-stubs/stubs/Sketchup/ShadowInfo.rb +259 -255
  134. data/lib/sketchup-api-stubs/stubs/Sketchup/ShadowInfoObserver.rb +59 -59
  135. data/lib/sketchup-api-stubs/stubs/Sketchup/Skp.rb +40 -40
  136. data/lib/sketchup-api-stubs/stubs/Sketchup/Snap.rb +125 -0
  137. data/lib/sketchup-api-stubs/stubs/Sketchup/Style.rb +88 -69
  138. data/lib/sketchup-api-stubs/stubs/Sketchup/Styles.rb +263 -217
  139. data/lib/sketchup-api-stubs/stubs/Sketchup/Text.rb +283 -262
  140. data/lib/sketchup-api-stubs/stubs/Sketchup/Texture.rb +199 -217
  141. data/lib/sketchup-api-stubs/stubs/Sketchup/TextureWriter.rb +237 -237
  142. data/lib/sketchup-api-stubs/stubs/Sketchup/Tool.rb +924 -834
  143. data/lib/sketchup-api-stubs/stubs/Sketchup/Tools.rb +132 -132
  144. data/lib/sketchup-api-stubs/stubs/Sketchup/ToolsObserver.rb +156 -156
  145. data/lib/sketchup-api-stubs/stubs/Sketchup/UVHelper.rb +75 -75
  146. data/lib/sketchup-api-stubs/stubs/Sketchup/Vertex.rb +143 -142
  147. data/lib/sketchup-api-stubs/stubs/Sketchup/View.rb +1566 -1311
  148. data/lib/sketchup-api-stubs/stubs/Sketchup/ViewObserver.rb +71 -45
  149. data/lib/sketchup-api-stubs/stubs/Sketchup.rb +1429 -1377
  150. data/lib/sketchup-api-stubs/stubs/SketchupExtension.rb +353 -353
  151. data/lib/sketchup-api-stubs/stubs/String.rb +24 -24
  152. data/lib/sketchup-api-stubs/stubs/UI/Command.rb +399 -389
  153. data/lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb +580 -494
  154. data/lib/sketchup-api-stubs/stubs/UI/Notification.rb +280 -269
  155. data/lib/sketchup-api-stubs/stubs/UI/Toolbar.rb +258 -241
  156. data/lib/sketchup-api-stubs/stubs/UI/WebDialog.rb +636 -635
  157. data/lib/sketchup-api-stubs/stubs/UI.rb +791 -683
  158. data/lib/sketchup-api-stubs/stubs/_top_level.rb +303 -303
  159. data/lib/sketchup-api-stubs.rb +1 -1
  160. metadata +10 -24
@@ -1,10 +1,10 @@
1
- # Copyright:: Copyright 2023 Trimble Inc.
2
- # License:: The MIT License (MIT)
3
-
4
- # This is raised whenever a method attempts to modify any {Layout::Entity}
5
- # that is individually locked.
6
- #
7
- # @version LayOut 2018
8
- class Layout::LockedEntityError < ArgumentError
9
-
10
- end
1
+ # Copyright:: Copyright 2026 Trimble Inc.
2
+ # License:: The MIT License (MIT)
3
+
4
+ # This is raised whenever a method attempts to modify any {Layout::Entity}
5
+ # that is individually locked.
6
+ #
7
+ # @version LayOut 2018
8
+ class Layout::LockedEntityError < ArgumentError
9
+
10
+ end
@@ -1,11 +1,11 @@
1
- # Copyright:: Copyright 2023 Trimble Inc.
2
- # License:: The MIT License (MIT)
3
-
4
- # This is raised whenever a method attempts to modify any {Layout::Entity}
5
- # that resides on a locked {Layout::Layer}, or when attempting to change the
6
- # shared attribute of a locked {Layout::Layer}.
7
- #
8
- # @version LayOut 2018
9
- class Layout::LockedLayerError < ArgumentError
10
-
11
- end
1
+ # Copyright:: Copyright 2026 Trimble Inc.
2
+ # License:: The MIT License (MIT)
3
+
4
+ # This is raised whenever a method attempts to modify any {Layout::Entity}
5
+ # that resides on a locked {Layout::Layer}, or when attempting to change the
6
+ # shared attribute of a locked {Layout::Layer}.
7
+ #
8
+ # @version LayOut 2018
9
+ class Layout::LockedLayerError < ArgumentError
10
+
11
+ end
@@ -1,183 +1,282 @@
1
- # Copyright:: Copyright 2023 Trimble Inc.
2
- # License:: The MIT License (MIT)
3
-
4
- # Class for a single page in a LayOut document.
5
- #
6
- # @version LayOut 2018
7
- class Layout::Page
8
-
9
- # Instance Methods
10
-
11
- # The {#==} method checks to see if the two {Layout::Page}s are equal.
12
- # This checks whether the Ruby Objects are pointing to the same internal
13
- # object.
14
- #
15
- # @example
16
- # doc = Layout::Document.open("C:/path/to/document.layout")
17
- # document = doc.pages.first.document
18
- # doc.pages.first == document.pages.first
19
- #
20
- # @param [Layout::Page] other
21
- #
22
- # @return [Boolean]
23
- #
24
- # @version LayOut 2018
25
- def ==(other)
26
- end
27
-
28
- # The {#document} method returns the {Layout::Document} that the {Layout::Page}
29
- # belongs to.
30
- #
31
- # @example
32
- # doc = Layout::Document.open("C:/path/to/document.layout")
33
- # first_page = doc.pages.first
34
- # # page_doc should reference the same document as doc
35
- # page_doc = first_page.document
36
- #
37
- # @return [Layout::Document]
38
- #
39
- # @version LayOut 2018
40
- def document
41
- end
42
-
43
- # The {#entities} method returns all {Layout::Entity}s that are on the
44
- # {Layout::Page}. This is the equivalent of iterating over all
45
- # {Layout::LayerInstance}s and using {Layout::LayerInstance.entities}.
46
- #
47
- # @example
48
- # doc = Layout::Document.open("C:/path/to/document.layout")
49
- # first_page = doc.pages.first
50
- # entities = first_page.entities
51
- #
52
- # @return [Layout::Entities]
53
- #
54
- # @version LayOut 2018
55
- def entities
56
- end
57
-
58
- # The {#in_presentation=} method sets whether the {Layout::Page} is included in
59
- # presentations.
60
- #
61
- # @example
62
- # doc = Layout::Document.open("C:/path/to/document.layout")
63
- # first_page = doc.pages.first
64
- # first_page.in_presentation = true
65
- #
66
- # @param [Boolean] in_presentation
67
- #
68
- # @version LayOut 2018
69
- def in_presentation=(in_presentation)
70
- end
71
-
72
- # The {#in_presentation?} method returns whether the {Layout::Page} is included
73
- # in presentations.
74
- #
75
- # @example
76
- # doc = Layout::Document.open("C:/path/to/document.layout")
77
- # first_page = doc.pages.first
78
- # in_presentation = first_page.in_presentation?
79
- #
80
- # @return [Boolean]
81
- #
82
- # @version LayOut 2018
83
- def in_presentation?
84
- end
85
-
86
- # The {#layer_instances} method returns an array of the {Layout::LayerInstance}s
87
- # for the {Layout::Page}.
88
- #
89
- # @example
90
- # # An example of page.layer_instances
91
- #
92
- # @return [Array<Layout::LayerInstance>]
93
- #
94
- # @version LayOut 2018
95
- def layer_instances
96
- end
97
-
98
- # The {#layer_visible?} method returns whether a {Layout::Layer} is visible
99
- # on the {Layout::Page}.
100
- #
101
- # @example
102
- # doc = Layout::Document.open("C:/path/to/document.layout")
103
- # first_page = doc.pages.first
104
- # layer = doc.layers.first
105
- # visible = first_page.layer_visible?(layer)
106
- #
107
- # @param [Layout::Layer] layer
108
- #
109
- # @raise [ArgumentError] if layer and page are not in the same document
110
- #
111
- # @return [Boolean]
112
- #
113
- # @version LayOut 2018
114
- def layer_visible?(layer)
115
- end
116
-
117
- # The {#name} method returns the name of the {Layout::Page}.
118
- #
119
- # @example
120
- # doc = Layout::Document.open("C:/path/to/document.layout")
121
- # pages = doc.pages
122
- # first_page_name = pages.first.name
123
- #
124
- # @return [String]
125
- #
126
- # @version LayOut 2018
127
- def name
128
- end
129
-
130
- # The {#name=} method sets the name of a page.
131
- #
132
- # @example
133
- # doc = Layout::Document.open("C:/path/to/document.layout")
134
- # pages = doc.pages
135
- # pages.first.name = "First page"
136
- #
137
- # @param [String] name
138
- #
139
- # @raise [ArgumentError] if name is an empty string
140
- #
141
- # @version LayOut 2018
142
- def name=(name)
143
- end
144
-
145
- # The {#nonshared_entities} method returns the {Layout::Entities}
146
- # unique to the {Layout::Page}.
147
- #
148
- # @example
149
- # doc = Layout::Document.open("C:/path/to/document.layout")
150
- # first_page = doc.pages.first
151
- # entities = first_page.nonshared_entities
152
- #
153
- # @return [Layout::Entities]
154
- #
155
- # @version LayOut 2018
156
- def nonshared_entities
157
- end
158
-
159
- # The {#set_layer_visibility} method sets whether a {Layout::Layer} is visible
160
- # on the {Layout::Page}.
161
- #
162
- # @example
163
- # doc = Layout::Document.open("C:/path/to/document.layout")
164
- # first_page = doc.pages.first
165
- # layer = doc.layers.first
166
- # first_page.set_layer_visibility(layer, false)
167
- #
168
- # @param [Layout::Layer] layer
169
- #
170
- # @param [Boolean] visible
171
- #
172
- # @raise [ArgumentError] if layer and page are not in the same document
173
- #
174
- # @raise [ArgumentError] if layer could not be hidden because there must be at
175
- # least one unlocked, visible layer on each page
176
- #
177
- # @return [Boolean]
178
- #
179
- # @version LayOut 2018
180
- def set_layer_visibility(layer, visible)
181
- end
182
-
183
- end
1
+ # Copyright:: Copyright 2026 Trimble Inc.
2
+ # License:: The MIT License (MIT)
3
+
4
+ # Class for a single page in a LayOut document.
5
+ #
6
+ # @version LayOut 2018
7
+ class Layout::Page
8
+
9
+ # Instance Methods
10
+
11
+ # The {#==} method checks to see if the two {Layout::Page}s are equal.
12
+ # This checks whether the Ruby Objects are pointing to the same internal
13
+ # object.
14
+ #
15
+ # @example
16
+ # doc = Layout::Document.open("C:/path/to/document.layout")
17
+ # document = doc.pages.first.document
18
+ # doc.pages.first == document.pages.first
19
+ #
20
+ # @param [Layout::Page] other
21
+ #
22
+ # @return [Boolean]
23
+ #
24
+ # @version LayOut 2018
25
+ def ==(other)
26
+ end
27
+
28
+ # The {#attribute_dictionary} method returns a copy of the page's attribute dictionary with the
29
+ # given name.
30
+ #
31
+ # @example
32
+ # doc = Layout::Document.open("C:/path/to/document.layout")
33
+ # page = doc.pages.first
34
+ # page.set_attribute("jane_doe_doc_maker", "made_by_doc_maker", true)
35
+ # attributes = page.attribute_dictionary("jane_doe_doc_maker")
36
+ # # Adding to this Layout::Dictionary does not apply to the page's attribute dictionary, use
37
+ # # Layout::Page#set_attribute.
38
+ # attributes.merge!(doc_id: 42)
39
+ #
40
+ # @param [String] name
41
+ #
42
+ # @return [Layout::Dictionary, nil] A copy of the page's attribute dictionary, or nil if there is
43
+ # no attribute dictionary
44
+ #
45
+ # @version LayOut 2026.0
46
+ def attribute_dictionary(name)
47
+ end
48
+
49
+ # The {#delete_attribute} method is used to delete an attribute from a page.
50
+ #
51
+ # @overload delete_attribute(dictionary_name)
52
+ #
53
+ # @param [String] dictionary_name The name of an attribute dictionary.
54
+ # @return [Boolean]
55
+ #
56
+ # @example
57
+ # doc = Layout::Document.open("C:/path/to/document.layout")
58
+ # page = doc.pages.first
59
+ # page.set_attribute("jane_doe_doc_maker", "made_by_doc_maker", true)
60
+ # page.delete_attribute("jane_doe_doc_maker")
61
+ #
62
+ # @overload delete_attribute(dictionary_name, key)
63
+ #
64
+ # @param [String] dictionary_name The name of an attribute dictionary.
65
+ # @param [String] key An attribute key.
66
+ # @return [Boolean]
67
+ #
68
+ # @example
69
+ # doc = Layout::Document.open("C:/path/to/document.layout")
70
+ # page = doc.pages.first
71
+ # page.set_attribute("jane_doe_doc_maker", "made_by_doc_maker", true)
72
+ # page.delete_attribute("jane_doe_doc_maker", "made_by_doc_maker")
73
+ #
74
+ # @version LayOut 2026.0
75
+ def delete_attribute(*args)
76
+ end
77
+
78
+ # The {#document} method returns the {Layout::Document} that the {Layout::Page}
79
+ # belongs to.
80
+ #
81
+ # @example
82
+ # doc = Layout::Document.open("C:/path/to/document.layout")
83
+ # first_page = doc.pages.first
84
+ # # page_doc should reference the same document as doc
85
+ # page_doc = first_page.document
86
+ #
87
+ # @return [Layout::Document]
88
+ #
89
+ # @version LayOut 2018
90
+ def document
91
+ end
92
+
93
+ # The {#entities} method returns all {Layout::Entity}s that are on the
94
+ # {Layout::Page}. This is the equivalent of iterating over all
95
+ # {Layout::LayerInstance}s and using {Layout::LayerInstance.entities}.
96
+ #
97
+ # @example
98
+ # doc = Layout::Document.open("C:/path/to/document.layout")
99
+ # first_page = doc.pages.first
100
+ # entities = first_page.entities
101
+ #
102
+ # @return [Layout::Entities]
103
+ #
104
+ # @version LayOut 2018
105
+ def entities
106
+ end
107
+
108
+ # The {#get_attribute} method is used to retrieve the value of an attribute in
109
+ # the page's attribute dictionary.
110
+ #
111
+ # If the third parameter, +default_value+, is not passed and there is no
112
+ # attribute that matches the given name, it returns +nil+.
113
+ #
114
+ # If +default_value+ is provided and there is no matching attribute it returns
115
+ # the given value. It does not create an attribute with that name though.
116
+ #
117
+ # @example
118
+ # doc = Layout::Document.open("C:/path/to/document.layout")
119
+ # page = doc.pages.first
120
+ # # Read an attribute value from the page. In this case this will return the
121
+ # # default value provided: 42.
122
+ # page.get_attribute("jane_doe_doc_maker", "doc_id", 42)
123
+ #
124
+ # @param [String] name
125
+ # The name of an attribute dictionary.
126
+ #
127
+ # @param [String] key
128
+ # An attribute key.
129
+ #
130
+ # @param [String, Boolean, Integer, Float, Hash, Layout::Dictionary, nil] default_value
131
+ # A default
132
+ # value to return if no attribute is found.
133
+ #
134
+ # @return [String, Boolean, Integer, Float, Layout::Dictionary, nil] the retrieved value.
135
+ #
136
+ # @version LayOut 2026.0
137
+ def get_attribute(name, key, default_value = nil)
138
+ end
139
+
140
+ # The {#in_presentation=} method sets whether the {Layout::Page} is included in
141
+ # presentations.
142
+ #
143
+ # @example
144
+ # doc = Layout::Document.open("C:/path/to/document.layout")
145
+ # first_page = doc.pages.first
146
+ # first_page.in_presentation = true
147
+ #
148
+ # @param [Boolean] in_presentation
149
+ #
150
+ # @version LayOut 2018
151
+ def in_presentation=(in_presentation)
152
+ end
153
+
154
+ # The {#in_presentation?} method returns whether the {Layout::Page} is included
155
+ # in presentations.
156
+ #
157
+ # @example
158
+ # doc = Layout::Document.open("C:/path/to/document.layout")
159
+ # first_page = doc.pages.first
160
+ # in_presentation = first_page.in_presentation?
161
+ #
162
+ # @return [Boolean]
163
+ #
164
+ # @version LayOut 2018
165
+ def in_presentation?
166
+ end
167
+
168
+ # The {#layer_instances} method returns an array of the {Layout::LayerInstance}s
169
+ # for the {Layout::Page}.
170
+ #
171
+ # @example
172
+ # # An example of page.layer_instances
173
+ #
174
+ # @return [Array<Layout::LayerInstance>]
175
+ #
176
+ # @version LayOut 2018
177
+ def layer_instances
178
+ end
179
+
180
+ # The {#layer_visible?} method returns whether a {Layout::Layer} is visible
181
+ # on the {Layout::Page}.
182
+ #
183
+ # @example
184
+ # doc = Layout::Document.open("C:/path/to/document.layout")
185
+ # first_page = doc.pages.first
186
+ # layer = doc.layers.first
187
+ # visible = first_page.layer_visible?(layer)
188
+ #
189
+ # @param [Layout::Layer] layer
190
+ #
191
+ # @raise [ArgumentError] if layer and page are not in the same document
192
+ #
193
+ # @return [Boolean]
194
+ #
195
+ # @version LayOut 2018
196
+ def layer_visible?(layer)
197
+ end
198
+
199
+ # The {#name} method returns the name of the {Layout::Page}.
200
+ #
201
+ # @example
202
+ # doc = Layout::Document.open("C:/path/to/document.layout")
203
+ # pages = doc.pages
204
+ # first_page_name = pages.first.name
205
+ #
206
+ # @return [String]
207
+ #
208
+ # @version LayOut 2018
209
+ def name
210
+ end
211
+
212
+ # The {#name=} method sets the name of a page.
213
+ #
214
+ # @example
215
+ # doc = Layout::Document.open("C:/path/to/document.layout")
216
+ # pages = doc.pages
217
+ # pages.first.name = "First page"
218
+ #
219
+ # @param [String] name
220
+ #
221
+ # @raise [ArgumentError] if name is an empty string
222
+ #
223
+ # @version LayOut 2018
224
+ def name=(name)
225
+ end
226
+
227
+ # The {#nonshared_entities} method returns the {Layout::Entities}
228
+ # unique to the {Layout::Page}.
229
+ #
230
+ # @example
231
+ # doc = Layout::Document.open("C:/path/to/document.layout")
232
+ # first_page = doc.pages.first
233
+ # entities = first_page.nonshared_entities
234
+ #
235
+ # @return [Layout::Entities]
236
+ #
237
+ # @version LayOut 2018
238
+ def nonshared_entities
239
+ end
240
+
241
+ # The {#set_attribute} method adds an attribute to the page's attribute dictionary.
242
+ #
243
+ # @example
244
+ # doc = Layout::Document.open("C:/path/to/document.layout")
245
+ # page = doc.pages.first
246
+ # page.set_attribute("jane_doe_doc_maker", "doc_id", 42)
247
+ #
248
+ # @param [String] name
249
+ # The name of an attribute dictionary.
250
+ # @param [String] key An attribute key.
251
+ # @param [String, Boolean, Integer, Float, Hash, Layout::Dictionary, nil] value The value for the
252
+ # attribute.
253
+ #
254
+ # @version LayOut 2026.0
255
+ def set_attribute(name, key, value)
256
+ end
257
+
258
+ # The {#set_layer_visibility} method sets whether a {Layout::Layer} is visible
259
+ # on the {Layout::Page}.
260
+ #
261
+ # @example
262
+ # doc = Layout::Document.open("C:/path/to/document.layout")
263
+ # first_page = doc.pages.first
264
+ # layer = doc.layers.first
265
+ # first_page.set_layer_visibility(layer, false)
266
+ #
267
+ # @param [Layout::Layer] layer
268
+ #
269
+ # @param [Boolean] visible
270
+ #
271
+ # @raise [ArgumentError] if layer and page are not in the same document
272
+ #
273
+ # @raise [ArgumentError] if layer could not be hidden because there must be at
274
+ # least one unlocked, visible layer on each page
275
+ #
276
+ # @return [Boolean]
277
+ #
278
+ # @version LayOut 2018
279
+ def set_layer_visibility(layer, visible)
280
+ end
281
+
282
+ end