]> pere.pagekite.me Git - text-madewithcc.git/blobdiff - fixup.rb
Reinsert UTF-8 enabling LaTeX editing.
[text-madewithcc.git] / fixup.rb
index b96f66625f40c4811713176a39df51bfe25ee169..17bf82b34724ecef667256acf3ec9e3a766e3271 100644 (file)
--- a/fixup.rb
+++ b/fixup.rb
@@ -27,6 +27,7 @@ log 0, 'Merging multiline sentences '
   ['Providing a custom service to consumers of your work *', '\[MARKET-BASED\]*'],
   ['Memberships and individual donations', '*\[RECIPROCITY-BASED\]*'],
   ['The', '', 'Creative', '', 'Commons', '', 'Licenses'],
+  ['jonathanmann.net and', '', 'jonathanmann.bandcamp.com'],
   ['PLOS','', '(Public Library of Science)']
 ].each do |str|
   # This should be done more generic, more robust... But before
@@ -62,6 +63,15 @@ log 0, 'Merging multiline sentences '
   (str.size - 1).times { data.delete_at(at+1) }
 end
 
+log 0, 'correct emphesis in some titles'
+data.map {|lin| lin.gsub!(/ *\* \\\[/, ' *\[')}
+
+log 0, 'tag title and author'
+data.delete_at(1) # Remove unwanted blank line between title and authors
+data[0].sub!(/^/, '% ') # title
+data[1].sub!(/^/, '% ') # authors
+data[1].sub!(/ and /, ';') # authors
+
 # Mark up headings: Very artisanal and suboptimal, but should do the
 # trick.
 #
@@ -76,8 +86,8 @@ end
 # Try to keep this ordered as it appears within the book, as it will
 # help us spot omissions and mistakes!
 log 0, 'Mark up headings'
-[ [2, 'Foreword'],
-  [2, 'Introduction'],
+[ [1, 'Foreword'],
+  [1, 'Introduction'],
   [1, 'Part 1'],
   [1, 'The Big Picture'],
   [2, 'The New World of Digital Commons'],
@@ -103,15 +113,15 @@ log 0, 'Mark up headings'
   [4, 'Use CC to differentiate yourself'],
   [3, 'Making Money'],
   [4, 'Market-based revenue streams'],
-  [4, 'Providing a custom service to consumers of your work * \[MARKET-BASED\]*'],
-  [4, 'Charging for the physical copy * \[MARKET-BASED\]*'],
-  [4, 'Charging for the in-person version * \[MARKET-BASED\]*'],
-  [4, 'Selling merchandise * \[MARKET-BASED\]*'],
-  [4, 'Charging advertisers or sponsors * \[MARKET-BASED\]*'],
-  [4, 'Charging your content creators * \[MARKET-BASED\]*'],
-  [4, 'Charging a transaction fee * \[MARKET-BASED\]*'],
-  [4, 'Providing a service to your creators\[MARKET-BASED\]*'],
-  [4, 'Licensing a trademark\[MARKET-BASED\]*'],
+  [4, 'Providing a custom service to consumers of your work *\[MARKET-BASED\]*'],
+  [4, 'Charging for the physical copy *\[MARKET-BASED\]*'],
+  [4, 'Charging for the in-person version *\[MARKET-BASED\]*'],
+  [4, 'Selling merchandise *\[MARKET-BASED\]*'],
+  [4, 'Charging advertisers or sponsors *\[MARKET-BASED\]*'],
+  [4, 'Charging your content creators *\[MARKET-BASED\]*'],
+  [4, 'Charging a transaction fee *\[MARKET-BASED\]*'],
+  [4, 'Providing a service to your creators *\[MARKET-BASED\]*'],
+  [4, 'Licensing a trademark *\[MARKET-BASED\]*'],
   [4, 'Reciprocity-based revenue streams'],
   [4, 'Memberships and individual donations *\[RECIPROCITY-BASED\]*'],
   [4, 'The pay-what-you-want model *\[RECIPROCITY-BASED\]*'],
@@ -125,7 +135,7 @@ log 0, 'Mark up headings'
   [4, 'Build a community'],
   [4, 'Give more to the commons than you take'],
   [4, 'Involve people in what you do'],
-  [4, 'Notes'],
+  [3, 'Notes'],
   [2, 'The Creative Commons Licenses'],
   [1, 'Part 2'],
   [1, 'The Case Studies'],
@@ -149,12 +159,12 @@ log 0, 'Mark up headings'
   [2, 'Rijksmuseum'],
   [2, 'Shareable'],
   [2, 'Siyavula'],
-  [2, 'Sparkfun'],
+  [2, 'SparkFun'],
   [2, 'TeachAIDS'],
   [2, 'Tribe of Noise'],
   [2, 'Wikimedia Foundation'],
-  [2, 'Bibliography'],
-  [2, 'Acknowledgments'],
+  [1, 'Bibliography'],
+  [1, 'Acknowledgments'],
   
 ].each do |item|
   log 1, item.join(' -> ')
@@ -165,7 +175,17 @@ log 0, 'Mark up headings'
   data[at] = '%s %s' % ['#' * item[0], data[at]]
 end
 
+# We have the explicit strings "Part 1" and "Part 2" as structural
+# elements — They are to be generated upon book compilation. Nuke
+# them.
+data.delete("# Part 1")
+data.delete("# Part 2")
 
+log 0, 'add heading to colophon page'
+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 {-}')
 
 # Join erroneously split paragraphs: Write the contents of the line
 # _preceding_ the unneeded break, the break will be removed.
@@ -210,5 +230,73 @@ log 0, 'Join erroneously split paragraphs'
   end
 end
 
+log 0, 'Mark quote in dedication as quote with attribute in markdown'
+start = "“I don’t know a whole lot about nonfiction journalism. . ."
+stop = "- David Foster Wallace"
+quote=false
+data.each_with_index do |lin, idx|
+  if lin == stop
+    lin.sub!(/^- /, "> — ")
+    lin.sub!("David Foster Wallace", "*David Foster Wallace*")
+    quote=false
+    break
+  end
+  if lin == start
+    quote=true
+  end
+  if quote
+    lin.sub!(/^/, "> ")
+  end
+end
+
+log 0, 'Identify and mark footnotes/endnodes'
+scope="unknown"
+noteblock=false
+data.each_with_index do |lin, idx|
+  if lin =~ /^## (.+)$/
+    scope=$1.gsub(" ", "-")
+  end
+  # First, mark note reference
+  lin.sub!(/([a-z]\.["”]?)(\d+)(\s)/, "\\1[^" + scope + "-\\2]\\3")
+  lin.sub!(/([a-z]\.["”]?)(\d+)$/, "\\1[^" + scope + "-\\2]")
+  # Next, mark note content, only between /Web Links?|Notes/ and next heading
+  if noteblock
+    lin.sub!(/^(\d+)\. /, "[^" + scope + "-\\1]: ")
+    if lin =~ /^##?.+/
+      noteblock=false
+    end
+  end
+  if lin =~ /^(### Notes|Web links?)/
+    noteblock=true
+  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, 'Writing processed file'
 File.open(dstfile, 'w') {|f| f.puts data.join("\n")}