X-Git-Url: https://pere.pagekite.me/gitweb/text-madewithcc.git/blobdiff_plain/8446dad9043a00d78a23ba79d0789b888e892442..ed8ec7f588b659b3ff328190bf705cb0bb0f5b78:/fixup-docbook.rb diff --git a/fixup-docbook.rb b/fixup-docbook.rb index 884450f..1abfc9c 100755 --- a/fixup-docbook.rb +++ b/fixup-docbook.rb @@ -30,16 +30,16 @@ end log 0, 'replace article* with book*' xml.css('articleinfo').each do |node| node.name = 'bookinfo' - node.first_element_child.before(<<'XML') - - Gunnar Wolf -
Mexico City
-
-XML - node.first_element_child.before(<<'XML') + node.last_element_child.after(<<'XML') 2017 Creative Commons + +XML + node.last_element_child.after(<<'XML') + + Instituto de Investigaciones Económicas +
Universidad Nacional Autónoma de México
XML end @@ -51,10 +51,10 @@ end log 0, 'change parts to colophon, dedication and chapter' partreplace(xml, 'colophon', 'colophon') partreplace(xml, 'dedication', 'dedication') -partreplace(xml, 'foreword', 'chapter') -partreplace(xml, 'introduction', 'chapter') -partreplace(xml, 'bibliography', 'chapter') -partreplace(xml, 'acknowledgments', 'chapter') +partreplace(xml, 'foreword', 'preface') +partreplace(xml, 'introduction', 'preface') +partreplace(xml, 'bibliography', 'appendix') +partreplace(xml, 'acknowledgments', 'appendix') log 0, 'place part introduction into ' s = xml.xpath("//part/title[text()='The Case Studies']")[0] @@ -66,6 +66,190 @@ if s end end + +log 0, 'remove empty notes/web links sections' +[ + 'Notes', + 'Web links', + 'Web link', +].each do |title| + xml.xpath("//title[text()='%s']" % title).each do |node| + p = node.parent + node.remove + if p.content =~ /^\s*$/ + p.remove + else + raise RuntimeError, 'Non-empty «%s» found' % title + end + end +end + +log 0, 'remove title from dedication' +if ! xml.css('dedication title').empty? + xml.css('dedication title')[0].content = "" +end + +log 0, 're-styling dedication, preface and introduction authors' +xml.css('dedication').each do |ded| +# Take content out of the quote marks, and into the blockquote + quote = ded.css('quote').first + auth = ded.css('itemizedlist').first + quote_c = quote.content + auth_c = auth.content + # Styling the attribution (including the introducing hyphen) should + # be left to the following layers + auth_c.gsub!(/\s+/, ' ') + c = ded.css('quote').first.content + quote.parent.remove # remove the '' containing the quote + auth.remove + ded.last_element_child.after('
%s%s
' % + [auth_c, quote_c]) +end + +%w(preface#foreword preface#introduction).each do |spec| + sect = xml.css(spec)[0] + paras = sect.css('para emphasis') + auth = '
' + auth += paras.map{|p| p.content}.join(', ') + auth += '
' + sect.last_element_child.after(auth) + paras.each {|i| i.parent.remove} # Remove both the 'emphasis' and its parent 'para' +end + +auth = xml.css('chapter')[0].css('para')[0] +auth.content =~ /^\s*Paul Stacey\s*$/ or + raise RuntimeError, 'Error finding author name in chapter 1 -- ' + auth.content +auth.before('
Paul Stacey
') +auth.remove + +auth = xml.css('chapter')[1].css('para')[0] +auth.content =~ /^\s*Sarah Hinchliff Pearson.*$/ or + raise RuntimeError, 'Error finding author name in chapter 2 -- ' + auth.content +auth.before('
Sarah Hinchliff Pearson
') +auth.remove + +log 0, 'move legal notice to bookinfo' +xml.css('book bookinfo')[0].last_element_child.after('') +ln = xml.css('book bookinfo legalnotice')[0] +xml.css('para').each do |para| + if para.content =~ /This book is published under a/ + log 0, 'found legal' + para.parent = ln + break + end +end + +log 0, 'replace colophon page with one for this edition' + xml.xpath('//colophon/para').remove +s = xml.xpath('//colophon')[0] +s.first_element_child.after(<<'XML') +Made with Creative Commons by Paul Stacey and Sarah Hinchliff Pearson + +© 2017 by the Creative Commons Foundation. + +Published under a Creative Commons Attribution-ShareAlike +license (CC BY-SA), version 4.0. + +The license means that you can copy, redistribute, remix, +transform, and build upon the content for any purpose, even +commercially, as long as you give appropriate credit, provide a link +to the license, and indicate if changes were made. If you remix, +transform, or build upon the material, you must distribute your +contributions under the same license as the original. License details: + + +Illustrations by Bryan Mathers, +. + +Publisher: Gunnar Wolf. + + + +  + + +Made With Creative Commons was originally published with the +kind support of Creative Commons and backers of our +crowdfunding-campaign on the Kickstarter.com platform. + +This edition of the book is maintained on +, and the +translations are maintained on +. If +you find any error in the book, please let us know. + +ISBN: YET-TO-BE-DECIDED (PDF), YET-TO-BE-DECIDED (ePub), +YET-TO-BE-DECIDED (Paperback) + + + + +(Dewey) 346.048, 347.78 + + + +(US Library of Congress) Z286 O63 S73 2017 + + + +(Melvil) 025.523 + + +XML + +log 0, 'remove title from colophon' +xml.css('colophon title')[0].content = "" + +log 0, 'change CC logo images to informalfigure' +xml.css('figure mediaobject imageobject imagedata[width="40.0%"]').each do |id| + f = id.parent.parent.parent + f.name = 'informalfigure' +end + +log 0, 'assigning IDs to formal figures' +seq = 1 +xml.css('figure').each do |fig| + fig['id'] = 'fig-%d' % seq + seq = seq + 1 +end + +log 0, 'Set epigraph line in each case study' +xml.css('blockquote para').select {|p| p.inner_text =~ /Profile written by/}.each do |epi| + p = epi.parent + by = epi.inner_text + epi.remove + p.first_element_child.before('%s
' % by) +end + + +# Disabled as dblatex do not understand chapter/chapterinfo/author, +# see . +if false +log 0, 'migrate chapter author into where relevant' +xml.css('chapter para').each do |para| + if para.content =~ /^\s*((Paul|Sarah Hinchliff) (Stacey|Pearson))\s*$/ + log 1, 'migrated %s %s' % [$2, $3] + para.parent.css('title')[0].before(<<'XML' % [$2, $3]) + + + %s%s + + +XML + para.remove + end +end +end + +log 0, 'replace "Fig. \#." with docbook figure xref' +xml.css("para").each do |para| + xml_text = para.to_xml(:skip_instruct => true).to_s + xml_text.gsub!(/Fig\.\s+(\d)\.?/, + 'Fig. ') + para.after(xml_text) + para.remove +end + log 0, 'Writing processed file' # Unable to figure out API way to replace DOCTYPE data = xml.to_xml().gsub!(/DOCTYPE article/, 'DOCTYPE book')