caxlsx 3.2.0 → 3.3.0

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 (300) hide show
  1. checksums.yaml +4 -4
  2. data/.yardopts +9 -9
  3. data/.yardopts_guide +18 -18
  4. data/CHANGELOG.md +385 -354
  5. data/LICENSE +21 -21
  6. data/README.md +165 -168
  7. data/Rakefile +29 -29
  8. data/examples/generate.rb +15 -15
  9. data/lib/axlsx/content_type/abstract_content_type.rb +32 -32
  10. data/lib/axlsx/content_type/content_type.rb +26 -26
  11. data/lib/axlsx/content_type/default.rb +25 -25
  12. data/lib/axlsx/content_type/override.rb +25 -25
  13. data/lib/axlsx/doc_props/app.rb +235 -235
  14. data/lib/axlsx/doc_props/core.rb +39 -39
  15. data/lib/axlsx/drawing/area_chart.rb +99 -99
  16. data/lib/axlsx/drawing/area_series.rb +110 -110
  17. data/lib/axlsx/drawing/ax_data_source.rb +26 -26
  18. data/lib/axlsx/drawing/axes.rb +61 -61
  19. data/lib/axlsx/drawing/axis.rb +190 -190
  20. data/lib/axlsx/drawing/bar_3D_chart.rb +148 -148
  21. data/lib/axlsx/drawing/bar_chart.rb +138 -138
  22. data/lib/axlsx/drawing/bar_series.rb +97 -97
  23. data/lib/axlsx/drawing/bubble_chart.rb +59 -59
  24. data/lib/axlsx/drawing/bubble_series.rb +63 -63
  25. data/lib/axlsx/drawing/cat_axis.rb +85 -85
  26. data/lib/axlsx/drawing/chart.rb +299 -276
  27. data/lib/axlsx/drawing/d_lbls.rb +91 -90
  28. data/lib/axlsx/drawing/drawing.rb +167 -167
  29. data/lib/axlsx/drawing/graphic_frame.rb +54 -54
  30. data/lib/axlsx/drawing/hyperlink.rb +100 -100
  31. data/lib/axlsx/drawing/line_3D_chart.rb +68 -68
  32. data/lib/axlsx/drawing/line_chart.rb +99 -99
  33. data/lib/axlsx/drawing/line_series.rb +110 -110
  34. data/lib/axlsx/drawing/marker.rb +84 -84
  35. data/lib/axlsx/drawing/num_data.rb +52 -52
  36. data/lib/axlsx/drawing/num_data_source.rb +62 -62
  37. data/lib/axlsx/drawing/num_val.rb +34 -34
  38. data/lib/axlsx/drawing/one_cell_anchor.rb +99 -99
  39. data/lib/axlsx/drawing/pic.rb +211 -211
  40. data/lib/axlsx/drawing/picture_locking.rb +42 -42
  41. data/lib/axlsx/drawing/pie_3D_chart.rb +47 -47
  42. data/lib/axlsx/drawing/pie_series.rb +74 -74
  43. data/lib/axlsx/drawing/scaling.rb +60 -60
  44. data/lib/axlsx/drawing/scatter_chart.rb +74 -74
  45. data/lib/axlsx/drawing/scatter_series.rb +129 -129
  46. data/lib/axlsx/drawing/ser_axis.rb +45 -45
  47. data/lib/axlsx/drawing/series.rb +69 -69
  48. data/lib/axlsx/drawing/series_title.rb +25 -25
  49. data/lib/axlsx/drawing/str_data.rb +42 -42
  50. data/lib/axlsx/drawing/str_val.rb +34 -34
  51. data/lib/axlsx/drawing/title.rb +107 -97
  52. data/lib/axlsx/drawing/two_cell_anchor.rb +97 -97
  53. data/lib/axlsx/drawing/val_axis.rb +37 -37
  54. data/lib/axlsx/drawing/view_3D.rb +115 -115
  55. data/lib/axlsx/drawing/vml_drawing.rb +42 -42
  56. data/lib/axlsx/drawing/vml_shape.rb +66 -66
  57. data/lib/axlsx/package.rb +398 -388
  58. data/lib/axlsx/rels/relationship.rb +130 -130
  59. data/lib/axlsx/rels/relationships.rb +32 -32
  60. data/lib/axlsx/stylesheet/border.rb +73 -73
  61. data/lib/axlsx/stylesheet/border_pr.rb +71 -71
  62. data/lib/axlsx/stylesheet/cell_alignment.rb +132 -132
  63. data/lib/axlsx/stylesheet/cell_protection.rb +41 -41
  64. data/lib/axlsx/stylesheet/cell_style.rb +72 -72
  65. data/lib/axlsx/stylesheet/color.rb +76 -76
  66. data/lib/axlsx/stylesheet/dxf.rb +79 -79
  67. data/lib/axlsx/stylesheet/fill.rb +35 -35
  68. data/lib/axlsx/stylesheet/font.rb +156 -156
  69. data/lib/axlsx/stylesheet/gradient_fill.rb +103 -103
  70. data/lib/axlsx/stylesheet/gradient_stop.rb +37 -37
  71. data/lib/axlsx/stylesheet/num_fmt.rb +86 -86
  72. data/lib/axlsx/stylesheet/pattern_fill.rb +73 -73
  73. data/lib/axlsx/stylesheet/styles.rb +535 -494
  74. data/lib/axlsx/stylesheet/table_style.rb +54 -54
  75. data/lib/axlsx/stylesheet/table_style_element.rb +77 -77
  76. data/lib/axlsx/stylesheet/table_styles.rb +46 -46
  77. data/lib/axlsx/stylesheet/xf.rb +147 -147
  78. data/lib/axlsx/util/accessors.rb +64 -64
  79. data/lib/axlsx/util/constants.rb +416 -410
  80. data/lib/axlsx/util/mime_type_utils.rb +11 -11
  81. data/lib/axlsx/util/options_parser.rb +16 -16
  82. data/lib/axlsx/util/serialized_attributes.rb +89 -89
  83. data/lib/axlsx/util/simple_typed_list.rb +179 -179
  84. data/lib/axlsx/util/storage.rb +146 -146
  85. data/lib/axlsx/util/validators.rb +312 -312
  86. data/lib/axlsx/util/zip_command.rb +73 -73
  87. data/lib/axlsx/version.rb +5 -5
  88. data/lib/axlsx/workbook/defined_name.rb +128 -128
  89. data/lib/axlsx/workbook/defined_names.rb +21 -21
  90. data/lib/axlsx/workbook/shared_strings_table.rb +77 -77
  91. data/lib/axlsx/workbook/workbook.rb +425 -395
  92. data/lib/axlsx/workbook/workbook_view.rb +80 -80
  93. data/lib/axlsx/workbook/workbook_views.rb +22 -22
  94. data/lib/axlsx/workbook/worksheet/auto_filter/auto_filter.rb +77 -77
  95. data/lib/axlsx/workbook/worksheet/auto_filter/filter_column.rb +94 -94
  96. data/lib/axlsx/workbook/worksheet/auto_filter/filters.rb +244 -244
  97. data/lib/axlsx/workbook/worksheet/border_creator.rb +76 -0
  98. data/lib/axlsx/workbook/worksheet/break.rb +35 -35
  99. data/lib/axlsx/workbook/worksheet/cell.rb +532 -506
  100. data/lib/axlsx/workbook/worksheet/cell_serializer.rb +164 -164
  101. data/lib/axlsx/workbook/worksheet/cfvo.rb +60 -60
  102. data/lib/axlsx/workbook/worksheet/cfvos.rb +18 -18
  103. data/lib/axlsx/workbook/worksheet/col.rb +145 -145
  104. data/lib/axlsx/workbook/worksheet/col_breaks.rb +35 -35
  105. data/lib/axlsx/workbook/worksheet/color_scale.rb +110 -110
  106. data/lib/axlsx/workbook/worksheet/cols.rb +23 -23
  107. data/lib/axlsx/workbook/worksheet/comment.rb +91 -91
  108. data/lib/axlsx/workbook/worksheet/comments.rb +82 -82
  109. data/lib/axlsx/workbook/worksheet/conditional_formatting.rb +82 -82
  110. data/lib/axlsx/workbook/worksheet/conditional_formatting_rule.rb +220 -220
  111. data/lib/axlsx/workbook/worksheet/conditional_formattings.rb +25 -25
  112. data/lib/axlsx/workbook/worksheet/data_bar.rb +129 -129
  113. data/lib/axlsx/workbook/worksheet/data_validation.rb +267 -246
  114. data/lib/axlsx/workbook/worksheet/data_validations.rb +28 -28
  115. data/lib/axlsx/workbook/worksheet/date_time_converter.rb +30 -30
  116. data/lib/axlsx/workbook/worksheet/dimension.rb +64 -64
  117. data/lib/axlsx/workbook/worksheet/header_footer.rb +52 -52
  118. data/lib/axlsx/workbook/worksheet/icon_set.rb +81 -81
  119. data/lib/axlsx/workbook/worksheet/merged_cells.rb +37 -37
  120. data/lib/axlsx/workbook/worksheet/outline_pr.rb +33 -33
  121. data/lib/axlsx/workbook/worksheet/page_margins.rb +97 -97
  122. data/lib/axlsx/workbook/worksheet/page_set_up_pr.rb +44 -44
  123. data/lib/axlsx/workbook/worksheet/page_setup.rb +240 -240
  124. data/lib/axlsx/workbook/worksheet/pane.rb +139 -139
  125. data/lib/axlsx/workbook/worksheet/pivot_table.rb +335 -296
  126. data/lib/axlsx/workbook/worksheet/pivot_table_cache_definition.rb +66 -66
  127. data/lib/axlsx/workbook/worksheet/pivot_tables.rb +24 -24
  128. data/lib/axlsx/workbook/worksheet/print_options.rb +39 -39
  129. data/lib/axlsx/workbook/worksheet/protected_range.rb +47 -47
  130. data/lib/axlsx/workbook/worksheet/protected_ranges.rb +37 -37
  131. data/lib/axlsx/workbook/worksheet/rich_text.rb +55 -55
  132. data/lib/axlsx/workbook/worksheet/rich_text_run.rb +250 -250
  133. data/lib/axlsx/workbook/worksheet/row.rb +164 -164
  134. data/lib/axlsx/workbook/worksheet/row_breaks.rb +33 -33
  135. data/lib/axlsx/workbook/worksheet/selection.rb +101 -101
  136. data/lib/axlsx/workbook/worksheet/sheet_calc_pr.rb +29 -29
  137. data/lib/axlsx/workbook/worksheet/sheet_data.rb +27 -27
  138. data/lib/axlsx/workbook/worksheet/sheet_pr.rb +87 -87
  139. data/lib/axlsx/workbook/worksheet/sheet_protection.rb +118 -118
  140. data/lib/axlsx/workbook/worksheet/sheet_view.rb +213 -213
  141. data/lib/axlsx/workbook/worksheet/table.rb +102 -102
  142. data/lib/axlsx/workbook/worksheet/table_style_info.rb +49 -49
  143. data/lib/axlsx/workbook/worksheet/tables.rb +34 -34
  144. data/lib/axlsx/workbook/worksheet/worksheet.rb +829 -786
  145. data/lib/axlsx/workbook/worksheet/worksheet_comments.rb +58 -58
  146. data/lib/axlsx/workbook/worksheet/worksheet_drawing.rb +58 -58
  147. data/lib/axlsx/workbook/worksheet/worksheet_hyperlink.rb +74 -74
  148. data/lib/axlsx/workbook/worksheet/worksheet_hyperlinks.rb +38 -38
  149. data/lib/axlsx.rb +204 -185
  150. data/lib/caxlsx.rb +2 -2
  151. data/lib/schema/dc.xsd +118 -118
  152. data/lib/schema/dcmitype.xsd +51 -51
  153. data/lib/schema/dcterms.xsd +331 -331
  154. data/lib/schema/dml-chartDrawing.xsd +146 -146
  155. data/lib/schema/dml-compatibility.xsd +14 -14
  156. data/lib/schema/dml-lockedCanvas.xsd +11 -11
  157. data/lib/schema/dml-main.xsd +3048 -3048
  158. data/lib/schema/dml-picture.xsd +23 -23
  159. data/lib/schema/dml-spreadsheetDrawing.xsd +185 -185
  160. data/lib/schema/dml-wordprocessingDrawing.xsd +185 -185
  161. data/lib/schema/shared-additionalCharacteristics.xsd +28 -28
  162. data/lib/schema/shared-bibliography.xsd +144 -144
  163. data/lib/schema/shared-commonSimpleTypes.xsd +166 -166
  164. data/lib/schema/shared-customXmlDataProperties.xsd +25 -25
  165. data/lib/schema/shared-customXmlSchemaProperties.xsd +18 -18
  166. data/lib/schema/shared-documentPropertiesCustom.xsd +59 -59
  167. data/lib/schema/shared-documentPropertiesExtended.xsd +56 -56
  168. data/lib/schema/shared-documentPropertiesVariantTypes.xsd +195 -195
  169. data/lib/schema/shared-relationshipReference.xsd +25 -25
  170. data/lib/schema/vml-main.xsd +569 -569
  171. data/lib/schema/vml-officeDrawing.xsd +509 -509
  172. data/lib/schema/vml-presentationDrawing.xsd +12 -12
  173. data/lib/schema/vml-spreadsheetDrawing.xsd +108 -108
  174. data/lib/schema/vml-wordprocessingDrawing.xsd +96 -96
  175. data/lib/schema/xml.xsd +116 -116
  176. metadata +5 -252
  177. data/test/benchmark.rb +0 -72
  178. data/test/content_type/tc_content_type.rb +0 -76
  179. data/test/content_type/tc_default.rb +0 -16
  180. data/test/content_type/tc_override.rb +0 -14
  181. data/test/doc_props/tc_app.rb +0 -43
  182. data/test/doc_props/tc_core.rb +0 -42
  183. data/test/drawing/tc_area_chart.rb +0 -39
  184. data/test/drawing/tc_area_series.rb +0 -71
  185. data/test/drawing/tc_axes.rb +0 -8
  186. data/test/drawing/tc_axis.rb +0 -112
  187. data/test/drawing/tc_bar_3D_chart.rb +0 -86
  188. data/test/drawing/tc_bar_chart.rb +0 -86
  189. data/test/drawing/tc_bar_series.rb +0 -46
  190. data/test/drawing/tc_bubble_chart.rb +0 -44
  191. data/test/drawing/tc_bubble_series.rb +0 -21
  192. data/test/drawing/tc_cat_axis.rb +0 -31
  193. data/test/drawing/tc_cat_axis_data.rb +0 -27
  194. data/test/drawing/tc_chart.rb +0 -123
  195. data/test/drawing/tc_d_lbls.rb +0 -57
  196. data/test/drawing/tc_data_source.rb +0 -23
  197. data/test/drawing/tc_drawing.rb +0 -80
  198. data/test/drawing/tc_graphic_frame.rb +0 -27
  199. data/test/drawing/tc_hyperlink.rb +0 -64
  200. data/test/drawing/tc_line_3d_chart.rb +0 -47
  201. data/test/drawing/tc_line_chart.rb +0 -39
  202. data/test/drawing/tc_line_series.rb +0 -71
  203. data/test/drawing/tc_marker.rb +0 -44
  204. data/test/drawing/tc_named_axis_data.rb +0 -27
  205. data/test/drawing/tc_num_data.rb +0 -31
  206. data/test/drawing/tc_num_val.rb +0 -29
  207. data/test/drawing/tc_one_cell_anchor.rb +0 -66
  208. data/test/drawing/tc_pic.rb +0 -103
  209. data/test/drawing/tc_picture_locking.rb +0 -72
  210. data/test/drawing/tc_pie_3D_chart.rb +0 -28
  211. data/test/drawing/tc_pie_series.rb +0 -33
  212. data/test/drawing/tc_scaling.rb +0 -36
  213. data/test/drawing/tc_scatter_chart.rb +0 -48
  214. data/test/drawing/tc_scatter_series.rb +0 -74
  215. data/test/drawing/tc_ser_axis.rb +0 -31
  216. data/test/drawing/tc_series.rb +0 -23
  217. data/test/drawing/tc_series_title.rb +0 -54
  218. data/test/drawing/tc_str_data.rb +0 -18
  219. data/test/drawing/tc_str_val.rb +0 -30
  220. data/test/drawing/tc_title.rb +0 -70
  221. data/test/drawing/tc_two_cell_anchor.rb +0 -36
  222. data/test/drawing/tc_val_axis.rb +0 -24
  223. data/test/drawing/tc_view_3D.rb +0 -54
  224. data/test/drawing/tc_vml_drawing.rb +0 -25
  225. data/test/drawing/tc_vml_shape.rb +0 -106
  226. data/test/fixtures/image1.gif +0 -0
  227. data/test/fixtures/image1.jpeg +0 -0
  228. data/test/fixtures/image1.jpg +0 -0
  229. data/test/fixtures/image1.png +0 -0
  230. data/test/fixtures/image1_fake.jpg +0 -0
  231. data/test/profile.rb +0 -24
  232. data/test/rels/tc_relationship.rb +0 -52
  233. data/test/rels/tc_relationships.rb +0 -37
  234. data/test/stylesheet/tc_border.rb +0 -37
  235. data/test/stylesheet/tc_border_pr.rb +0 -32
  236. data/test/stylesheet/tc_cell_alignment.rb +0 -81
  237. data/test/stylesheet/tc_cell_protection.rb +0 -29
  238. data/test/stylesheet/tc_cell_style.rb +0 -57
  239. data/test/stylesheet/tc_color.rb +0 -43
  240. data/test/stylesheet/tc_dxf.rb +0 -81
  241. data/test/stylesheet/tc_fill.rb +0 -18
  242. data/test/stylesheet/tc_font.rb +0 -133
  243. data/test/stylesheet/tc_gradient_fill.rb +0 -72
  244. data/test/stylesheet/tc_gradient_stop.rb +0 -31
  245. data/test/stylesheet/tc_num_fmt.rb +0 -30
  246. data/test/stylesheet/tc_pattern_fill.rb +0 -43
  247. data/test/stylesheet/tc_styles.rb +0 -309
  248. data/test/stylesheet/tc_table_style.rb +0 -44
  249. data/test/stylesheet/tc_table_style_element.rb +0 -45
  250. data/test/stylesheet/tc_table_styles.rb +0 -29
  251. data/test/stylesheet/tc_xf.rb +0 -120
  252. data/test/tc_axlsx.rb +0 -109
  253. data/test/tc_helper.rb +0 -10
  254. data/test/tc_package.rb +0 -317
  255. data/test/util/tc_mime_type_utils.rb +0 -13
  256. data/test/util/tc_serialized_attributes.rb +0 -19
  257. data/test/util/tc_simple_typed_list.rb +0 -77
  258. data/test/util/tc_validators.rb +0 -210
  259. data/test/workbook/tc_defined_name.rb +0 -49
  260. data/test/workbook/tc_shared_strings_table.rb +0 -59
  261. data/test/workbook/tc_workbook.rb +0 -165
  262. data/test/workbook/tc_workbook_view.rb +0 -50
  263. data/test/workbook/worksheet/auto_filter/tc_auto_filter.rb +0 -38
  264. data/test/workbook/worksheet/auto_filter/tc_filter_column.rb +0 -76
  265. data/test/workbook/worksheet/auto_filter/tc_filters.rb +0 -50
  266. data/test/workbook/worksheet/tc_break.rb +0 -49
  267. data/test/workbook/worksheet/tc_cell.rb +0 -465
  268. data/test/workbook/worksheet/tc_cfvo.rb +0 -31
  269. data/test/workbook/worksheet/tc_col.rb +0 -93
  270. data/test/workbook/worksheet/tc_color_scale.rb +0 -58
  271. data/test/workbook/worksheet/tc_comment.rb +0 -72
  272. data/test/workbook/worksheet/tc_comments.rb +0 -57
  273. data/test/workbook/worksheet/tc_conditional_formatting.rb +0 -224
  274. data/test/workbook/worksheet/tc_data_bar.rb +0 -46
  275. data/test/workbook/worksheet/tc_data_validation.rb +0 -265
  276. data/test/workbook/worksheet/tc_date_time_converter.rb +0 -124
  277. data/test/workbook/worksheet/tc_header_footer.rb +0 -151
  278. data/test/workbook/worksheet/tc_icon_set.rb +0 -45
  279. data/test/workbook/worksheet/tc_outline_pr.rb +0 -19
  280. data/test/workbook/worksheet/tc_page_margins.rb +0 -97
  281. data/test/workbook/worksheet/tc_page_set_up_pr.rb +0 -15
  282. data/test/workbook/worksheet/tc_page_setup.rb +0 -143
  283. data/test/workbook/worksheet/tc_pane.rb +0 -54
  284. data/test/workbook/worksheet/tc_pivot_table.rb +0 -180
  285. data/test/workbook/worksheet/tc_pivot_table_cache_definition.rb +0 -62
  286. data/test/workbook/worksheet/tc_print_options.rb +0 -72
  287. data/test/workbook/worksheet/tc_protected_range.rb +0 -17
  288. data/test/workbook/worksheet/tc_rich_text.rb +0 -44
  289. data/test/workbook/worksheet/tc_rich_text_run.rb +0 -173
  290. data/test/workbook/worksheet/tc_row.rb +0 -160
  291. data/test/workbook/worksheet/tc_selection.rb +0 -55
  292. data/test/workbook/worksheet/tc_sheet_calc_pr.rb +0 -18
  293. data/test/workbook/worksheet/tc_sheet_format_pr.rb +0 -88
  294. data/test/workbook/worksheet/tc_sheet_pr.rb +0 -49
  295. data/test/workbook/worksheet/tc_sheet_protection.rb +0 -117
  296. data/test/workbook/worksheet/tc_sheet_view.rb +0 -214
  297. data/test/workbook/worksheet/tc_table.rb +0 -77
  298. data/test/workbook/worksheet/tc_table_style_info.rb +0 -53
  299. data/test/workbook/worksheet/tc_worksheet.rb +0 -632
  300. data/test/workbook/worksheet/tc_worksheet_hyperlink.rb +0 -55
@@ -1,11 +1,11 @@
1
- module Axlsx
2
- # This module defines some utils related with mime type detection
3
- module MimeTypeUtils
4
- # Detect a file mime type
5
- # @param [String] v File path
6
- # @return [String] File mime type
7
- def self.get_mime_type(v)
8
- Marcel::MimeType.for(Pathname.new(v))
9
- end
10
- end
11
- end
1
+ module Axlsx
2
+ # This module defines some utils related with mime type detection
3
+ module MimeTypeUtils
4
+ # Detect a file mime type
5
+ # @param [String] v File path
6
+ # @return [String] File mime type
7
+ def self.get_mime_type(v)
8
+ Marcel::MimeType.for(Pathname.new(v))
9
+ end
10
+ end
11
+ end
@@ -1,16 +1,16 @@
1
- module Axlsx
2
- # This module defines a single method for parsing options in class
3
- # initializers.
4
- module OptionsParser
5
-
6
- # Parses an options hash by calling any defined method by the same
7
- # name of the key postfixed with an '='
8
- # @param [Hash] options Options to parse.
9
- def parse_options(options={})
10
- options.each do |key, value|
11
- key = :"#{key}="
12
- self.send(key, value) if !value.nil? && self.respond_to?(key)
13
- end
14
- end
15
- end
16
- end
1
+ module Axlsx
2
+ # This module defines a single method for parsing options in class
3
+ # initializers.
4
+ module OptionsParser
5
+
6
+ # Parses an options hash by calling any defined method by the same
7
+ # name of the key postfixed with an '='
8
+ # @param [Hash] options Options to parse.
9
+ def parse_options(options={})
10
+ options.each do |key, value|
11
+ key = :"#{key}="
12
+ self.send(key, value) if !value.nil? && self.respond_to?(key)
13
+ end
14
+ end
15
+ end
16
+ end
@@ -1,89 +1,89 @@
1
- module Axlsx
2
- # This module allows us to define a list of symbols defining which
3
- # attributes will be serialized for a class.
4
- module SerializedAttributes
5
-
6
- # Extend with class methods
7
- def self.included(base)
8
- base.send :extend, ClassMethods
9
- end
10
-
11
- # class methods applied to all includers
12
- module ClassMethods
13
-
14
- # This is the method to be used in inheriting classes to specify
15
- # which of the instance values are serializable
16
- def serializable_attributes(*symbols)
17
- @xml_attributes = symbols
18
- end
19
-
20
- # a reader for those attributes
21
- attr_reader :xml_attributes
22
-
23
- # This helper registers the attributes that will be formatted as elements.
24
- def serializable_element_attributes(*symbols)
25
- @xml_element_attributes = symbols
26
- end
27
-
28
- # attr reader for element attributes
29
- attr_reader :xml_element_attributes
30
- end
31
-
32
- # creates a XML tag with serialized attributes
33
- # @see SerializedAttributes#serialized_attributes
34
- def serialized_tag(tagname, str, additional_attributes = {}, &block)
35
- str << "<#{tagname} "
36
- serialized_attributes(str, additional_attributes)
37
- if block_given?
38
- str << '>'
39
- yield
40
- str << "</#{tagname}>"
41
- else
42
- str << '/>'
43
- end
44
- end
45
-
46
- # serializes the instance values of the defining object based on the
47
- # list of serializable attributes.
48
- # @param [String] str The string instance to append this
49
- # serialization to.
50
- # @param [Hash] additional_attributes An option key value hash for
51
- # defining values that are not serializable attributes list.
52
- def serialized_attributes(str = '', additional_attributes = {})
53
- attributes = declared_attributes.merge! additional_attributes
54
- attributes.each do |key, value|
55
- str << "#{Axlsx.camel(key, false)}=\"#{Axlsx.camel(Axlsx.booleanize(value), false)}\" "
56
- end
57
- str
58
- end
59
-
60
- # A hash of instance variables that have been declared with
61
- # seraialized_attributes and are not nil.
62
- # This requires ruby 1.9.3 or higher
63
- def declared_attributes
64
- instance_values.select do |key, value|
65
- value != nil && self.class.xml_attributes.include?(key.to_sym)
66
- end
67
- end
68
-
69
- # serialized instance values at text nodes on a camelized element of the
70
- # attribute name. You may pass in a block for evaluation against non nil
71
- # values. We use an array for element attributes becuase misordering will
72
- # break the xml and 1.8.7 does not support ordered hashes.
73
- # @param [String] str The string instance to which serialized data is appended
74
- # @param [Array] additional_attributes An array of additional attribute names.
75
- # @return [String] The serialized output.
76
- def serialized_element_attributes(str='', additional_attributes=[], &block)
77
- attrs = self.class.xml_element_attributes + additional_attributes
78
- values = instance_values
79
- attrs.each do |attribute_name|
80
- value = values[attribute_name.to_s]
81
- next if value.nil?
82
- value = yield value if block_given?
83
- element_name = Axlsx.camel(attribute_name, false)
84
- str << "<#{element_name}>#{value}</#{element_name}>"
85
- end
86
- str
87
- end
88
- end
89
- end
1
+ module Axlsx
2
+ # This module allows us to define a list of symbols defining which
3
+ # attributes will be serialized for a class.
4
+ module SerializedAttributes
5
+
6
+ # Extend with class methods
7
+ def self.included(base)
8
+ base.send :extend, ClassMethods
9
+ end
10
+
11
+ # class methods applied to all includers
12
+ module ClassMethods
13
+
14
+ # This is the method to be used in inheriting classes to specify
15
+ # which of the instance values are serializable
16
+ def serializable_attributes(*symbols)
17
+ @xml_attributes = symbols
18
+ end
19
+
20
+ # a reader for those attributes
21
+ attr_reader :xml_attributes
22
+
23
+ # This helper registers the attributes that will be formatted as elements.
24
+ def serializable_element_attributes(*symbols)
25
+ @xml_element_attributes = symbols
26
+ end
27
+
28
+ # attr reader for element attributes
29
+ attr_reader :xml_element_attributes
30
+ end
31
+
32
+ # creates a XML tag with serialized attributes
33
+ # @see SerializedAttributes#serialized_attributes
34
+ def serialized_tag(tagname, str, additional_attributes = {}, &block)
35
+ str << "<#{tagname} "
36
+ serialized_attributes(str, additional_attributes)
37
+ if block_given?
38
+ str << '>'
39
+ yield
40
+ str << "</#{tagname}>"
41
+ else
42
+ str << '/>'
43
+ end
44
+ end
45
+
46
+ # serializes the instance values of the defining object based on the
47
+ # list of serializable attributes.
48
+ # @param [String] str The string instance to append this
49
+ # serialization to.
50
+ # @param [Hash] additional_attributes An option key value hash for
51
+ # defining values that are not serializable attributes list.
52
+ def serialized_attributes(str = '', additional_attributes = {})
53
+ attributes = declared_attributes.merge! additional_attributes
54
+ attributes.each do |key, value|
55
+ str << "#{Axlsx.camel(key, false)}=\"#{Axlsx.camel(Axlsx.booleanize(value), false)}\" "
56
+ end
57
+ str
58
+ end
59
+
60
+ # A hash of instance variables that have been declared with
61
+ # seraialized_attributes and are not nil.
62
+ # This requires ruby 1.9.3 or higher
63
+ def declared_attributes
64
+ Axlsx.instance_values_for(self).select do |key, value|
65
+ value != nil && self.class.xml_attributes.include?(key.to_sym)
66
+ end
67
+ end
68
+
69
+ # serialized instance values at text nodes on a camelized element of the
70
+ # attribute name. You may pass in a block for evaluation against non nil
71
+ # values. We use an array for element attributes becuase misordering will
72
+ # break the xml and 1.8.7 does not support ordered hashes.
73
+ # @param [String] str The string instance to which serialized data is appended
74
+ # @param [Array] additional_attributes An array of additional attribute names.
75
+ # @return [String] The serialized output.
76
+ def serialized_element_attributes(str='', additional_attributes=[], &block)
77
+ attrs = self.class.xml_element_attributes + additional_attributes
78
+ values = Axlsx.instance_values_for(self)
79
+ attrs.each do |attribute_name|
80
+ value = values[attribute_name.to_s]
81
+ next if value.nil?
82
+ value = yield value if block_given?
83
+ element_name = Axlsx.camel(attribute_name, false)
84
+ str << "<#{element_name}>#{value}</#{element_name}>"
85
+ end
86
+ str
87
+ end
88
+ end
89
+ end
@@ -1,179 +1,179 @@
1
- # encoding: UTF-8
2
- module Axlsx
3
-
4
- # A SimpleTypedList is a type restrictive collection that allows some of the methods from Array and supports basic xml serialization.
5
- # @private
6
- class SimpleTypedList
7
- # Creats a new typed list
8
- # @param [Array, Class] type An array of Class objects or a single Class object
9
- # @param [String] serialize_as The tag name to use in serialization
10
- # @raise [ArgumentError] if all members of type are not Class objects
11
- def initialize type, serialize_as=nil, start_size = 0
12
- if type.is_a? Array
13
- type.each { |item| raise ArgumentError, "All members of type must be Class objects" unless item.is_a? Class }
14
- @allowed_types = type
15
- else
16
- raise ArgumentError, "Type must be a Class object or array of Class objects" unless type.is_a? Class
17
- @allowed_types = [type]
18
- end
19
- @serialize_as = serialize_as unless serialize_as.nil?
20
- @list = Array.new(start_size)
21
- end
22
-
23
- # The class constants of allowed types
24
- # @return [Array]
25
- attr_reader :allowed_types
26
-
27
- # The index below which items cannot be removed
28
- # @return [Integer]
29
- def locked_at
30
- defined?(@locked_at) ? @locked_at : nil
31
- end
32
-
33
- # The tag name to use when serializing this object
34
- # by default the parent node for all items in the list is the classname of the first allowed type with the first letter in lowercase.
35
- # @return [String]
36
- attr_reader :serialize_as
37
-
38
- # Transposes the list (without blowing up like ruby does)
39
- # any non populated cell in the matrix will be a nil value
40
- def transpose
41
- return @list.clone if @list.size == 0
42
- row_count = @list.size
43
- max_column_count = @list.map{|row| row.cells.size}.max
44
- result = Array.new(max_column_count) { Array.new(row_count) }
45
- # yes, I know it is silly, but that warning is really annoying
46
- row_count.times do |row_index|
47
- max_column_count.times do |column_index|
48
- datum = if @list[row_index].cells.size >= max_column_count
49
- @list[row_index].cells[column_index]
50
- elsif block_given?
51
- yield(column_index, row_index)
52
- end
53
- result[column_index][row_index] = datum
54
- end
55
- end
56
- result
57
- end
58
-
59
- # Lock this list at the current size
60
- # @return [self]
61
- def lock
62
- @locked_at = @list.size
63
- self
64
- end
65
-
66
- # Unlock the list
67
- # @return [self]
68
- def unlock
69
- @locked_at = nil
70
- self
71
- end
72
-
73
- def to_ary
74
- @list
75
- end
76
-
77
- alias :to_a :to_ary
78
-
79
- # join operator
80
- # @param [Array] v the array to join
81
- # @raise [ArgumentError] if any of the values being joined are not
82
- # one of the allowed types
83
- # @return [SimpleTypedList]
84
- def +(v)
85
- v.each do |item|
86
- DataTypeValidator.validate :SimpleTypedList_plus, @allowed_types, item
87
- @list << item
88
- end
89
- end
90
-
91
- # Concat operator
92
- # @param [Any] v the data to be added
93
- # @raise [ArgumentError] if the value being added is not one fo the allowed types
94
- # @return [Integer] returns the index of the item added.
95
- def <<(v)
96
- DataTypeValidator.validate :SimpleTypedList_push, @allowed_types, v
97
- @list << v
98
- @list.size - 1
99
- end
100
-
101
- alias :push :<<
102
-
103
-
104
- # delete the item from the list
105
- # @param [Any] v The item to be deleted.
106
- # @raise [ArgumentError] if the item's index is protected by locking
107
- # @return [Any] The item deleted
108
- def delete(v)
109
- return unless include? v
110
- raise ArgumentError, "Item is protected and cannot be deleted" if protected? index(v)
111
- @list.delete v
112
- end
113
-
114
- # delete the item from the list at the index position provided
115
- # @raise [ArgumentError] if the index is protected by locking
116
- # @return [Any] The item deleted
117
- def delete_at(index)
118
- @list[index]
119
- raise ArgumentError, "Item is protected and cannot be deleted" if protected? index
120
- @list.delete_at index
121
- end
122
-
123
- # positional assignment. Adds the item at the index specified
124
- # @param [Integer] index
125
- # @param [Any] v
126
- # @raise [ArgumentError] if the index is protected by locking
127
- # @raise [ArgumentError] if the item is not one of the allowed types
128
- def []=(index, v)
129
- DataTypeValidator.validate :SimpleTypedList_insert, @allowed_types, v
130
- raise ArgumentError, "Item is protected and cannot be changed" if protected? index
131
- @list[index] = v
132
- v
133
- end
134
-
135
- # inserts an item at the index specfied
136
- # @param [Integer] index
137
- # @param [Any] v
138
- # @raise [ArgumentError] if the index is protected by locking
139
- # @raise [ArgumentError] if the index is not one of the allowed types
140
- def insert(index, v)
141
- DataTypeValidator.validate :SimpleTypedList_insert, @allowed_types, v
142
- raise ArgumentError, "Item is protected and cannot be changed" if protected? index
143
- @list.insert(index, v)
144
- v
145
- end
146
-
147
- # determines if the index is protected
148
- # @param [Integer] index
149
- def protected? index
150
- return false unless locked_at.is_a? Integer
151
- index < locked_at
152
- end
153
-
154
- DESTRUCTIVE = ['replace', 'insert', 'collect!', 'map!', 'pop', 'delete_if',
155
- 'reverse!', 'shift', 'shuffle!', 'slice!', 'sort!', 'uniq!',
156
- 'unshift', 'zip', 'flatten!', 'fill', 'drop', 'drop_while',
157
- 'delete_if', 'clear']
158
- DELEGATES = Array.instance_methods - self.instance_methods - DESTRUCTIVE
159
-
160
- DELEGATES.each do |method|
161
- class_eval %{
162
- def #{method}(*args, &block)
163
- @list.send(:#{method}, *args, &block)
164
- end
165
- }
166
- end
167
-
168
- def to_xml_string(str = '')
169
- classname = @allowed_types[0].name.split('::').last
170
- el_name = serialize_as.to_s || (classname[0,1].downcase + classname[1..-1])
171
- str << ('<' << el_name << ' count="' << size.to_s << '">')
172
- each { |item| item.to_xml_string(str) }
173
- str << ('</' << el_name << '>')
174
- end
175
-
176
- end
177
-
178
-
179
- end
1
+ # encoding: UTF-8
2
+ module Axlsx
3
+
4
+ # A SimpleTypedList is a type restrictive collection that allows some of the methods from Array and supports basic xml serialization.
5
+ # @private
6
+ class SimpleTypedList
7
+ # Creats a new typed list
8
+ # @param [Array, Class] type An array of Class objects or a single Class object
9
+ # @param [String] serialize_as The tag name to use in serialization
10
+ # @raise [ArgumentError] if all members of type are not Class objects
11
+ def initialize type, serialize_as=nil, start_size = 0
12
+ if type.is_a? Array
13
+ type.each { |item| raise ArgumentError, "All members of type must be Class objects" unless item.is_a? Class }
14
+ @allowed_types = type
15
+ else
16
+ raise ArgumentError, "Type must be a Class object or array of Class objects" unless type.is_a? Class
17
+ @allowed_types = [type]
18
+ end
19
+ @serialize_as = serialize_as unless serialize_as.nil?
20
+ @list = Array.new(start_size)
21
+ end
22
+
23
+ # The class constants of allowed types
24
+ # @return [Array]
25
+ attr_reader :allowed_types
26
+
27
+ # The index below which items cannot be removed
28
+ # @return [Integer]
29
+ def locked_at
30
+ defined?(@locked_at) ? @locked_at : nil
31
+ end
32
+
33
+ # The tag name to use when serializing this object
34
+ # by default the parent node for all items in the list is the classname of the first allowed type with the first letter in lowercase.
35
+ # @return [String]
36
+ attr_reader :serialize_as
37
+
38
+ # Transposes the list (without blowing up like ruby does)
39
+ # any non populated cell in the matrix will be a nil value
40
+ def transpose
41
+ return @list.clone if @list.size == 0
42
+ row_count = @list.size
43
+ max_column_count = @list.map{|row| row.cells.size}.max
44
+ result = Array.new(max_column_count) { Array.new(row_count) }
45
+ # yes, I know it is silly, but that warning is really annoying
46
+ row_count.times do |row_index|
47
+ max_column_count.times do |column_index|
48
+ datum = if @list[row_index].cells.size >= max_column_count
49
+ @list[row_index].cells[column_index]
50
+ elsif block_given?
51
+ yield(column_index, row_index)
52
+ end
53
+ result[column_index][row_index] = datum
54
+ end
55
+ end
56
+ result
57
+ end
58
+
59
+ # Lock this list at the current size
60
+ # @return [self]
61
+ def lock
62
+ @locked_at = @list.size
63
+ self
64
+ end
65
+
66
+ # Unlock the list
67
+ # @return [self]
68
+ def unlock
69
+ @locked_at = nil
70
+ self
71
+ end
72
+
73
+ def to_ary
74
+ @list
75
+ end
76
+
77
+ alias :to_a :to_ary
78
+
79
+ # join operator
80
+ # @param [Array] v the array to join
81
+ # @raise [ArgumentError] if any of the values being joined are not
82
+ # one of the allowed types
83
+ # @return [SimpleTypedList]
84
+ def +(v)
85
+ v.each do |item|
86
+ DataTypeValidator.validate :SimpleTypedList_plus, @allowed_types, item
87
+ @list << item
88
+ end
89
+ end
90
+
91
+ # Concat operator
92
+ # @param [Any] v the data to be added
93
+ # @raise [ArgumentError] if the value being added is not one fo the allowed types
94
+ # @return [Integer] returns the index of the item added.
95
+ def <<(v)
96
+ DataTypeValidator.validate :SimpleTypedList_push, @allowed_types, v
97
+ @list << v
98
+ @list.size - 1
99
+ end
100
+
101
+ alias :push :<<
102
+
103
+
104
+ # delete the item from the list
105
+ # @param [Any] v The item to be deleted.
106
+ # @raise [ArgumentError] if the item's index is protected by locking
107
+ # @return [Any] The item deleted
108
+ def delete(v)
109
+ return unless include? v
110
+ raise ArgumentError, "Item is protected and cannot be deleted" if protected? index(v)
111
+ @list.delete v
112
+ end
113
+
114
+ # delete the item from the list at the index position provided
115
+ # @raise [ArgumentError] if the index is protected by locking
116
+ # @return [Any] The item deleted
117
+ def delete_at(index)
118
+ @list[index]
119
+ raise ArgumentError, "Item is protected and cannot be deleted" if protected? index
120
+ @list.delete_at index
121
+ end
122
+
123
+ # positional assignment. Adds the item at the index specified
124
+ # @param [Integer] index
125
+ # @param [Any] v
126
+ # @raise [ArgumentError] if the index is protected by locking
127
+ # @raise [ArgumentError] if the item is not one of the allowed types
128
+ def []=(index, v)
129
+ DataTypeValidator.validate :SimpleTypedList_insert, @allowed_types, v
130
+ raise ArgumentError, "Item is protected and cannot be changed" if protected? index
131
+ @list[index] = v
132
+ v
133
+ end
134
+
135
+ # inserts an item at the index specfied
136
+ # @param [Integer] index
137
+ # @param [Any] v
138
+ # @raise [ArgumentError] if the index is protected by locking
139
+ # @raise [ArgumentError] if the index is not one of the allowed types
140
+ def insert(index, v)
141
+ DataTypeValidator.validate :SimpleTypedList_insert, @allowed_types, v
142
+ raise ArgumentError, "Item is protected and cannot be changed" if protected? index
143
+ @list.insert(index, v)
144
+ v
145
+ end
146
+
147
+ # determines if the index is protected
148
+ # @param [Integer] index
149
+ def protected? index
150
+ return false unless locked_at.is_a? Integer
151
+ index < locked_at
152
+ end
153
+
154
+ DESTRUCTIVE = ['replace', 'insert', 'collect!', 'map!', 'pop', 'delete_if',
155
+ 'reverse!', 'shift', 'shuffle!', 'slice!', 'sort!', 'uniq!',
156
+ 'unshift', 'zip', 'flatten!', 'fill', 'drop', 'drop_while',
157
+ 'delete_if', 'clear']
158
+ DELEGATES = Array.instance_methods - self.instance_methods - DESTRUCTIVE
159
+
160
+ DELEGATES.each do |method|
161
+ class_eval %{
162
+ def #{method}(*args, &block)
163
+ @list.send(:#{method}, *args, &block)
164
+ end
165
+ }
166
+ end
167
+
168
+ def to_xml_string(str = '')
169
+ classname = @allowed_types[0].name.split('::').last
170
+ el_name = serialize_as.to_s || (classname[0,1].downcase + classname[1..-1])
171
+ str << ('<' << el_name << ' count="' << size.to_s << '">')
172
+ each { |item| item.to_xml_string(str) }
173
+ str << ('</' << el_name << '>')
174
+ end
175
+
176
+ end
177
+
178
+
179
+ end