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.
'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
'license', # 6169
'authors and Shuttleworth; Mark remains incredibly proud of this', # 6452
'BY-SA and opting in others with collecting societies like', # 7218
+ 'Journeys to a Generative Economy. San Francisco:', # 7553
'Cecilie Maria, Cedric Howe, Cefn Hoile,', # 7796
'Braddlee, Drew Spencer, Duncan', # 7839
'Elizabeth Holloway, Ellen Buecher, Ellen Kaye-', # 7844
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]")
+ lin.sub!(/([a-z][\.\)]+["”]?)(\d+)(\s)/, "\\1[^" + scope + "-\\2]\\3")
+ lin.sub!(/([a-z][\.\)]+["”]?)(\d+)$/, "\\1[^" + scope + "-\\2]")
+ # Special case some refs hard to match otherwise
+ lin.sub!(/(section.\)) 36 /, "\\1[^" + scope + "-36] ")
+ lin.sub!(/(Data Futures Forum in 2014,)1 /, "\\1[^" + scope + "-1] ")
+ lin.sub!(/(5,080)5/, "\\1[^" + scope + "-5]")
+ lin.sub!(/(sustain her creative work.) 1/, "\\1[^" + scope + "-1]")
# Next, mark note content, only between /Web Links?|Notes/ and next heading
if noteblock
lin.sub!(/^(\d+)\. /, "[^" + scope + "-\\1]: ")
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
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'],
+ ['10000201000008000000045C30360249076453E6.png', 'Enterprise engagement with commons, state and market.'],
+ ['10000201000007D0000007D0ACF13F8B71EAF0B9.png', 'Four aspects of resource management'],
+ ['10000201000009C40000065D9EC4F530BD4DFBE0.png', 'How the market, commons and state concieve of resources.'],
+ ['10000201000009C4000005153EACBD62F00F6BA9.png', 'In preindustrialized society.'],
+ ['10000201000009C4000005150F069409C1CC12F0.png', 'The commons is gradually superseded by the state.'],
+ ['10000201000009C400000515F1CAA15B223F6BAF.png', 'How the market, the state and the commons look today.'],
].each do |fig|
at = data.index {|i| i.include? fig[0]}
if at.nil?
data[at].gsub!(/!\[\]\(Pictures/, '
end
+log 0, 'adding http:// to all URLs and turn them into links'
+data.map {|lin| lin.gsub!(/(^|\s+)([-a-z0-9\\.]+\.(ca|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")}