jekyll-pandoc-multiple-formats-jekyll34 0.2.10 → 0.2.12

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: cc15f74f343f35ce8aa968401206265fc3e92e2f
4
- data.tar.gz: 31b077b4b25e78cfd898f7fcb6c5f0e743dc41f6
3
+ metadata.gz: 9f26bdb61d717f7c75c85f2fc8f3e688d76e831f
4
+ data.tar.gz: 1c071b0ec7c88cb176ccc2a7d6ad56df72fdeb72
5
5
  SHA512:
6
- metadata.gz: e7bdd6d2e0fe689863fac4d39c938bfaf93594fd663cbfe27ccca8041eb9237c777cdf2b866953897b0fd209722b215b301b1b80bf860e51cb2b814108f6ccc0
7
- data.tar.gz: a11a5a24539b95705f525e840b1d2f7a4545081164027b7b1aa4c058ae940fd863be7191a3418fa6d5a9e32a4dd1196b6e05c97a02ac517c0c740821f5c7726e
6
+ metadata.gz: '049a1d23a4b3c89cc41cc203b4ee6291768f34b6db8809326d7a397c084b404ec313f79bb60c3720770d98e8cd3cec599db5fb63a5bc41d38f28c825f3c7e37c'
7
+ data.tar.gz: 477e32477687e9625a87e7e491b5e21f28d5a6071567accfe05570cec162cee4d7646bbafd7856bbf1f9128adfca5a87a471bbdfaf36f517b846b95c46ad0959
data/Gemfile ADDED
@@ -0,0 +1,3 @@
1
+ source 'https://rubygems.org'
2
+
3
+ gemspec
data/LICENSE ADDED
@@ -0,0 +1,22 @@
1
+ Copytight 2017 윤병익 <by_yeun@daum.net>
2
+
3
+ Original Authors : Nicolás Reynolds <fauno@endefensadelsl.org>, Mauricio Pasquier Juan <mpj@endefensadelsl.org>, Brian Candler <b.candler@pobox.com>
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,190 @@
1
+ # Another pandoc plugin for jekyll
2
+
3
+ This jekyll plugin was inspired by [jekyll-pandoc-plugin][1] but it was changed
4
+ to generate multiple outputs, rather than just using pandoc to generate jekyll
5
+ html posts. Besides, it doesn't require the 'pandoc-ruby' gem.
6
+
7
+ It's used on [En Defensa del Software Libre][0]. Please check [our
8
+ repo](https://github.com/edsl/endefensadelsl.org) if you like to see how
9
+ it works in production.
10
+
11
+ [0]: http://endefensadelsl.org
12
+ [1]: https://github.com/dsanson/jekyll-pandoc-plugin
13
+
14
+
15
+ ## What does it do
16
+
17
+ It replaces the html generation for pandoc. This means you will have
18
+ support for pandoc's markdown extensions, like ~strikethrough~ and
19
+ [@cite], tables and [a lot more stuff](http://pandoc.org/README.html).
20
+
21
+ It'll also generate the post in other formats you like, so your
22
+ blog can be made available in different formats at the same time. Epub
23
+ for ebook readers, mediawiki for copy&paste to wikis, etc.
24
+
25
+ If instructed, this plugin will also generate pdfs in ready for print
26
+ format.
27
+
28
+
29
+ ## Configuration
30
+
31
+ Add to `_config.yml`:
32
+
33
+ ```yaml
34
+
35
+ markdown: pandoc
36
+ pandoc:
37
+ skip: false
38
+ bundle_permalink: ':output_ext/:slug.:output_ext'
39
+ papersize: 'a5paper'
40
+ sheetsize: 'a4paper'
41
+ imposition: true
42
+ binder: true
43
+ covers_dir: assets/covers
44
+ signature: 20
45
+
46
+ flags: '--smart'
47
+ site_flags: '--toc'
48
+ outputs:
49
+ latex:
50
+ pdf: '--latex-engine=xelatex'
51
+ epub: '--epub-chapter-level=2'
52
+
53
+ ```
54
+
55
+ * `markdown: pandoc` will instruct jekyll to use the pandoc html
56
+ converter.
57
+
58
+ * `skip` allows you to skip the other formats generation and proceed with the
59
+ regular jekyll site build.
60
+
61
+ * `site_flags` are flags applied to the html generation
62
+
63
+ * `flags` is a string with the flags you will normally pass to `pandoc` on cli.
64
+ It's used on all output types.
65
+
66
+ * `outputs` is a hash of output formats (even markdown!). You can add
67
+ output-specific flags.
68
+
69
+ * `imposition` creates ready to print PDFs if you're creating PDF
70
+ output.
71
+
72
+ * `binder` creates ready to print PDFs
73
+
74
+ * `bundle_permalink` is the path of the bundled articles
75
+
76
+ * `papersize` is the page size for PDF. You can also use this option on
77
+ the front matter.
78
+
79
+ * `sheetsize` is the page size for ready the print PDF. You can also
80
+ use this option on the front matter.
81
+
82
+ * `covers_dir` the directory where covers are stored
83
+
84
+ * `signature` is the amount of pages per fold on the imposition version.
85
+ Specify `0` for a single fold of all the pages. You can also use this
86
+ option on the front matter.
87
+
88
+ **IMPORTANT**: As of version 0.1.0 the syntax of the config changed.
89
+ Please upgrade your `_config.yml` accordingly.
90
+
91
+
92
+ ## Front Matter
93
+
94
+ ### Covers
95
+
96
+ Support for epub covers has been added. You can add the path to
97
+ a cover on the front matter of the article to have pandoc add a cover
98
+ image on the epub result.
99
+
100
+ ---
101
+ cover: images/awesome.png
102
+ ---
103
+
104
+ For categories or posts without a cover specified, the plugin looks for
105
+ a PNG file inside the `covers_dir` whose file name will be the
106
+ category/post slug.
107
+
108
+ Since 0.2.0, there's also support for PDF covers. If you have a PNG
109
+ cover, it will get converted to PDF. You can also provide a PDF cover
110
+ as long as it's the same file name as the PNG cover.
111
+
112
+ * Category cover: `assets/covers/the_category_slug.png`
113
+ * PDF cover: `assets/covers/the_slug.pdf`
114
+
115
+ ### Paper sizes
116
+
117
+ For PDFs, each article can have a `papersize` and a `sheetsize`. The
118
+ `papersize` indicates the page size, and the `sheetsize` indicates the
119
+ pages per fold size.
120
+
121
+ Only A* sizes from A7 to A0 are supported for now.
122
+
123
+ ---
124
+ papersize: a5paper
125
+ sheesize: a4paper
126
+ ---
127
+
128
+ This example will generate a 2 pages per A4 sheet.
129
+
130
+ ### Bundled articles
131
+
132
+ If articles share a category, the generator will create a PDF book
133
+ including all of them. The name of the category will become the title
134
+ of the book.
135
+
136
+ ---
137
+ category: [ 'En Defensa del Software Libre #0' ]
138
+ ---
139
+
140
+ The papersize will be the `papersize` of the first article found or the
141
+ default papersize on the `_config.yml` file. Same applies for
142
+ `sheetsize`.
143
+
144
+ NOTE: Authorship will be set to empty. This could change in the future.
145
+
146
+ ## Bibliography
147
+
148
+ If you have bibliography, pandoc recommends leaving an empty
149
+ section at the end of the document if you want to have a separate
150
+ section for it. For bundled articles, this plugin will remove the extra
151
+ sections and create one for everything at the end.
152
+
153
+ # Bibliography
154
+
155
+ <EOF>
156
+
157
+ You can also use the underlined version of the section title (aka
158
+ `settext style` vs `atx style`).
159
+
160
+
161
+ ## Layout
162
+
163
+ Add this liquid snippet on your `_layout/post.html` to generate links to the
164
+ other available formats from the post itself:
165
+
166
+ <ul>
167
+ {% for format in site.pandoc.outputs %}
168
+ {% capture extension %}{{ format | first }}{% endcapture %}
169
+ <li>
170
+ <a href="{{ page.url | remove:'.html' }}.{{ extension }}">
171
+ {{ extension }}
172
+ </a>
173
+ </li>
174
+ {% endfor %}
175
+ </ul>
176
+
177
+ ## How to install
178
+
179
+ Add this snippet to your `_config.yml` on jekyll 1.3
180
+
181
+ gems: [ 'jekyll-pandoc-multiple-formats' ]
182
+
183
+ Alternative, see
184
+ [here](https://github.com/fauno/jekyll-pandoc-multiple-formats/issues/7).
185
+
186
+
187
+ ## How to run
188
+
189
+ Execute `jekyll build` normally :D
190
+
data/Rakefile ADDED
@@ -0,0 +1,13 @@
1
+ require "bundler/gem_tasks"
2
+ Bundler.setup(:default, :development, :test)
3
+
4
+ require 'rake'
5
+ require 'rake/testtask'
6
+
7
+ Rake::TestTask.new(:test) do |test|
8
+ test.libs << 'lib' << 'test'
9
+ test.pattern = 'test/**/test_*.rb'
10
+ test.verbose = true
11
+ end
12
+
13
+ task :default => 'test'
data/bin/imponer ADDED
@@ -0,0 +1,62 @@
1
+ #!/usr/bin/env ruby
2
+ # Copyright (c) 2012-2015 Nicolás Reynolds <fauno@endefensadelsl.org>
3
+ # 2012-2013 Mauricio Pasquier Juan <mpj@endefensadelsl.org>
4
+ # 2013 Brian Candler <b.candler@pobox.com>
5
+ #
6
+ # Permission is hereby granted, free of charge, to any person obtaining
7
+ # a copy of this software and associated documentation files (the
8
+ # "Software"), to deal in the Software without restriction, including
9
+ # without limitation the rights to use, copy, modify, merge, publish,
10
+ # distribute, sublicense, and/or sell copies of the Software, and to
11
+ # permit persons to whom the Software is furnished to do so, subject to
12
+ # the following conditions:
13
+ #
14
+ # The above copyright notice and this permission notice shall be
15
+ # included in all copies or substantial portions of the Software.
16
+ #
17
+ # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
18
+ # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
+ # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20
+ # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
21
+ # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
22
+ # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
23
+ # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24
+
25
+
26
+ file = ARGV.first
27
+ exit if not File.exist? file
28
+
29
+ # Los temporales tiene un sufijo -tmp
30
+ file_tmp = file.gsub(/\.pdf$/, '-tmp.pdf')
31
+ # Los definitivos -tmp-imposed
32
+ file_imp = file.gsub(/\.pdf$/, '-tmp-imposed.pdf')
33
+
34
+ # Cantidad de páginas
35
+ pages = `pdfinfo '#{file}' | grep '^Pages:' | cut -d: -f2 | tr -d ' '`.to_i
36
+
37
+ # Encontramos el múltiplo de 4 más cercano a la cantidad de páginas
38
+ pages4 = ((pages+3)/4)*4.to_i
39
+ # y luego el múltiplo de 4 más cercano al dividir la cantidad de páginas
40
+ # por dos (porque cada hoja tiene dos mitades del libro)
41
+ pages8 = ((pages4/2+3)/4*4).to_i
42
+
43
+ # Creamos la imposición de páginas para A5
44
+ `pdfjam --vanilla \
45
+ --outfile "#{File.dirname file}" \
46
+ --paper a5paper \
47
+ --suffix tmp \
48
+ --landscape \
49
+ --signature #{pages4} \
50
+ "#{file}"`
51
+
52
+ # Y luego lo dividimos por la mitad y hacemos 2x2 en A4
53
+ `pdfjam --vanilla \
54
+ --outfile "#{File.dirname file}" \
55
+ --paper a4paper \
56
+ --suffix imposed \
57
+ --no-landscape \
58
+ --signature #{pages8} \
59
+ "#{file_tmp}"`
60
+
61
+ `rm -v "#{file_tmp}"`
62
+ `mv -v "#{file_imp}" "#{file_imp.gsub /-tmp/, ''}"`
@@ -0,0 +1,29 @@
1
+ # encoding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'jekyll-pandoc-multiple-formats-jekyll34/version'
5
+
6
+ Gem::Specification.new do |gem|
7
+ gem.name = 'jekyll-pandoc-multiple-formats-jekyll34'
8
+ gem.version = JekyllPandocMultipleFormats::VERSION
9
+ gem.authors = ['윤병익']
10
+ gem.email = ['by_yeun@daum.net']
11
+ gem.description = %q{This is a fork of the original "jekyll-pandoc-multiple-formats" to update dependencies. This jekyll plugin was inspired by
12
+ jekyll-pandoc-plugin but it was changed to generate multiple outputs,
13
+ rather than just using pandoc to generate jekyll html posts. Besides,
14
+ it doesn't require the 'pandoc-ruby' gem.}
15
+ gem.summary = %q{Use pandoc on jekyll to generate posts in multiple formats}
16
+ gem.license = 'MIT'
17
+
18
+ gem.files = `git ls-files`.split($/)
19
+ gem.executables = gem.files.grep(%r{^bin/}).map{ |f| File.basename(f) }
20
+ gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
21
+ gem.require_paths = ['lib']
22
+
23
+ gem.add_dependency('jekyll', '>= 3.4')
24
+ gem.add_dependency('pdf_info', '>= 0.5')
25
+ gem.add_dependency('rtex', '>= 2.1')
26
+ gem.add_development_dependency('rake', '>= 12.0.0')
27
+ gem.add_development_dependency('minitest', '>= 5.10.0')
28
+ gem.add_development_dependency('shoulda', '~> 3.5.0')
29
+ end
@@ -0,0 +1,37 @@
1
+ # Copyright (c) 2012-2015 Nicolás Reynolds <fauno@endefensadelsl.org>
2
+ # 2012-2013 Mauricio Pasquier Juan <mpj@endefensadelsl.org>
3
+ # 2013 Brian Candler <b.candler@pobox.com>
4
+ #
5
+ # Permission is hereby granted, free of charge, to any person obtaining
6
+ # a copy of this software and associated documentation files (the
7
+ # "Software"), to deal in the Software without restriction, including
8
+ # without limitation the rights to use, copy, modify, merge, publish,
9
+ # distribute, sublicense, and/or sell copies of the Software, and to
10
+ # permit persons to whom the Software is furnished to do so, subject to
11
+ # the following conditions:
12
+ #
13
+ # The above copyright notice and this permission notice shall be
14
+ # included in all copies or substantial portions of the Software.
15
+ #
16
+ # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23
+
24
+ require 'open3'
25
+
26
+ require 'jekyll-pandoc-multiple-formats-jekyll34/version'
27
+ require 'jekyll-pandoc-multiple-formats-jekyll34/config'
28
+
29
+ # TODO this may go to a separate gem
30
+ require 'jekyll-pandoc-multiple-formats-jekyll34/printer'
31
+ require 'jekyll-pandoc-multiple-formats-jekyll34/imposition'
32
+ require 'jekyll-pandoc-multiple-formats-jekyll34/binder'
33
+ require 'jekyll-pandoc-multiple-formats-jekyll34/unite'
34
+
35
+ require 'jekyll-pandoc-multiple-formats-jekyll34/pandoc_file'
36
+ require 'jekyll-pandoc-multiple-formats-jekyll34/generator'
37
+ require 'jekyll-pandoc-multiple-formats-jekyll34/converter'
@@ -0,0 +1,45 @@
1
+ # Copyright (c) 2012-2015 Nicolás Reynolds <fauno@endefensadelsl.org>
2
+ # 2012-2013 Mauricio Pasquier Juan <mpj@endefensadelsl.org>
3
+ # 2013 Brian Candler <b.candler@pobox.com>
4
+ #
5
+ # Permission is hereby granted, free of charge, to any person obtaining
6
+ # a copy of this software and associated documentation files (the
7
+ # "Software"), to deal in the Software without restriction, including
8
+ # without limitation the rights to use, copy, modify, merge, publish,
9
+ # distribute, sublicense, and/or sell copies of the Software, and to
10
+ # permit persons to whom the Software is furnished to do so, subject to
11
+ # the following conditions:
12
+ #
13
+ # The above copyright notice and this permission notice shall be
14
+ # included in all copies or substantial portions of the Software.
15
+ #
16
+ # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23
+
24
+ module JekyllPandocMultipleFormats
25
+ class Binder < Printer
26
+ def initialize(file, papersize = nil, sheetsize = nil, extra_options = nil)
27
+ super
28
+ @output_file = file.gsub(/\.pdf\Z/, '-binder.pdf')
29
+
30
+ render_template
31
+ self
32
+ end
33
+
34
+ def to_nup
35
+ @pages.times.map{|i|i+1}.map do |page|
36
+ sheet=[]
37
+ @nup.times do
38
+ sheet << page
39
+ end
40
+
41
+ sheet
42
+ end.flatten
43
+ end
44
+ end
45
+ end
@@ -0,0 +1,40 @@
1
+ module JekyllPandocMultipleFormats
2
+ class Config
3
+ DEFAULTS = {
4
+ 'skip' => false,
5
+ 'bundle_permalink' => ':output_ext/:slug.:output_ext',
6
+ 'papersize' => 'a5paper',
7
+ 'sheetsize' => 'a4paper',
8
+ 'imposition' => true,
9
+ 'binder' => true,
10
+ 'signature' => 20,
11
+ 'flags' => '--smart',
12
+ 'site_flags' => '--toc',
13
+ 'outputs' => {},
14
+ 'covers_dir' => 'images/'
15
+ }
16
+
17
+ attr_accessor :config
18
+
19
+ def initialize(config = {})
20
+ @config = Jekyll::Utils.deep_merge_hashes(DEFAULTS, config)
21
+ end
22
+
23
+ def skip?
24
+ @config['skip']
25
+ end
26
+
27
+ def imposition?
28
+ @config['imposition']
29
+ end
30
+
31
+ def binder?
32
+ @config['binder']
33
+ end
34
+
35
+ # TODO magic
36
+ def outputs
37
+ @config['outputs']
38
+ end
39
+ end
40
+ end