pdf_paradise 0.1.43

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of pdf_paradise might be problematic. Click here for more details.

Files changed (93) hide show
  1. checksums.yaml +7 -0
  2. data/README.md +376 -0
  3. data/bin/automatic_pdf_title +7 -0
  4. data/bin/convert_markdown_to_pdf +7 -0
  5. data/bin/convert_pdf_to_text +7 -0
  6. data/bin/merge_then_open +7 -0
  7. data/bin/n_pages +10 -0
  8. data/bin/open_main_pdf +7 -0
  9. data/bin/pdf_paradise +7 -0
  10. data/bin/set_main_book +7 -0
  11. data/bin/set_title_of_this_pdf_file +15 -0
  12. data/doc/README.gen +348 -0
  13. data/doc/todo/todo.md +2 -0
  14. data/lib/pdf_paradise.rb +5 -0
  15. data/lib/pdf_paradise/base/base.rb +173 -0
  16. data/lib/pdf_paradise/commandline/help.rb +69 -0
  17. data/lib/pdf_paradise/commandline/menu.rb +160 -0
  18. data/lib/pdf_paradise/compress_this_pdf_file.rb +82 -0
  19. data/lib/pdf_paradise/constants/constants.rb +59 -0
  20. data/lib/pdf_paradise/convert_text_to_pdf.rb +94 -0
  21. data/lib/pdf_paradise/css/project.css +17 -0
  22. data/lib/pdf_paradise/djvu_to_pdf.rb +85 -0
  23. data/lib/pdf_paradise/gui/README.md +6 -0
  24. data/lib/pdf_paradise/gui/fox/split_pdf_file.rb +77 -0
  25. data/lib/pdf_paradise/gui/gtk2/delete_the_first_or_the_last_page_of_this_pdf_file/delete_the_first_or_the_last_page_of_this_pdf_file.rb +39 -0
  26. data/lib/pdf_paradise/gui/gtk2/pdf_viewer/pdf_viewer.rb +34 -0
  27. data/lib/pdf_paradise/gui/gtk2/split_pdf_file/split_pdf_file.rb +34 -0
  28. data/lib/pdf_paradise/gui/gtk2/statistics_widget/statistics_widget.rb +34 -0
  29. data/lib/pdf_paradise/gui/gtk2/to_pdf/to_pdf.rb +32 -0
  30. data/lib/pdf_paradise/gui/gtk3/controller/controller.rb +197 -0
  31. data/lib/pdf_paradise/gui/gtk3/convert_pdf_to_text/convert_pdf_to_text.rb +34 -0
  32. data/lib/pdf_paradise/gui/gtk3/delete_the_first_or_the_last_page_of_this_pdf_file/delete_the_first_or_the_last_page_of_this_pdf_file.rb +39 -0
  33. data/lib/pdf_paradise/gui/gtk3/pdf_viewer/pdf_viewer.rb +34 -0
  34. data/lib/pdf_paradise/gui/gtk3/split_pdf_file/split_pdf_file.rb +34 -0
  35. data/lib/pdf_paradise/gui/gtk3/statistics_widget/statistics_widget.rb +34 -0
  36. data/lib/pdf_paradise/gui/gtk3/to_pdf/to_pdf.rb +32 -0
  37. data/lib/pdf_paradise/gui/shared_code/convert_pdf_to_text/convert_pdf_to_text_module.rb +277 -0
  38. data/lib/pdf_paradise/gui/shared_code/delete_the_first_or_the_last_page_of_this_pdf_file/delete_the_first_or_the_last_page_of_this_pdf_file_module.rb +428 -0
  39. data/lib/pdf_paradise/gui/shared_code/pdf_viewer/pdf_viewer.css +5 -0
  40. data/lib/pdf_paradise/gui/shared_code/pdf_viewer/pdf_viewer_module.rb +284 -0
  41. data/lib/pdf_paradise/gui/shared_code/split_pdf_file/split_pdf_file.css +0 -0
  42. data/lib/pdf_paradise/gui/shared_code/split_pdf_file/split_pdf_file_module.rb +294 -0
  43. data/lib/pdf_paradise/gui/shared_code/statistics_widget/statistics_widget_module.rb +333 -0
  44. data/lib/pdf_paradise/gui/shared_code/to_pdf/to_pdf_module.rb +273 -0
  45. data/lib/pdf_paradise/main_pdf/main_pdf.rb +437 -0
  46. data/lib/pdf_paradise/merge_pdf/menu.rb +63 -0
  47. data/lib/pdf_paradise/merge_pdf/merge_pdf.rb +292 -0
  48. data/lib/pdf_paradise/merge_pdf_namespace.rb +9 -0
  49. data/lib/pdf_paradise/merge_then_open/merge_then_open.rb +105 -0
  50. data/lib/pdf_paradise/pdf_file_n_total_pages.rb +227 -0
  51. data/lib/pdf_paradise/project/project_base_directory.rb +22 -0
  52. data/lib/pdf_paradise/remove_pdf_password.rb +392 -0
  53. data/lib/pdf_paradise/requires/batch_require_toplevel_files.rb +22 -0
  54. data/lib/pdf_paradise/requires/colours.rb +7 -0
  55. data/lib/pdf_paradise/requires/colours_and_esystem_and_save_file_and_fileutils_and_opn.rb +11 -0
  56. data/lib/pdf_paradise/requires/esystem_and_colours.rb +10 -0
  57. data/lib/pdf_paradise/requires/esystem_and_opn_and_colours.rb +8 -0
  58. data/lib/pdf_paradise/requires/require_the_whole_project.rb +25 -0
  59. data/lib/pdf_paradise/requires/require_utility_scripts.rb +7 -0
  60. data/lib/pdf_paradise/rotate_pdf_file.rb +144 -0
  61. data/lib/pdf_paradise/set_main_book.rb +156 -0
  62. data/lib/pdf_paradise/set_pdf_title.rb +218 -0
  63. data/lib/pdf_paradise/sinatra/embeddable_interface.rb +315 -0
  64. data/lib/pdf_paradise/toplevel_methods/automatic_pdf_title.rb +55 -0
  65. data/lib/pdf_paradise/toplevel_methods/convert_epub_to_pdf.rb +27 -0
  66. data/lib/pdf_paradise/toplevel_methods/convert_markdown_to_pdf.rb +43 -0
  67. data/lib/pdf_paradise/toplevel_methods/convert_ppt_to_pdf.rb +35 -0
  68. data/lib/pdf_paradise/toplevel_methods/e.rb +16 -0
  69. data/lib/pdf_paradise/toplevel_methods/esystem.rb +19 -0
  70. data/lib/pdf_paradise/toplevel_methods/misc.rb +52 -0
  71. data/lib/pdf_paradise/toplevel_methods/number_pages.rb +38 -0
  72. data/lib/pdf_paradise/toplevel_methods/opened_pdf_files.rb +191 -0
  73. data/lib/pdf_paradise/toplevel_methods/query_pdf_title.rb +182 -0
  74. data/lib/pdf_paradise/toplevel_methods/reduce_size_of_this_pdf_file.rb +43 -0
  75. data/lib/pdf_paradise/toplevel_methods/roebe.rb +17 -0
  76. data/lib/pdf_paradise/toplevel_methods/to_pdf.rb +38 -0
  77. data/lib/pdf_paradise/utility_scripts/README.md +3 -0
  78. data/lib/pdf_paradise/utility_scripts/convert_pdf_to_text.rb +166 -0
  79. data/lib/pdf_paradise/utility_scripts/delete_first_page_of_this_pdf_file.rb +185 -0
  80. data/lib/pdf_paradise/utility_scripts/delete_last_page_of_this_pdf_file.rb +180 -0
  81. data/lib/pdf_paradise/utility_scripts/delete_this_page_of_this_pdf_file.rb +310 -0
  82. data/lib/pdf_paradise/utility_scripts/extract_pdf_page.rb +280 -0
  83. data/lib/pdf_paradise/utility_scripts/pdf_optimizer.rb +113 -0
  84. data/lib/pdf_paradise/utility_scripts/pdf_statistics.rb +150 -0
  85. data/lib/pdf_paradise/utility_scripts/remove_images.rb +110 -0
  86. data/lib/pdf_paradise/utility_scripts/split_pdf.rb +294 -0
  87. data/lib/pdf_paradise/utility_scripts/to_qdf.rb +82 -0
  88. data/lib/pdf_paradise/version/version.rb +19 -0
  89. data/lib/pdf_paradise/www/README.md +2 -0
  90. data/lib/pdf_paradise/www/sinatra/app.rb +276 -0
  91. data/pdf_paradise.gemspec +64 -0
  92. data/test/testing_pdf_paradise.rb +9 -0
  93. metadata +216 -0
@@ -0,0 +1,63 @@
1
+ #!/usr/bin/ruby -w
2
+ # Encoding: UTF-8
3
+ # frozen_string_literal: true
4
+ # =========================================================================== #
5
+ # require 'pdf_paradise/merge_pdf/menu.rb'
6
+ # =========================================================================== #
7
+ require 'pdf_paradise/base/base.rb'
8
+
9
+ module PdfParadise
10
+
11
+ class MergePdf < Base # === PdfParadise::MergePdf
12
+
13
+ # ========================================================================= #
14
+ # === menu (menu tag)
15
+ #
16
+ # This is check_against_menu(). We respond to some given input.
17
+ # ========================================================================= #
18
+ def menu(
19
+ i = commandline_arguments?
20
+ )
21
+ if i.is_a? Array
22
+ i.each {|entry| menu(entry) }
23
+ else
24
+ case i # (case tag)
25
+ # ===================================================================== #
26
+ # === --use-hexapdf
27
+ # ===================================================================== #
28
+ when /^-?-?use(-|_| )?hexapdf$/i,
29
+ /^-?-?hexapdf$/i
30
+ @use_this_program_for_merging_the_pdf_files = :hexapdf
31
+ # ===================================================================== #
32
+ # === --use-ghostscript
33
+ # ===================================================================== #
34
+ when /^-?-?use(-|_| )?ghostscript$/i,
35
+ /^-?-?ghostscript$/i
36
+ @use_this_program_for_merging_the_pdf_files = :ghostscript
37
+ # ===================================================================== #
38
+ # === --remove
39
+ # ===================================================================== #
40
+ when '1',
41
+ /^-?-?last$/i,
42
+ /^-?-?kill$/i,
43
+ /^-?-?remove$/i
44
+ remove_merged_files
45
+ exit
46
+ # ===================================================================== #
47
+ # === --openself
48
+ # ===================================================================== #
49
+ when '2',
50
+ /^-?-?openself$/i
51
+ open_this_file_here
52
+ exit
53
+ # ===================================================================== #
54
+ # === mergepdf --help
55
+ # ===================================================================== #
56
+ when /help/
57
+ show_help
58
+ exit
59
+ end
60
+ end
61
+ end; alias check_against_menu menu # === check_against_menu
62
+
63
+ end; end
@@ -0,0 +1,292 @@
1
+ #!/usr/bin/ruby -w
2
+ # Encoding: UTF-8
3
+ # frozen_string_literal: true
4
+ # =========================================================================== #
5
+ # === PdfParadise::MergePdf
6
+ #
7
+ # This class will merge together some .pdf files.
8
+ #
9
+ # Usage example:
10
+ #
11
+ # PdfParadise::MergePdf.new(ARGV)
12
+ #
13
+ # =========================================================================== #
14
+ # require 'pdf_paradise/merge_pdf/merge_pdf.rb'
15
+ # =========================================================================== #
16
+ require 'pdf_paradise/base/base.rb'
17
+ require 'pdf_paradise/merge_pdf/menu.rb'
18
+
19
+ module PdfParadise
20
+
21
+ class MergePdf < Base # === PdfParadise::MergePdf
22
+
23
+ # ========================================================================= #
24
+ # === NAMESPACE
25
+ # ========================================================================= #
26
+ NAMESPACE = inspect
27
+
28
+ # ========================================================================= #
29
+ # === THIS_FILE_HERE
30
+ # ========================================================================= #
31
+ THIS_FILE_HERE =
32
+ '/home/x/DATA/PROGRAMMING_LANGUAGES/RUBY/src/pdf_paradise/lib/pdf_paradise/merge_pdf/merge_pdf.rb'
33
+
34
+ # ========================================================================= #
35
+ # === STORE_WHERE_WE_MERGED_FILES
36
+ # ========================================================================= #
37
+ STORE_WHERE_WE_MERGED_FILES =
38
+ '/home/Temp/merged_these_pdf_files.md'
39
+
40
+ # ========================================================================= #
41
+ # === initialize
42
+ # ========================================================================= #
43
+ def initialize(
44
+ i = nil,
45
+ run_already = true
46
+ )
47
+ reset
48
+ set_commandline_arguments(
49
+ return_hyphen_arguments(i)
50
+ )
51
+ case i
52
+ when :dont_run_yet
53
+ run_already = false
54
+ else
55
+ set_array_pdf_files(i)
56
+ end
57
+ run if run_already
58
+ end
59
+
60
+ # ========================================================================= #
61
+ # === reset (reset tag)
62
+ # ========================================================================= #
63
+ def reset
64
+ # ======================================================================= #
65
+ # === @array_pdf_files
66
+ # ======================================================================= #
67
+ @array_pdf_files = []
68
+ # ======================================================================= #
69
+ # === @use_this_program_for_merging_the_pdf_files
70
+ #
71
+ # Currently we can either use :ghostscript (gs) or :hexapdf. The
72
+ # latter is a pure ruby-gem.
73
+ # ======================================================================= #
74
+ @use_this_program_for_merging_the_pdf_files = :hexapdf # :ghostscript
75
+ set_output_filename
76
+ end
77
+
78
+ # ========================================================================= #
79
+ # === show_help (help tag)
80
+ # ========================================================================= #
81
+ def show_help
82
+ e
83
+ e 'To remove the merged files, do this:'
84
+ e
85
+ e ' mergepdf --remove'
86
+ e
87
+ end
88
+
89
+ # ========================================================================= #
90
+ # === remove_merged_files (remove tag)
91
+ # ========================================================================= #
92
+ def remove_merged_files
93
+ _ = where_are_the_merged_files?
94
+ opnn; e 'We will now remove the merged files, by reading '\
95
+ 'in from `'+sfile(_)+'`.'
96
+ # ======================================================================= #
97
+ # Read in that save-file next. As of Feb 2015, the format is
98
+ # one-file-per-line. We also get rid of '"' characters.
99
+ # ======================================================================= #
100
+ _ = File.readlines(_).map {|entry|
101
+ entry.chomp.delete('"')
102
+ } # .split(' ')
103
+ _.each {|file| delete(file) }
104
+ end
105
+
106
+ # ========================================================================= #
107
+ # === open_this_file_here
108
+ # ========================================================================= #
109
+ def open_this_file_here
110
+ _ = 'bluefish '+THIS_FILE_HERE
111
+ esystem _
112
+ end
113
+
114
+ # ========================================================================= #
115
+ # === do_conversion
116
+ #
117
+ # This method will do the actual conversion.
118
+ # ========================================================================= #
119
+ def do_conversion
120
+ these_files = @array_pdf_files.join(N)
121
+ # ======================================================================= #
122
+ # Next, we store this in the save-file.
123
+ # ======================================================================= #
124
+ write_what_into(these_files, where_are_the_merged_files?)
125
+ case @use_this_program_for_merging_the_pdf_files
126
+ # ======================================================================= #
127
+ # === :hexapdf
128
+ # ======================================================================= #
129
+ when :hexapdf
130
+ _ = 'hexapdf merge --force '.dup
131
+ _ << these_files.tr(N,' ')
132
+ _ << " #{@output_filename}"
133
+ # ======================================================================= #
134
+ # === :ghostscript
135
+ #
136
+ # To use this via the commandline, try:
137
+ #
138
+ # mergepdf one.pdf two.pdf --use-ghostscript
139
+ #
140
+ # ======================================================================= #
141
+ when :ghostscript,
142
+ :default
143
+ _ = 'gs -dNOPAUSE -sDEVICE=pdfwrite -sOUTPUTFILE="'+
144
+ @output_filename+
145
+ '" -dBATCH '
146
+ _ << these_files.tr(N,' ')
147
+ end
148
+ e
149
+ cliner
150
+ e "#{::Colours.rev}We will run this command next for "\
151
+ "#{@array_pdf_files.size.to_s} .pdf files:"
152
+ e
153
+ efancy " #{_}" # This is the command we will run.
154
+ e
155
+ system _
156
+ cliner
157
+ end
158
+
159
+ # ========================================================================= #
160
+ # === where_are_the_merged_files?
161
+ # ========================================================================= #
162
+ def where_are_the_merged_files?
163
+ STORE_WHERE_WE_MERGED_FILES
164
+ end
165
+
166
+ # ========================================================================= #
167
+ # === delete
168
+ # ========================================================================= #
169
+ def delete(i)
170
+ unless i == '/'
171
+ efancy(" - #{i}") # Add a slight padding to the output.
172
+ File.delete(i) if File.exist? i # Safeguard.
173
+ end
174
+ end
175
+
176
+ # ========================================================================= #
177
+ # === pad_this
178
+ # ========================================================================= #
179
+ def pad_this(i)
180
+ return '"'+i+'"'
181
+ end
182
+
183
+ # ========================================================================= #
184
+ # === set_array_pdf_files
185
+ # ========================================================================= #
186
+ def set_array_pdf_files(i = '')
187
+ i = [i].flatten.compact.reject {|entry| entry.start_with?('--') }
188
+ if i.is_a?(Array) and i.empty?
189
+ all_pdf_files = Dir['*.pdf']
190
+ # ===================================================================== #
191
+ # Try to use all .pdf files.
192
+ # ===================================================================== #
193
+ unless all_pdf_files.empty?
194
+ opnn; e 'No specific input was given, thus using all '+
195
+ sfancy(all_pdf_files.size.to_s)+' .pdf files '\
196
+ 'in this directory'
197
+ i = all_pdf_files
198
+ end
199
+ end
200
+ if i.is_a? Array # Keep only files that exist.
201
+ i.select! {|entry| File.exist? entry }
202
+ end
203
+ if i.is_a? Array
204
+ i.map! {|entry| pad_this(entry) }
205
+ end
206
+ if i.empty?
207
+ opnn; ewarn 'Unable to find any existing files '\
208
+ 'to match to, thus exiting now.'
209
+ exit
210
+ end
211
+ @array_pdf_files << i
212
+ @array_pdf_files = @array_pdf_files.flatten # Always keep it flattened.
213
+ end; alias << set_array_pdf_files # === <<
214
+
215
+ # ========================================================================= #
216
+ # === set_output_filename
217
+ #
218
+ # Store the filename of the pdf through this method, the name of
219
+ # the output file.
220
+ # ========================================================================= #
221
+ def set_output_filename(
222
+ i = 'Merged_PDF_Files.pdf'
223
+ )
224
+ if i.size > 255
225
+ opnn; ewarn 'The name for the new filename is larger than 255.'
226
+ opnn; ewarn 'We will thus truncate the name to the first 255 '\
227
+ 'characters instead.'
228
+ i = i[0, 254]
229
+ # ===================================================================== #
230
+ # Since as of Jun 2016, we will get rid of the last 4
231
+ # characters and append '.pdf'
232
+ # ===================================================================== #
233
+ i[-4,4] = ''
234
+ i << '.pdf'
235
+ end
236
+ @output_filename = i
237
+ end; alias store_at set_output_filename # === store_at
238
+
239
+ # ========================================================================= #
240
+ # === opnn
241
+ # ========================================================================= #
242
+ def opnn
243
+ super(NAMESPACE)
244
+ end
245
+
246
+ # ========================================================================= #
247
+ # === feedback_where_it_is_stored
248
+ # ========================================================================= #
249
+ def feedback_where_it_is_stored
250
+ if File.exist? result?
251
+ opnn; e "The result is stored at `#{sfile(self.result)}`."
252
+ end
253
+ end; alias report feedback_where_it_is_stored # === report
254
+
255
+ # ========================================================================= #
256
+ # === output_filename
257
+ # ========================================================================= #
258
+ def output_filename
259
+ _ = @output_filename
260
+ _ = _.join(', ') if _.is_a? Array
261
+ return _
262
+ end; alias result output_filename # === result
263
+ alias result? output_filename # === result?
264
+ alias output_filename? output_filename # === output_filename?
265
+ alias output_file? output_filename # === output_file?
266
+
267
+ # ========================================================================= #
268
+ # === build_new_output_name_based_on_input
269
+ # ========================================================================= #
270
+ def build_new_output_name_based_on_input
271
+ _ = @array_pdf_files.map {|entry|
272
+ File.basename(entry).gsub(File.extname(entry), '')
273
+ }
274
+ _ = _.join(' ').gsub(/ /,'_').gsub(/\"/,'')+'.pdf'
275
+ set_output_filename(_)
276
+ end
277
+
278
+ # ========================================================================= #
279
+ # === run (run tag)
280
+ # ========================================================================= #
281
+ def run
282
+ menu
283
+ build_new_output_name_based_on_input
284
+ do_conversion
285
+ end
286
+
287
+ end; end
288
+
289
+ if __FILE__ == $PROGRAM_NAME
290
+ _ = PdfParadise::MergePdf.new(ARGV)
291
+ _.feedback_where_it_is_stored # Call it manually.
292
+ end # merge_pdf
@@ -0,0 +1,9 @@
1
+ #!/usr/bin/ruby -w
2
+ # Encoding: UTF-8
3
+ # frozen_string_literal: true
4
+ # =========================================================================== #
5
+ # require 'pdf_paradise/merge_pdf_namespace'
6
+ # =========================================================================== #
7
+ require 'pdf_paradise/requires/require_the_whole_project.rb'
8
+
9
+ MergePdf = PdfParadise::MergePdf # Now the MergePdf namespace is available in the toplevel.
@@ -0,0 +1,105 @@
1
+ #!/usr/bin/ruby -w
2
+ # Encoding: UTF-8
3
+ # frozen_string_literal: true
4
+ # =========================================================================== #
5
+ # === PdfParadise::MergeThenOpen
6
+ #
7
+ # This will first merge different .pdf files, and then open the
8
+ # newly generated .pdf file.
9
+ #
10
+ # Usage example:
11
+ #
12
+ # PdfParadise::MergeThenOpen.new(ARGV)
13
+ #
14
+ # =========================================================================== #
15
+ # require 'pdf_paradise/merge_then_open/merge_then_open.rb'
16
+ # PdfParadise::MergeThenOpen.new(ARGV)
17
+ # =========================================================================== #
18
+ require 'pdf_paradise/merge_pdf/merge_pdf.rb'
19
+
20
+ module PdfParadise
21
+
22
+ class MergeThenOpen < Base # === PdfParadise::MergeThenOpen
23
+
24
+ # ========================================================================= #
25
+ # === NAMESPACE
26
+ # ========================================================================= #
27
+ NAMESPACE = inspect
28
+
29
+ # ========================================================================= #
30
+ # === initialize
31
+ # ========================================================================= #
32
+ def initialize(
33
+ commandline_arguments = nil,
34
+ run_already = true
35
+ )
36
+ reset
37
+ set_commandline_arguments(
38
+ commandline_arguments
39
+ )
40
+ run if run_already
41
+ end
42
+
43
+ # ========================================================================= #
44
+ # === reset (reset tag)
45
+ # ========================================================================= #
46
+ def reset
47
+ super()
48
+ end
49
+
50
+ # ========================================================================= #
51
+ # === opnn
52
+ # ========================================================================= #
53
+ def opnn(i = NAMESPACE)
54
+ super(i)
55
+ end
56
+
57
+ # ========================================================================= #
58
+ # === set_commandline_arguments
59
+ # ========================================================================= #
60
+ def set_commandline_arguments(i = '')
61
+ i = [i].flatten.compact
62
+ @commandline_arguments = i
63
+ end
64
+
65
+ # ========================================================================= #
66
+ # === commandline_arguments?
67
+ # ========================================================================= #
68
+ def commandline_arguments?
69
+ @commandline_arguments
70
+ end
71
+
72
+ # ========================================================================= #
73
+ # === run (run tag)
74
+ # ========================================================================= #
75
+ def run
76
+ merge_pdf = MergePdf.new(@commandline_arguments)
77
+ new_file = merge_pdf.output_file?
78
+ if File.exist? new_file
79
+ # ===================================================================== #
80
+ # We have to open this file next.
81
+ # ===================================================================== #
82
+ begin
83
+ require 'roebe/classes/open/open.rb'
84
+ if Object.const_defined? :Roebe
85
+ opnn; e "Opening #{sfile(new_file)} next."
86
+ Roebe::Open.new(new_file)
87
+ end
88
+ rescue LoadError; end
89
+ else
90
+ opnn; e "No file appears to exist at #{sfile(new_file)}."
91
+ end
92
+ end
93
+
94
+ # ========================================================================= #
95
+ # === MergeThenOpen[]
96
+ # ========================================================================= #
97
+ def self.[](i = '')
98
+ new(i)
99
+ end
100
+
101
+ end; end
102
+
103
+ if __FILE__ == $PROGRAM_NAME
104
+ PdfParadise::MergeThenOpen.new(ARGV)
105
+ end # merge_then_open