X-Git-Url: https://pere.pagekite.me/gitweb/text-madewithcc.git/blobdiff_plain/6298b20bcba9fede86b50b51e0b45e6ea74dc05c..2d5e52ac1ff23e3971f8ecc48bfd2915b69f15a6:/fixup.rb diff --git a/fixup.rb b/fixup.rb index b96f666..cffbab3 100644 --- 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,79 @@ 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, '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, 'Writing processed file' File.open(dstfile, 'w') {|f| f.puts data.join("\n")}