diff options
| author | Ralph Amissah <ralph@amissah.com> | 2014-07-11 00:09:02 -0400 | 
|---|---|---|
| committer | Ralph Amissah <ralph@amissah.com> | 2014-07-11 00:24:46 -0400 | 
| commit | 86ce218124eeca073621a153c5f3f830a90f1a74 (patch) | |
| tree | 0ffc6019dd08647cfe03733532c7d956c202ed1b | |
| parent | v5 v6: ao_composite, variable name (diff) | |
v5 v6: ao_composite, nested includes, .ssi (insert) can now include .ssi & .sst
* .ssm can contain/include .sst or .ssi
  .sst files can be processed independently, they do not contain other files
  .ssi files have been only insertions of text & are not processed independently
  but as part of an ssm
  change proposed:
  .ssm unchanged,
  .sst unchanged,
  .ssi as before, but can include .sst or .ssi, so:
  files are only insertions & are not processed independently but as part of an
  .ssm or another .ssi
  i.e. as before with the addition that it like a .ssm can contain/include
  .sst or .ssi
* requested feature, (Closes: #744408)
  User beware. In previous versions there has been a deliberate attempt to keep
  it easy to follow documents & not have to dig through different levels of
  includes, as this is more likely to lead to errors in markup.
  The idea of nested includes has not been attractive (messy for a document),
  however, this is now made possible, use with care
  * it is not as easy to see document structure at a glance, and structural
    errors may be introduced and will need to be taken care of (requiring
    document markup debugging)
  * allowing .ssi to also include other .ssi or .sst could lead to infinite
    recursion if an .ssi includes another which includes itself; stopping after
    an additional level of includes seems arbitrary, and possibly prone to error
    if you are dealing with many documents
* requires testing
* version bump, new behavior added to .ssi one of the 3 sisu filetypes
| -rw-r--r-- | data/doc/sisu/CHANGELOG_v5 | 29 | ||||
| -rw-r--r-- | data/doc/sisu/CHANGELOG_v6 | 29 | ||||
| -rw-r--r-- | data/doc/sisu/sisu.org | 15 | ||||
| -rw-r--r-- | lib/sisu/v5/ao_composite.rb | 143 | ||||
| -rw-r--r-- | lib/sisu/v6/ao_composite.rb | 143 | 
5 files changed, 226 insertions, 133 deletions
| diff --git a/data/doc/sisu/CHANGELOG_v5 b/data/doc/sisu/CHANGELOG_v5 index ca6fecf2..a87629fa 100644 --- a/data/doc/sisu/CHANGELOG_v5 +++ b/data/doc/sisu/CHANGELOG_v5 @@ -42,6 +42,35 @@ http://www.jus.uio.no/sisu/pkg/src/sisu_5.5.0.orig.tar.xz    * auto name segment, extract "number" from heading, fix    * check that all auto given number based seg names are unique +* ao_composite, nested includes, .ssi (insert) can include .ssi & .sst +~ .ssm can contain/include .sst or .ssi +  .sst files can be processed independently, they do not contain other files +  .ssi files have been only insertions of text & are not processed independently +  but as part of an ssm +  change proposed: +  .ssm unchanged, +  .sst unchanged, +  .ssi as before, but can include .sst or .ssi, so: +  files are only insertions & are not processed independently but as part of an +  .ssm or another .ssi +  i.e. as before with the addition that it like a .ssm can contain/include +  .sst or .ssi +~ requested feature, (Closes: #744408) +  User beware. In previous versions there has been a deliberate attempt to keep +  it easy to follow documents & not have to dig through different levels of +  includes, as this is more likely to lead to errors in markup. +  The idea of nested includes has not been attractive (messy for a document), +  however, this is now made possible, use with care +  ~ it is not as easy to see document structure at a glance, and structural +    errors may be introduced and will need to be taken care of (requiring +    document markup debugging) +  ~ allowing .ssi to also include other .ssi or .sst could lead to infinite +    recursion if an .ssi includes another which includes itself; stopping after +    an additional level of includes seems arbitrary, and possibly prone to error +    if you are dealing with many documents +~ requires testing +~ version bump, new behavior added to .ssi one of the 3 sisu filetypes +  %% 5.4.5.orig.tar.xz (2014-07-07:27/1)  http://sources.sisudoc.org/gitweb/?p=code/sisu.git;a=log;h=refs/tags/sisu_5.4.5  http://sources.sisudoc.org/gitweb/?p=code/sisu.git;a=log;h=refs/tags/debian/sisu_5.4.5-1 diff --git a/data/doc/sisu/CHANGELOG_v6 b/data/doc/sisu/CHANGELOG_v6 index a1e1de70..c4a7d1a9 100644 --- a/data/doc/sisu/CHANGELOG_v6 +++ b/data/doc/sisu/CHANGELOG_v6 @@ -32,6 +32,35 @@ http://www.jus.uio.no/sisu/pkg/src/sisu_6.1.0.orig.tar.xz    * auto name segment, extract "number" from heading, fix    * check that all auto given number based seg names are unique +* ao_composite, nested includes, .ssi (insert) can include .ssi & .sst +~ .ssm can contain/include .sst or .ssi +  .sst files can be processed independently, they do not contain other files +  .ssi files have been only insertions of text & are not processed independently +  but as part of an ssm +  change proposed: +  .ssm unchanged, +  .sst unchanged, +  .ssi as before, but can include .sst or .ssi, so: +  files are only insertions & are not processed independently but as part of an +  .ssm or another .ssi +  i.e. as before with the addition that it like a .ssm can contain/include +  .sst or .ssi +~ requested feature, (Closes: #744408) +  User beware. In previous versions there has been a deliberate attempt to keep +  it easy to follow documents & not have to dig through different levels of +  includes, as this is more likely to lead to errors in markup. +  The idea of nested includes has not been attractive (messy for a document), +  however, this is now made possible, use with care +  ~ it is not as easy to see document structure at a glance, and structural +    errors may be introduced and will need to be taken care of (requiring +    document markup debugging) +  ~ allowing .ssi to also include other .ssi or .sst could lead to infinite +    recursion if an .ssi includes another which includes itself; stopping after +    an additional level of includes seems arbitrary, and possibly prone to error +    if you are dealing with many documents +~ requires testing +~ version bump, new behavior added to .ssi one of the 3 sisu filetypes +  %% 6.0.11.orig.tar.xz (2014-07-07:27/1)  http://sources.sisudoc.org/gitweb/?p=code/sisu.git;a=log;h=refs/tags/sisu_6.0.11  http://sources.sisudoc.org/gitweb/?p=code/sisu.git;a=log;h=refs/tags/debian/sisu_6.0.11-1 diff --git a/data/doc/sisu/sisu.org b/data/doc/sisu/sisu.org index 265abda9..8800572d 100644 --- a/data/doc/sisu/sisu.org +++ b/data/doc/sisu/sisu.org @@ -2247,15 +2247,24 @@ consider,  I have to date deliberately tried to keep it easy to follow documents & not have too much depth ...  The idea of recursive includes is un-attractive (messy for a document) -.ssm currently can contain .sst or .ssi +.ssm currently can contain/include .sst or .ssi  .sst files can be processed independently, -.ssi files are only insertions & cannot +.ssi files are only insertions & are not processed independently but as part of an ssm + +change proposed +.ssm unchanged +.sst unchanged +.ssi as before, but can include .sst or .ssi, so: +  files are only insertions & are not processed independently but as part of an .ssm or another .ssi +  i.e. as before with the addition that it like a .ssm can contain/include .sst or .ssi + +this is pretty much as requested by wishlist 744408  allowing .ssi to also include other .ssi or .sst could lead to recursive .ssi -allowing .ssm to also include other .ssm .ssi or .sst could lead to recursive .ssm  stopping after an additional level of includes seems arbitrary, and possibly prone to error if you are dealing with many documents +***** Discard  a possibility would be to have another file extension to flag the role of the file,  .ssmi (not very attractive) might do it  (providing visual cue signalling its role as both a master file and an insertion/included file that cannot be processed independently) diff --git a/lib/sisu/v5/ao_composite.rb b/lib/sisu/v5/ao_composite.rb index b35b2419..5cdfaa81 100644 --- a/lib/sisu/v5/ao_composite.rb +++ b/lib/sisu/v5/ao_composite.rb @@ -101,9 +101,17 @@ module SiSU_Assemble        begin          pwd=Dir.pwd          Dir.chdir(@opt.f_pth[:pth]) -        fns_array=IO.readlines(@opt.fno,'') -        assembled=insertions?(fns_array) -        write(assembled) +        if @opt.fno =~/\S+?\.ssm$/ +          SiSU_Screen::Ansi.new( +            @opt.act[:color_state][:set], +            'Composite Document', +            "[#{@opt.f_pth[:lng_is]}] #{@opt.fno}", +          ).grey_title_hi unless @opt.act[:quiet][:set]==:on +          assembled=loadfile(@opt.fno) +          #assembled=insertions?(fns_array) +          write(assembled) +          write(assembled) +        end          Dir.chdir(pwd)        rescue          SiSU_Errors::Rescued.new($!,$@,@opt.cmd,@opt.fns).location do @@ -112,6 +120,73 @@ module SiSU_Assemble        ensure        end      end +    def insert?(para) +      if para =~ /^<<\s+((?:https?|file):\/\/\S+?\.ss[it])$/ # and NetTest +        url($1.strip) +      elsif para =~/^<<\s+(\S+?\.ss[it])$/ +        loadfilename=$1.strip +        insert_array=loadfile(loadfilename) +        file=insertion(loadfilename,insert_array) +        file[:prepared] +      else para +      end +    end +    def loadfile(loadfilename) +      tuned_file=[] +      begin +        if FileTest.file?(loadfilename) +          insert_array=IO.readlines(loadfilename,'') +          if loadfilename =~/\S+?\.ss[im]$/ +            if (@opt.act[:verbose][:set]==:on \ +            || @opt.act[:verbose_plus][:set]==:on \ +            || @opt.act[:maintenance][:set]==:on) +              SiSU_Screen::Ansi.new( +                @opt.act[:color_state][:set], +                'loading:', +                loadfilename, +              ).txt_grey +            end +            insert_array.each do |para| +              tuned_file << insert?(para) +            end +          elsif loadfilename =~/\S+?\.sst$/ +            insert_array.each do |para| +              tuned_file << para +            end +          end +        end +        tuned_file=tuned_file.flatten.compact +      rescue +        SiSU_Errors::Rescued.new($!,$@,@opt.cmd,@opt.fns).location do +          __LINE__.to_s + ':' + __FILE__ +        end +      ensure +      end +    end +    def url(loadfilename) +      if loadfilename =~ /((?:https?|file):\/\/\S+?\.ss[it])$/ # and NetTest +        loadfilename=$1 +        imagedir = /((?:https?|file):\/\/\S+?)\/[^\/]+?\.ss[it]$/. +          match(loadfilename).captures.join + +          '/_sisu/image' #watch +        begin +          require 'uri' +          require 'open-uri' +          require 'pp' +        rescue LoadError +          SiSU_Utils::CodeMarker.new(__LINE__,__FILE__,:fuchsia). +            error('uri, open-uri or pp NOT FOUND (LoadError)') +        end +        image_uri=URI.parse(imagedir) +        insert=open(loadfilename) +        insert_array=insert.dup +        insert.close +        file=insertion(loadfilename,insert_array) +        @@imager[image_uri] ||=[] +        @@imager[image_uri] << file[:images] +        file[:prepared] +      end +    end      def write(assembled)        assembled_file=File.new("#{@env.processing_path.composite_file}/#{@opt.fnb}.ssm.sst",'w+')        assembled.each {|a| assembled_file << a } @@ -165,68 +240,6 @@ module SiSU_Assemble        end        file      end -    def insertions?(fns_array) -      tuned_file,imagedir=[],[] -      SiSU_Screen::Ansi.new( -        @opt.act[:color_state][:set], -        'Composite Document', -        "[#{@opt.f_pth[:lng_is]}] #{@opt.fno}", -      ).grey_title_hi unless @opt.act[:quiet][:set]==:on -      fns_array.each do |para| -        if para =~/^<<\s+(\S+?\.ss[it])$/ -          loadfilename=$1.strip -          if (@opt.act[:verbose][:set]==:on \ -          || @opt.act[:verbose_plus][:set]==:on \ -          || @opt.act[:maintenance][:set]==:on) -            SiSU_Screen::Ansi.new( -              @opt.act[:color_state][:set], -              'loading:', -              loadfilename, -            ).txt_grey -          end -          tuned_file << if loadfilename =~ /(?:https?|file):\/\/\S+?\.ss[it]$/ # and NetTest -            imagedir = /((?:https?|file):\/\/\S+?)\/[^\/]+?\.ss[it]$/. -              match(loadfilename).captures.join + -              '/_sisu/image' #watch -            begin -              require 'uri' -              require 'open-uri' -              require 'pp' -            rescue LoadError -              SiSU_Utils::CodeMarker.new(__LINE__,__FILE__,:fuchsia). -                error('uri, open-uri or pp NOT FOUND (LoadError)') -            end -            image_uri=URI.parse(imagedir) -            insert=open(loadfilename) -            insert_array=insert.dup -            insert.close -            file=insertion(loadfilename,insert_array) -            @@imager[image_uri] ||=[] -            @@imager[image_uri] << file[:images] -            file[:prepared] -          elsif loadfilename =~ /\.ss[it]$/ \ -          and FileTest.file?(loadfilename) -            insert_array=IO.readlines(loadfilename,'') -            file=insertion(loadfilename,insert_array) -            file[:prepared] -          else -            STDERR.puts %{SKIPPED processing file: [#{@opt.lng}] "#{@opt.fns}" it requires an invalid or non-existent file: "#{loadfilename}"} -            $process_document = :skip; break #remove this line to continue processing documents that have missing include files -            para -          end -        else tuned_file << para -        end -        tuned_file=tuned_file.flatten.compact -      end -      if @@imager.length >0 -        @@imager.each do |d,i| -          i=i.flatten.uniq -          image_info=d + i -          download_images(image_info.flatten) -        end -      end -      tuned_file -    end    end    class CompositeFileList      @@imager={} diff --git a/lib/sisu/v6/ao_composite.rb b/lib/sisu/v6/ao_composite.rb index efe3815f..078e8ece 100644 --- a/lib/sisu/v6/ao_composite.rb +++ b/lib/sisu/v6/ao_composite.rb @@ -101,9 +101,17 @@ module SiSU_Assemble        begin          pwd=Dir.pwd          Dir.chdir(@opt.f_pth[:pth]) -        fns_array=IO.readlines(@opt.fno,'') -        assembled=insertions?(fns_array) -        write(assembled) +        if @opt.fno =~/\S+?\.ssm$/ +          SiSU_Screen::Ansi.new( +            @opt.act[:color_state][:set], +            'Composite Document', +            "[#{@opt.f_pth[:lng_is]}] #{@opt.fno}", +          ).grey_title_hi unless @opt.act[:quiet][:set]==:on +          assembled=loadfile(@opt.fno) +          #assembled=insertions?(fns_array) +          write(assembled) +          write(assembled) +        end          Dir.chdir(pwd)        rescue          SiSU_Errors::Rescued.new($!,$@,@opt.cmd,@opt.fns).location do @@ -112,6 +120,73 @@ module SiSU_Assemble        ensure        end      end +    def insert?(para) +      if para =~ /^<<\s+((?:https?|file):\/\/\S+?\.ss[it])$/ # and NetTest +        url($1.strip) +      elsif para =~/^<<\s+(\S+?\.ss[it])$/ +        loadfilename=$1.strip +        insert_array=loadfile(loadfilename) +        file=insertion(loadfilename,insert_array) +        file[:prepared] +      else para +      end +    end +    def loadfile(loadfilename) +      tuned_file=[] +      begin +        if FileTest.file?(loadfilename) +          insert_array=IO.readlines(loadfilename,'') +          if loadfilename =~/\S+?\.ss[im]$/ +            if (@opt.act[:verbose][:set]==:on \ +            || @opt.act[:verbose_plus][:set]==:on \ +            || @opt.act[:maintenance][:set]==:on) +              SiSU_Screen::Ansi.new( +                @opt.act[:color_state][:set], +                'loading:', +                loadfilename, +              ).txt_grey +            end +            insert_array.each do |para| +              tuned_file << insert?(para) +            end +          elsif loadfilename =~/\S+?\.sst$/ +            insert_array.each do |para| +              tuned_file << para +            end +          end +        end +        tuned_file=tuned_file.flatten.compact +      rescue +        SiSU_Errors::Rescued.new($!,$@,@opt.cmd,@opt.fns).location do +          __LINE__.to_s + ':' + __FILE__ +        end +      ensure +      end +    end +    def url(loadfilename) +      if loadfilename =~ /((?:https?|file):\/\/\S+?\.ss[it])$/ # and NetTest +        loadfilename=$1 +        imagedir = /((?:https?|file):\/\/\S+?)\/[^\/]+?\.ss[it]$/. +          match(loadfilename).captures.join + +          '/_sisu/image' #watch +        begin +          require 'uri' +          require 'open-uri' +          require 'pp' +        rescue LoadError +          SiSU_Utils::CodeMarker.new(__LINE__,__FILE__,:fuchsia). +            error('uri, open-uri or pp NOT FOUND (LoadError)') +        end +        image_uri=URI.parse(imagedir) +        insert=open(loadfilename) +        insert_array=insert.dup +        insert.close +        file=insertion(loadfilename,insert_array) +        @@imager[image_uri] ||=[] +        @@imager[image_uri] << file[:images] +        file[:prepared] +      end +    end      def write(assembled)        assembled_file=File.new("#{@env.processing_path.composite_file}/#{@opt.fnb}.ssm.sst",'w+')        assembled.each {|a| assembled_file << a } @@ -165,68 +240,6 @@ module SiSU_Assemble        end        file      end -    def insertions?(fns_array) -      tuned_file,imagedir=[],[] -      SiSU_Screen::Ansi.new( -        @opt.act[:color_state][:set], -        'Composite Document', -        "[#{@opt.f_pth[:lng_is]}] #{@opt.fno}", -      ).grey_title_hi unless @opt.act[:quiet][:set]==:on -      fns_array.each do |para| -        if para =~/^<<\s+(\S+?\.ss[it])$/ -          loadfilename=$1.strip -          if (@opt.act[:verbose][:set]==:on \ -          || @opt.act[:verbose_plus][:set]==:on \ -          || @opt.act[:maintenance][:set]==:on) -            SiSU_Screen::Ansi.new( -              @opt.act[:color_state][:set], -              'loading:', -              loadfilename, -            ).txt_grey -          end -          tuned_file << if loadfilename =~ /(?:https?|file):\/\/\S+?\.ss[it]$/ # and NetTest -            imagedir = /((?:https?|file):\/\/\S+?)\/[^\/]+?\.ss[it]$/. -              match(loadfilename).captures.join + -              '/_sisu/image' #watch -            begin -              require 'uri' -              require 'open-uri' -              require 'pp' -            rescue LoadError -              SiSU_Utils::CodeMarker.new(__LINE__,__FILE__,:fuchsia). -                error('uri, open-uri or pp NOT FOUND (LoadError)') -            end -            image_uri=URI.parse(imagedir) -            insert=open(loadfilename) -            insert_array=insert.dup -            insert.close -            file=insertion(loadfilename,insert_array) -            @@imager[image_uri] ||=[] -            @@imager[image_uri] << file[:images] -            file[:prepared] -          elsif loadfilename =~ /\.ss[it]$/ \ -          and FileTest.file?(loadfilename) -            insert_array=IO.readlines(loadfilename,'') -            file=insertion(loadfilename,insert_array) -            file[:prepared] -          else -            STDERR.puts %{SKIPPED processing file: [#{@opt.lng}] "#{@opt.fns}" it requires an invalid or non-existent file: "#{loadfilename}"} -            $process_document = :skip; break #remove this line to continue processing documents that have missing include files -            para -          end -        else tuned_file << para -        end -        tuned_file=tuned_file.flatten.compact -      end -      if @@imager.length >0 -        @@imager.each do |d,i| -          i=i.flatten.uniq -          image_info=d + i -          download_images(image_info.flatten) -        end -      end -      tuned_file -    end    end    class CompositeFileList      @@imager={} | 
