(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.
#
# 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'],
[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\]*'],
[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(' -> ')
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.
#
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, '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/, '
+end
+
log 0, 'Writing processed file'
File.open(dstfile, 'w') {|f| f.puts data.join("\n")}