]> pere.pagekite.me Git - text-madewithcc.git/blobdiff - fixup.rb
Add figure titles to cross referable figures in markdown, and remove workaround for...
[text-madewithcc.git] / fixup.rb
index 41e317d27e0f8c7b49e24875302b5407cdac1f16..e58f23248befb13f726f4487de14f6b37e3b9980 100644 (file)
--- a/fixup.rb
+++ b/fixup.rb
@@ -182,10 +182,10 @@ data.delete("# Part 1")
 data.delete("# Part 2")
 
 log 0, 'add heading to colophon page'
-data.insert(data.index('Made With Creative Commons'), '## Colophon {-}')
+data.insert(data.index('Made With Creative Commons'), '# Colophon {-}')
 
 log 0, 'add dedication as separeate chapter'
-data.insert(data.index('“I don’t know a whole lot about nonfiction journalism. . .'), '## Dedication {-}')
+data.insert(data.index('“I don’t know a whole lot about nonfiction journalism. . .'), '# Dedication {-}')
 
 # Join erroneously split paragraphs: Write the contents of the line
 # _preceding_ the unneeded break, the break will be removed.
@@ -271,5 +271,54 @@ data.each_with_index do |lin, idx|
   end
 end
 
+log 0, 'Turn indented block after use cases into block quotes'
+inscope=false
+quote=false
+data.each_with_index do |lin, idx|
+  if quote
+    lin.sub!(/^/, "> ")
+  end
+  if lin =~ /^> Profile written by/
+    quote=false
+  end
+  # To this heading
+  if lin =~ /^## Bibliography/
+    inscope=false
+  end
+  # From this heading
+  if lin =~ /^## Arduino/
+    inscope=true
+  end
+  if inscope and lin =~ /^## /
+    quote=true
+    next
+  end
+end
+
+log 0, 'emphesize keywords'
+data.map {|lin| lin.gsub!(/^(>\s*)(Revenue model|Interview date|Interviewees?):/, '\\1**\\2**:')}
+
+log 0, 'make figure sizes relative to text body width while keeping aspect ratio'
+data.map {|lin| lin.gsub!(/width="6.5in"/, 'width="100%"')}
+data.map {|lin| lin.gsub!(/width="4.198in"/, 'width="40%"')}
+data.map {|lin| lin.gsub!(/width="4.1665in"/, 'width="40%"')}
+data.map {|lin| lin.gsub!(/height="[0-9.]+in"/, '')}
+
+log 0, 'add figure titles required by Docbook for referable figures'
+[
+  ['10000201000008000000045C30360249076453E6.png', 'Enterprise engagements'],
+  ['10000201000007D0000007D0ACF13F8B71EAF0B9.png', 'Aspects of resource management'],
+  ['10000201000009C40000065D9EC4F530BD4DFBE0.png', 'Different views on resources'],
+  ['10000201000009C4000005153EACBD62F00F6BA9.png', 'Long ago'],
+  ['10000201000009C4000005150F069409C1CC12F0.png', 'State takeover of the commons'],
+  ['10000201000009C400000515F1CAA15B223F6BAF.png', 'Today'],
+].each do |fig|
+  at = data.index {|i| i.include? fig[0]}
+  if at.nil?
+    raise RuntimeError, 'No figure named «%s» found' % fig[0]
+  end
+  data[at].gsub!(/!\[\]\(Pictures/, '![%s](Pictures' % fig[1])
+end
+
 log 0, 'Writing processed file'
 File.open(dstfile, 'w') {|f| f.puts data.join("\n")}