X-Git-Url: https://pere.pagekite.me/gitweb/text-madewithcc.git/blobdiff_plain/d9532a0a236ce93f3e5116516874677843c55200..3a4bd75be002c79ae2ba3f68b62598dc1ef7d93f:/fixup.rb diff --git a/fixup.rb b/fixup.rb index ba204c2..4561ab7 100644 --- 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. @@ -201,6 +201,7 @@ log 0, 'Join erroneously split paragraphs' 'the kinds of participative communities that drive open', # 2157 'time', # 2220 'At a minimum, a CC-', # 2375 + '“Share Your Work” at', # 2508 'easier to trust a', # 2580 'free download, the', # 3086 'openness to fans remixing the game—give', # 3087 @@ -268,6 +269,30 @@ data.each_with_index do |lin, idx| end if lin =~ /^(### Notes|Web links?)/ noteblock=true + # Turn web link line into section header, to make it easier to + # find by fixup-docbook.rb. + lin.gsub!(/^(Web links?)/, "### \\1") + end +end + +log 0, 'verify every footnote/endnote is unique and used' +notes = Hash.new +data.each_with_index do |lin, idx| + if lin =~ /(\[\^[^\]]+\])(:)?/ +# log 0, "*** found %s %s" % [$1, $2] + if not notes.has_key?($1) + notes[$1] = Hash.new + end + if $2 == ':' + notes[$1]['def'] = true + else + notes[$1]['ref'] = true + end + end +end +notes.each do |key, val| + if val.has_key?('def') != val.has_key?('ref') + log 0, "error: check use of footnote %s" % key end end @@ -304,5 +329,25 @@ 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, 'adding http:// to all URLs and turn them into links' +data.map {|lin| lin.gsub!(/(^|\s+)([-a-z0-9\\.]+\.(cc|com|edu|eu|io|is|it|kr|net|nl|nz|org|se))/, '\\1http://\\2')} +data.map {|lin| lin.gsub!(/\b(https?:\/\/[-a-z0-9\\.]+)(\/[-\\.\/a-zA-Z0-9#_\?&=,]+[-\/a-zA-Z0-9#_\?&=,])?/, '[](\\1\\2)')} + log 0, 'Writing processed file' File.open(dstfile, 'w') {|f| f.puts data.join("\n")}