X-Git-Url: https://pere.pagekite.me/gitweb/text-madewithcc.git/blobdiff_plain/72a5cd26ba8c53910f3cbd1df4184d193139b4d6..482a5887358fd1618db1936f1a6b245b89ee01a4:/fixup.rb?ds=inline diff --git a/fixup.rb b/fixup.rb index 8e8f670..e58f232 100644 --- a/fixup.rb +++ b/fixup.rb @@ -86,8 +86,8 @@ data[1].sub!(/ and /, ';') # authors # 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'], @@ -163,8 +163,8 @@ log 0, 'Mark up headings' [2, 'TeachAIDS'], [2, 'Tribe of Noise'], [2, 'Wikimedia Foundation'], - [2, 'Bibliography'], - [2, 'Acknowledgments'], + [1, 'Bibliography'], + [1, 'Acknowledgments'], ].each do |item| log 1, item.join(' -> ') @@ -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. @@ -249,5 +249,76 @@ data.each_with_index do |lin, idx| 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/, '![%s](Pictures' % fig[1]) +end + log 0, 'Writing processed file' File.open(dstfile, 'w') {|f| f.puts data.join("\n")}