prawn 1.0.0.rc1 → 1.0.0.rc2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (203) hide show
  1. data/Gemfile +18 -0
  2. data/README.md +5 -3
  3. data/Rakefile +8 -14
  4. data/data/pdfs/nested_pages.pdf +13 -13
  5. data/lib/prawn.rb +3 -1
  6. data/lib/prawn/compatibility.rb +46 -10
  7. data/lib/prawn/core.rb +3 -1
  8. data/lib/prawn/core/document_state.rb +2 -1
  9. data/lib/prawn/core/object_store.rb +61 -5
  10. data/lib/prawn/core/page.rb +3 -6
  11. data/lib/prawn/core/pdf_object.rb +21 -4
  12. data/lib/prawn/core/reference.rb +6 -2
  13. data/lib/prawn/core/text.rb +4 -4
  14. data/lib/prawn/core/text/formatted/line_wrap.rb +23 -8
  15. data/lib/prawn/document.rb +21 -15
  16. data/lib/prawn/document/bounding_box.rb +3 -3
  17. data/lib/prawn/document/column_box.rb +22 -4
  18. data/lib/prawn/document/snapshot.rb +1 -1
  19. data/lib/prawn/encoding.rb +1 -1
  20. data/lib/prawn/errors.rb +4 -0
  21. data/lib/prawn/font.rb +1 -1
  22. data/lib/prawn/font/afm.rb +30 -72
  23. data/lib/prawn/font/ttf.rb +6 -33
  24. data/lib/prawn/graphics.rb +148 -23
  25. data/lib/prawn/graphics/color.rb +8 -1
  26. data/lib/prawn/graphics/patterns.rb +137 -0
  27. data/lib/prawn/images.rb +25 -19
  28. data/lib/prawn/images/jpg.rb +4 -4
  29. data/lib/prawn/images/png.rb +18 -12
  30. data/lib/prawn/security.rb +6 -4
  31. data/lib/prawn/soft_mask.rb +94 -0
  32. data/lib/prawn/table.rb +136 -31
  33. data/lib/prawn/table/cell.rb +260 -29
  34. data/lib/prawn/table/cell/span_dummy.rb +88 -0
  35. data/lib/prawn/table/cell/text.rb +36 -14
  36. data/lib/prawn/table/cells.rb +91 -41
  37. data/lib/prawn/text.rb +3 -2
  38. data/lib/prawn/text/formatted/box.rb +14 -5
  39. data/lib/prawn/text/formatted/fragment.rb +33 -22
  40. data/lib/prawn/text/formatted/parser.rb +5 -2
  41. data/lib/prawn/utilities.rb +44 -0
  42. data/manual/basic_concepts/adding_pages.rb +27 -0
  43. data/manual/basic_concepts/basic_concepts.rb +34 -0
  44. data/manual/basic_concepts/creation.rb +39 -0
  45. data/manual/basic_concepts/cursor.rb +33 -0
  46. data/manual/basic_concepts/measurement.rb +25 -0
  47. data/manual/basic_concepts/origin.rb +38 -0
  48. data/manual/basic_concepts/other_cursor_helpers.rb +40 -0
  49. data/manual/bounding_box/bounding_box.rb +39 -0
  50. data/manual/bounding_box/bounds.rb +49 -0
  51. data/manual/bounding_box/canvas.rb +24 -0
  52. data/manual/bounding_box/creation.rb +23 -0
  53. data/manual/bounding_box/indentation.rb +46 -0
  54. data/manual/bounding_box/nesting.rb +45 -0
  55. data/manual/bounding_box/russian_boxes.rb +40 -0
  56. data/manual/bounding_box/stretchy.rb +31 -0
  57. data/manual/document_and_page_options/background.rb +27 -0
  58. data/manual/document_and_page_options/document_and_page_options.rb +31 -0
  59. data/manual/document_and_page_options/metadata.rb +23 -0
  60. data/manual/document_and_page_options/page_margins.rb +38 -0
  61. data/manual/document_and_page_options/page_size.rb +34 -0
  62. data/manual/example_file.rb +116 -0
  63. data/manual/example_helper.rb +430 -0
  64. data/manual/example_package.rb +53 -0
  65. data/manual/example_section.rb +46 -0
  66. data/manual/graphics/circle_and_ellipse.rb +22 -0
  67. data/manual/graphics/color.rb +24 -0
  68. data/manual/graphics/common_lines.rb +28 -0
  69. data/manual/graphics/fill_and_stroke.rb +42 -0
  70. data/manual/graphics/fill_rules.rb +37 -0
  71. data/manual/graphics/gradients.rb +37 -0
  72. data/manual/graphics/graphics.rb +58 -0
  73. data/manual/graphics/helper.rb +17 -0
  74. data/manual/graphics/line_width.rb +35 -0
  75. data/manual/graphics/lines_and_curves.rb +41 -0
  76. data/manual/graphics/polygon.rb +29 -0
  77. data/manual/graphics/rectangle.rb +21 -0
  78. data/manual/graphics/rotate.rb +28 -0
  79. data/manual/graphics/scale.rb +41 -0
  80. data/manual/graphics/soft_masks.rb +46 -0
  81. data/manual/graphics/stroke_cap.rb +31 -0
  82. data/manual/graphics/stroke_dash.rb +43 -0
  83. data/manual/graphics/stroke_join.rb +30 -0
  84. data/manual/graphics/translate.rb +29 -0
  85. data/manual/graphics/transparency.rb +35 -0
  86. data/manual/images/absolute_position.rb +23 -0
  87. data/manual/images/fit.rb +21 -0
  88. data/manual/images/horizontal.rb +25 -0
  89. data/manual/images/images.rb +40 -0
  90. data/manual/images/plain_image.rb +18 -0
  91. data/manual/images/scale.rb +22 -0
  92. data/manual/images/vertical.rb +28 -0
  93. data/manual/images/width_and_height.rb +25 -0
  94. data/manual/layout/boxes.rb +27 -0
  95. data/manual/layout/content.rb +25 -0
  96. data/manual/layout/layout.rb +28 -0
  97. data/manual/layout/simple_grid.rb +23 -0
  98. data/manual/manual/cover.rb +26 -0
  99. data/manual/manual/foreword.rb +13 -0
  100. data/manual/manual/how_to_read_this_manual.rb +41 -0
  101. data/manual/manual/manual.rb +36 -0
  102. data/manual/outline/add_subsection_to.rb +61 -0
  103. data/manual/outline/insert_section_after.rb +47 -0
  104. data/manual/outline/outline.rb +32 -0
  105. data/manual/outline/sections_and_pages.rb +67 -0
  106. data/manual/repeatable_content/page_numbering.rb +54 -0
  107. data/manual/repeatable_content/repeatable_content.rb +31 -0
  108. data/manual/repeatable_content/repeater.rb +55 -0
  109. data/manual/repeatable_content/stamp.rb +41 -0
  110. data/manual/security/encryption.rb +31 -0
  111. data/manual/security/permissions.rb +38 -0
  112. data/manual/security/security.rb +28 -0
  113. data/manual/syntax_highlight.rb +52 -0
  114. data/manual/table/basic_block.rb +53 -0
  115. data/manual/table/before_rendering_page.rb +26 -0
  116. data/manual/table/cell_border_lines.rb +24 -0
  117. data/manual/table/cell_borders_and_bg.rb +31 -0
  118. data/manual/table/cell_dimensions.rb +30 -0
  119. data/manual/table/cell_text.rb +38 -0
  120. data/manual/table/column_widths.rb +30 -0
  121. data/manual/table/content_and_subtables.rb +39 -0
  122. data/manual/table/creation.rb +27 -0
  123. data/manual/table/filtering.rb +36 -0
  124. data/manual/table/flow_and_header.rb +17 -0
  125. data/manual/table/image_cells.rb +33 -0
  126. data/manual/table/position.rb +29 -0
  127. data/manual/table/row_colors.rb +20 -0
  128. data/manual/table/span.rb +30 -0
  129. data/manual/table/style.rb +22 -0
  130. data/manual/table/table.rb +52 -0
  131. data/manual/table/width.rb +27 -0
  132. data/manual/templates/full_template.rb +23 -0
  133. data/manual/templates/page_template.rb +47 -0
  134. data/manual/templates/templates.rb +26 -0
  135. data/manual/text/alignment.rb +44 -0
  136. data/manual/text/color.rb +24 -0
  137. data/manual/text/column_box.rb +32 -0
  138. data/manual/text/fallback_fonts.rb +37 -0
  139. data/manual/text/font.rb +41 -0
  140. data/manual/text/font_size.rb +45 -0
  141. data/manual/text/font_style.rb +23 -0
  142. data/manual/text/formatted_callbacks.rb +60 -0
  143. data/manual/text/formatted_text.rb +50 -0
  144. data/manual/text/free_flowing_text.rb +51 -0
  145. data/manual/text/group.rb +29 -0
  146. data/manual/text/inline.rb +43 -0
  147. data/manual/text/kerning_and_character_spacing.rb +39 -0
  148. data/manual/text/leading.rb +25 -0
  149. data/manual/text/line_wrapping.rb +41 -0
  150. data/manual/text/paragraph_indentation.rb +26 -0
  151. data/manual/text/positioned_text.rb +38 -0
  152. data/manual/text/registering_families.rb +48 -0
  153. data/manual/text/rendering_and_color.rb +37 -0
  154. data/manual/text/right_to_left_text.rb +43 -0
  155. data/manual/text/rotation.rb +43 -0
  156. data/manual/text/single_usage.rb +37 -0
  157. data/manual/text/text.rb +75 -0
  158. data/manual/text/text_box_excess.rb +32 -0
  159. data/manual/text/text_box_extensions.rb +45 -0
  160. data/manual/text/text_box_overflow.rb +44 -0
  161. data/manual/text/utf8.rb +28 -0
  162. data/manual/text/win_ansi_charset.rb +59 -0
  163. data/prawn.gemspec +10 -7
  164. data/spec/bounding_box_spec.rb +107 -17
  165. data/spec/cell_spec.rb +66 -40
  166. data/spec/column_box_spec.rb +33 -0
  167. data/spec/document_spec.rb +45 -24
  168. data/spec/extensions/encoding_helpers.rb +6 -0
  169. data/spec/extensions/mocha.rb +1 -0
  170. data/spec/font_spec.rb +71 -53
  171. data/spec/formatted_text_arranger_spec.rb +19 -19
  172. data/spec/formatted_text_box_spec.rb +16 -16
  173. data/spec/formatted_text_fragment_spec.rb +6 -6
  174. data/spec/graphics_spec.rb +96 -31
  175. data/spec/grid_spec.rb +2 -2
  176. data/spec/images_spec.rb +18 -10
  177. data/spec/jpg_spec.rb +1 -1
  178. data/spec/line_wrap_spec.rb +14 -14
  179. data/spec/measurement_units_spec.rb +2 -2
  180. data/spec/name_tree_spec.rb +6 -6
  181. data/spec/object_store_spec.rb +17 -17
  182. data/spec/outline_spec.rb +35 -17
  183. data/spec/pdf_object_spec.rb +3 -1
  184. data/spec/png_spec.rb +22 -19
  185. data/spec/reference_spec.rb +24 -1
  186. data/spec/repeater_spec.rb +9 -9
  187. data/spec/security_spec.rb +3 -3
  188. data/spec/snapshot_spec.rb +3 -3
  189. data/spec/soft_mask_spec.rb +117 -0
  190. data/spec/span_spec.rb +4 -4
  191. data/spec/spec_helper.rb +12 -6
  192. data/spec/stamp_spec.rb +12 -12
  193. data/spec/stroke_styles_spec.rb +5 -5
  194. data/spec/table_spec.rb +458 -88
  195. data/spec/template_spec.rb +108 -54
  196. data/spec/text_at_spec.rb +17 -17
  197. data/spec/text_box_spec.rb +76 -45
  198. data/spec/text_rendering_mode_spec.rb +5 -5
  199. data/spec/text_spacing_spec.rb +4 -4
  200. data/spec/text_spec.rb +44 -40
  201. metadata +419 -250
  202. data/lib/prawn/graphics/gradient.rb +0 -84
  203. data/lib/prawn/security/arcfour.rb +0 -51
@@ -0,0 +1,49 @@
1
+ # encoding: utf-8
2
+ #
3
+ # The <code>bounds</code> method returns the current bounding box. This is
4
+ # useful because the <code>Prawn::BoundinBox</code> exposes some nice boundary
5
+ # helpers.
6
+ #
7
+ # <code>top</code>, <code>bottom</code>, <code>left</code> and
8
+ # <code>right</code> methods return the bounding box boundaries relative to its
9
+ # translated origin. <code>top_left</code>, <code>top_right</code>,
10
+ # <code>bottom_left</code> and <code>bottom_right</code> return those boundaries
11
+ # pairs inside arrays.
12
+ #
13
+ # All these methods have an "absolute" version like <code>absolute_right</code>.
14
+ # The absolute version returns the same boundary relative to the page absolute
15
+ # coordinates.
16
+ #
17
+ # The following snippet shows the boundaries for the margin box side by side
18
+ # with the boundaries for a custom bounding box.
19
+ #
20
+ require File.expand_path(File.join(File.dirname(__FILE__),
21
+ %w[.. example_helper]))
22
+
23
+ filename = File.basename(__FILE__).gsub('.rb', '.pdf')
24
+ Prawn::Example.generate(filename) do
25
+ def print_coordinates
26
+ text "top: #{bounds.top}"
27
+ text "bottom: #{bounds.bottom}"
28
+ text "left: #{bounds.left}"
29
+ text "right: #{bounds.right}"
30
+
31
+ move_down 10
32
+
33
+ text "absolute top: #{sprintf "%.2f", bounds.absolute_top}"
34
+ text "absolute bottom: #{sprintf "%.2f", bounds.absolute_bottom}"
35
+ text "absolute left: #{sprintf "%.2f", bounds.absolute_left}"
36
+ text "absolute right: #{sprintf "%.2f", bounds.absolute_right}"
37
+ end
38
+
39
+ text "Margin box bounds:"
40
+ move_down 5
41
+ print_coordinates
42
+
43
+ bounding_box([250, cursor + 140], :width => 200, :height => 150) do
44
+ text "This bounding box bounds:"
45
+ move_down 5
46
+ print_coordinates
47
+ transparent(0.5) { stroke_bounds }
48
+ end
49
+ end
@@ -0,0 +1,24 @@
1
+ # encoding: utf-8
2
+ #
3
+ # The origin example already mentions that a new document already comes with
4
+ # a margin box whose bottom left corner is used as the origin for calculating
5
+ # coordinates.
6
+ #
7
+ # What has not been told is that there is one helper for "bypassing" the margin
8
+ # box: <code>canvas</code>. This method is a shortcut for creating a bounding
9
+ # box mapped to the absolute coordinates and evaluating the code inside it.
10
+ #
11
+ # The following snippet draws a circle on each of the four absolute corners.
12
+ #
13
+ require File.expand_path(File.join(File.dirname(__FILE__),
14
+ %w[.. example_helper]))
15
+
16
+ filename = File.basename(__FILE__).gsub('.rb', '.pdf')
17
+ Prawn::Example.generate(filename) do
18
+ canvas do
19
+ fill_circle [bounds.left, bounds.top], 30
20
+ fill_circle [bounds.right, bounds.top], 30
21
+ fill_circle [bounds.right, bounds.bottom], 30
22
+ fill_circle [0, 0], 30
23
+ end
24
+ end
@@ -0,0 +1,23 @@
1
+ # encoding: utf-8
2
+ #
3
+ # If you've read the basic concepts examples you probably know that the origin
4
+ # of a page is on the bottom left corner and that the content flows from top to
5
+ # bottom.
6
+ #
7
+ # You also know that a Bounding Box is a structure for helping the content flow.
8
+ #
9
+ # A bounding box can be created with the <code>bounding_box</code> method. Just
10
+ # provide the top left corner, a required <code>:width</code> option and an
11
+ # optional <code>:height</code>.
12
+ #
13
+ require File.expand_path(File.join(File.dirname(__FILE__),
14
+ %w[.. example_helper]))
15
+
16
+ filename = File.basename(__FILE__).gsub('.rb', '.pdf')
17
+ Prawn::Example.generate(filename) do
18
+ bounding_box([200, cursor - 100], :width => 200, :height => 100) do
19
+ text "Just your regular bounding box"
20
+
21
+ transparent(0.5) { stroke_bounds }
22
+ end
23
+ end
@@ -0,0 +1,46 @@
1
+ # encoding: utf-8
2
+ #
3
+ # Sometimes you just need to indent a portion of the contents of a bounding box,
4
+ # and using a nested bounding box is pure overkill. The <code>indent</code>
5
+ # method is what you might need.
6
+ #
7
+ # Just provide a number for it to indent all content generated inside the
8
+ # block.
9
+ #
10
+ require File.expand_path(File.join(File.dirname(__FILE__),
11
+ %w[.. example_helper]))
12
+
13
+ filename = File.basename(__FILE__).gsub('.rb', '.pdf')
14
+ Prawn::Example.generate(filename) do
15
+ text "No indentation on the margin box."
16
+ indent(20) do
17
+ text "Some indentation inside an indent block."
18
+ end
19
+ move_down 20
20
+
21
+ bounding_box([50, cursor], :width => 400, :height => cursor) do
22
+ transparent(0.5) { stroke_bounds }
23
+
24
+ move_down 10
25
+ text "No indentation inside this bounding box."
26
+ indent(40) do
27
+ text "Inside an indent block. And so is this horizontal line:"
28
+
29
+ stroke_horizontal_rule
30
+ end
31
+ move_down 10
32
+ text "No indentation"
33
+
34
+ move_down 20
35
+ indent(60) do
36
+ text "Another indent block."
37
+
38
+ bounding_box([0, cursor], :width => 200) do
39
+ text "Note that this bounding box coordinates are relative to the " +
40
+ "indent block"
41
+
42
+ transparent(0.5) { stroke_bounds }
43
+ end
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,45 @@
1
+ # encoding: utf-8
2
+ #
3
+ # Normally when we provide the top left corner of a bounding box we
4
+ # express the coordinates relative to the margin box. This is not the
5
+ # case when we have nested bounding boxes. Once nested the inner bounding box
6
+ # coordinates are relative to the outter bounding box.
7
+ #
8
+ # This example shows some nested bounding boxes with fixed and stretchy heights.
9
+ # Note how the <code>cursor</code> method returns coordinates relative to
10
+ # the current bounding box.
11
+ #
12
+ require File.expand_path(File.join(File.dirname(__FILE__),
13
+ %w[.. example_helper]))
14
+
15
+ filename = File.basename(__FILE__).gsub('.rb', '.pdf')
16
+ Prawn::Example.generate(filename) do
17
+ def box_content(string)
18
+ text string
19
+ transparent(0.5) { stroke_bounds }
20
+ end
21
+
22
+ gap = 20
23
+ bounding_box([50, cursor], :width => 400, :height => 200) do
24
+ box_content("Fixed height")
25
+
26
+ bounding_box([gap, cursor - gap], :width => 300) do
27
+ text "Stretchy height"
28
+
29
+ bounding_box([gap, bounds.top - gap], :width => 100) do
30
+ text "Stretchy height"
31
+ transparent(0.5) { dash(1); stroke_bounds; undash }
32
+ end
33
+
34
+ bounding_box([gap * 7, bounds.top - gap], :width => 100, :height => 50) do
35
+ box_content("Fixed height")
36
+ end
37
+
38
+ transparent(0.5) { dash(1); stroke_bounds; undash }
39
+ end
40
+
41
+ bounding_box([gap, cursor - gap], :width => 300, :height => 50) do
42
+ box_content("Fixed height")
43
+ end
44
+ end
45
+ end
@@ -0,0 +1,40 @@
1
+ # encoding: utf-8
2
+ #
3
+ # This example is mostly just for fun, and shows how nested bounding boxes
4
+ # can simplify calculations. See the "Bounding Box" section of the manual
5
+ # for more basic uses.
6
+ #
7
+ require File.expand_path(File.join(File.dirname(__FILE__),
8
+ %w[.. example_helper]))
9
+
10
+ filename = File.basename(__FILE__).gsub('.rb', '.pdf')
11
+ Prawn::Example.generate(filename) do
12
+ def combine(a1, a2)
13
+ output = []
14
+ a1.each do |i1|
15
+ a2.each do |i2|
16
+ output += [[i1,i2]]
17
+ end
18
+ end
19
+ output
20
+ end
21
+
22
+ def recurse_bounding_box(max_depth=4, depth=1)
23
+ width = (bounds.width-15)/2
24
+ height = (bounds.height-15)/2
25
+ left_top_corners = combine([5, bounds.right-width-5],
26
+ [bounds.top-5, height+5])
27
+ left_top_corners.each do |lt|
28
+ bounding_box(lt, :width => width, :height => height) do
29
+ stroke_bounds
30
+ recurse_bounding_box(max_depth, depth+1) if depth < max_depth
31
+ end
32
+ end
33
+ end
34
+
35
+ # Set up a bbox from the dashed line to the bottom of the page
36
+ bounding_box([0, cursor], :width => bounds.width, :height => cursor) do
37
+ recurse_bounding_box
38
+ end
39
+ end
40
+
@@ -0,0 +1,31 @@
1
+ # encoding: utf-8
2
+ #
3
+ # Bounding Boxes accept an optional <code>:height</code> parameter. Unless it
4
+ # is provided the bounding box will be stretchy. It will expand the height to
5
+ # fit all content generated inside it.
6
+ #
7
+ require File.expand_path(File.join(File.dirname(__FILE__),
8
+ %w[.. example_helper]))
9
+
10
+ filename = File.basename(__FILE__).gsub('.rb', '.pdf')
11
+ Prawn::Example.generate(filename) do
12
+ y_position = cursor
13
+ bounding_box([0, y_position], :width => 200, :height => 100) do
14
+ text "This bounding box has a height of 100. If this text gets too large " +
15
+ "it will flow to the next page."
16
+
17
+ transparent(0.5) { stroke_bounds }
18
+ end
19
+
20
+ bounding_box([300, y_position], :width => 200) do
21
+ text "This bounding box has variable height. No matter how much text is " +
22
+ "written here, the height will expand to fit."
23
+
24
+ text " _" * 100
25
+
26
+ text " *" * 100
27
+
28
+ transparent(0.5) { stroke_bounds }
29
+ end
30
+
31
+ end
@@ -0,0 +1,27 @@
1
+ # encoding: utf-8
2
+ #
3
+ # Pass an image path to the <code>:background</code> option and it will be used
4
+ # as the background for all pages.
5
+ # This option can only be used on document creation.
6
+ #
7
+ require File.expand_path(File.join(File.dirname(__FILE__),
8
+ %w[.. example_helper]))
9
+
10
+ img = "#{Prawn::DATADIR}/images/letterhead.jpg"
11
+
12
+ Prawn::Document.generate("background.pdf",
13
+ :background => img,
14
+ :margin => 100
15
+ ) do
16
+ text "My report caption", :size => 18, :align => :right
17
+
18
+ move_down font.height * 2
19
+
20
+ text "Here is my text explaning this report. " * 20,
21
+ :size => 12, :align => :left, :leading => 2
22
+
23
+ move_down font.height
24
+
25
+ text "I'm using a soft background. " * 40,
26
+ :size => 12, :align => :left, :leading => 2
27
+ end
@@ -0,0 +1,31 @@
1
+ # encoding: utf-8
2
+ #
3
+ # Examples for stamps and repeaters.
4
+ #
5
+ require File.expand_path(File.join(File.dirname(__FILE__),
6
+ %w[.. example_helper]))
7
+
8
+ Prawn::Example.generate("document_and_page_options.pdf",
9
+ :page_size => "FOLIO") do
10
+
11
+ package "document_and_page_options" do |p|
12
+
13
+ p.example "page_size", :eval_source => false, :full_source => true
14
+ p.example "page_margins", :eval_source => false, :full_source => true
15
+ p.example "background", :eval_source => false, :full_source => true
16
+ p.example "metadata", :eval_source => false, :full_source => true
17
+
18
+ p.intro do
19
+ prose("So far we've already seen how to create new documents and start new pages. This chapter expands on the previous examples by showing other options avialable. Some of the options are only available when creating new documents.
20
+
21
+ The examples show:")
22
+
23
+ list( "How to configure page size",
24
+ "How to configure page margins",
25
+ "How to use a background image",
26
+ "How to add metadata to the generated PDF"
27
+ )
28
+ end
29
+
30
+ end
31
+ end
@@ -0,0 +1,23 @@
1
+ # encoding: utf-8
2
+ #
3
+ # To set the document metadata just pass a hash to the <code>:info</code>
4
+ # option when creating new documents.
5
+ #
6
+ require File.expand_path(File.join(File.dirname(__FILE__),
7
+ %w[.. example_helper]))
8
+
9
+ Prawn::Document.generate("metadata.pdf",
10
+ :info => {
11
+ :Title => "My title",
12
+ :Author => "John Doe",
13
+ :Subject => "My Subject",
14
+ :Keywords => "test metadata ruby pdf dry",
15
+ :Creator => "ACME Soft App",
16
+ :Producer => "Prawn",
17
+ :CreationDate => Time.now,
18
+ :Grok => "Test Property"
19
+ }) do
20
+
21
+ text "This is a test of setting metadata properties via the info option."
22
+ text "It allows one to specify non standard properties like 'Grok'."
23
+ end
@@ -0,0 +1,38 @@
1
+ # encoding: utf-8
2
+ #
3
+ # The default margin for pages is 0.5 inch but you can change that with the
4
+ # <code>:margin</code> option or if you'd like to have different margins you
5
+ # can use the <code>:left_margin</code>, <code>:right_margin</code>,
6
+ # <code>:top_margin</code>, <code>:bottom_margin</code> options.
7
+ #
8
+ # These options are available both for starting new pages and creating new
9
+ # documents.
10
+ #
11
+ require File.expand_path(File.join(File.dirname(__FILE__),
12
+ %w[.. example_helper]))
13
+
14
+ Prawn::Document.generate("page_margins.pdf",
15
+ :margin => 100
16
+ ) do
17
+ text "100 pts margins."
18
+ stroke_bounds
19
+
20
+ start_new_page(:left_margin => 300)
21
+ text "300 pts margin on the left."
22
+ stroke_bounds
23
+
24
+ start_new_page(:top_margin => 300)
25
+ text "300 pts margin both on the top and on the left. Notice that whenever " +
26
+ "you set an option for a new page it will remain the default for the " +
27
+ "following pages."
28
+ stroke_bounds
29
+
30
+ start_new_page(:margin => 50)
31
+ text "50 pts margins. Using the margin option will reset previous specific " +
32
+ "calls to left, right, top and bottom margins."
33
+ stroke_bounds
34
+
35
+ start_new_page(:margin => [50, 100, 150, 200])
36
+ text "There is also the shorthand CSS like syntax used here."
37
+ stroke_bounds
38
+ end
@@ -0,0 +1,34 @@
1
+ # encoding: utf-8
2
+ #
3
+ # Prawn comes with support for most of the common page sizes so you'll only need
4
+ # to provide specific values if your intended format is not supported. To see a
5
+ # list with all supported sizes take a look at: https://github.com/prawnpdf/prawn/blob/master/lib/prawn/document/page_geometry.rb
6
+ #
7
+ # To define the size use <code>:page_size</code> when creating new documents
8
+ # and <code>:size</code> when starting new pages. The default page size for new
9
+ # documents is LETTER (612.00 x 792.00).
10
+ #
11
+ # You may also define the orientation of the page to be either portrait
12
+ # (default) or landscape. Use <code>:page_layout</code> when creating new
13
+ # documents and <code>:layout</code> when starting new pages.
14
+ #
15
+ require File.expand_path(File.join(File.dirname(__FILE__),
16
+ %w[.. example_helper]))
17
+
18
+ Prawn::Document.generate("page_size.pdf",
19
+ :page_size => "EXECUTIVE",
20
+ :page_layout => :landscape
21
+ ) do
22
+ text "EXECUTIVE landscape page."
23
+
24
+ custom_size = [275, 326]
25
+
26
+ ["A4", "TABLOID", "B7", custom_size ].each do |size|
27
+
28
+ start_new_page(:size => size, :layout => :portrait)
29
+ text "#{size} portrait page."
30
+
31
+ start_new_page(:size => size, :layout => :landscape)
32
+ text "#{size} landscape page."
33
+ end
34
+ end
@@ -0,0 +1,116 @@
1
+ # encoding: utf-8
2
+
3
+ module Prawn
4
+
5
+ # The Prawn::ExampleFile class is a utility class to ease the manipulation
6
+ # and extraction of source code and comments from the actual example files
7
+ #
8
+ class ExampleFile
9
+ attr_reader :package, :filename
10
+
11
+ # Stores the file data, filename and parent, which will be either an
12
+ # ExampleSection or an ExamplePackage.
13
+ #
14
+ # Available boolean options are:
15
+ #
16
+ # <tt>:eval_source</tt>:: Evals the example source code (default: true)
17
+ # <tt>:full_source</tt>:: Extract the full source code when true. Extract
18
+ # only the code between the generate block when false (default: false)
19
+ #
20
+ def initialize(parent, filename, options={})
21
+ @parent = parent.is_a?(String) ? ExamplePackage.new(parent) : parent
22
+
23
+ @filename = filename
24
+ @data = read_file(@parent.folder_name, filename)
25
+
26
+ @options = {:eval_source => true, :full_source => false}.merge(options)
27
+ end
28
+
29
+ # Return the example source code excluding the initial comments and
30
+ # require calls
31
+ #
32
+ def full_source
33
+ @data.gsub(/# encoding.*?\n.*require.*?\n\n/m, "\n").strip
34
+ end
35
+
36
+ # Return the example source contained inside the first generate block or
37
+ # the full source if no generate block is found
38
+ #
39
+ def generate_block_source
40
+ block = @data.slice(/\w+\.generate.*? do\n(.*)end/m, 1)
41
+
42
+ return full_source unless block
43
+
44
+ block.gsub(/^( ){2}/, "")
45
+ end
46
+
47
+ # Return either the full_source or the generate_block_source according
48
+ # to the options
49
+ #
50
+ def source
51
+ @options[:full_source] ? full_source : generate_block_source
52
+ end
53
+
54
+ # Return true if the example source should be evaluated inline within
55
+ # the manual according to the options
56
+ #
57
+ def eval?
58
+ @options[:eval_source]
59
+ end
60
+
61
+ # Retrieve the comments between the encoding declaration and the require
62
+ # call for example_helper.rb
63
+ #
64
+ # Then removes the '#' signs, reflows the line breaks and return the result
65
+ #
66
+ def introduction_text
67
+ intro = @data.slice(/# encoding.*?\n(.*)require File\.expand_path/m, 1)
68
+ intro.gsub!(/\n# (?=\S)/m, ' ')
69
+ intro.gsub!(/^#/, '')
70
+ intro.gsub!("\n", "\n\n")
71
+ intro.rstrip!
72
+ intro
73
+ end
74
+
75
+ # Returns a human friendly version of the example file name
76
+ #
77
+ def name
78
+ @name ||= @filename[/(.*)\.rb/, 1].gsub("_", " ").capitalize
79
+ end
80
+
81
+ # Returns this example's parent original folder name
82
+ #
83
+ def parent_folder_name
84
+ @parent.folder_name
85
+ end
86
+
87
+ # Returns the human friendly version of this example parent name
88
+ #
89
+ def parent_name
90
+ @parent.name
91
+ end
92
+
93
+ # Renders this example to a pdf
94
+ #
95
+ def render(pdf)
96
+ pdf.render_example(self)
97
+ end
98
+
99
+ private
100
+
101
+ # Read the data from a file in a given package
102
+ #
103
+ def read_file(folder_name, filename)
104
+ data = File.read(File.expand_path(File.join(
105
+ File.dirname(__FILE__), folder_name, filename)))
106
+
107
+ # XXX If we ever have manual files with source encodings other than
108
+ # UTF-8, we will need to fix this to work on Ruby 1.9.
109
+ if data.respond_to?(:encode!)
110
+ data.encode!("UTF-8")
111
+ end
112
+ data
113
+ end
114
+
115
+ end
116
+ end