# coding: utf-8
=begin
* Name: SiSU
* Description: a framework for document structuring, publishing and search
* Author: Ralph Amissah
* Copyright: (C) 1997 - 2010, Ralph Amissah, All Rights Reserved.
* License: GPL 3 or later:
SiSU, a framework for document structuring, publishing and search
Copyright (C) Ralph Amissah
This program is free software: you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by the Free
Software Foundation, either version 3 of the License, or (at your option)
any later version.
This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
more details.
You should have received a copy of the GNU General Public License along with
this program. If not, see .
If you have Internet connection, the latest version of the GPL should be
available at these locations:
* SiSU uses:
* Standard SiSU markup syntax,
* Standard SiSU meta-markup syntax, and the
* Standard SiSU object citation numbering and system
* Hompages:
* Download:
* Ralph Amissah
** Description: texinfo formatting template
=end
module SiSU_Texinfo_format
@@table_pg_break_counter=1
require "#{SiSU_lib}/param"
include SiSU_Param
include SiSU_Viz
class Texinfo
@@tex_backslash="\\\\"
@@tex_1='\\\\~' #?? debug
@@tabular="{tabular}"
@@tex_pattern_margin_number="\\\\marginpar.+?\s+"
@@dp=nil
def initialize(md,t_o)
@md,@t_o=md,t_o
if t_o.class == Hash
@txt =t_o[:txt] || nil
#@h_name =t_o[:h_name] || nil
#elsif t_o.class == Array
# @txt =txt[0]
#elsif t_o.class == String
# @txt =txt
else
p t_o.class
p caller
end
@vz=SiSU_Env::Get_init.instance.skin
@dp=@@dp ||=SiSU_Env::Info_env.new.digest.pattern
end
def head
t=Time.now
year=t.year
filename=%{#{@md.fns}}[/(.+?)\.\w\w\d\d$/,1]
title=spec_char_string(@md.title)
title=title.gsub(/<(br|p|i)>|<\/\s*(br|p|i)>|<(br|p)\s*\/>/," #{@@tex_backslash*2} ")
title.gsub!(/\$/,"\\$")
title.gsub!(/[,]\s*/,' - ')
if @md.subtitle
subtitle=spec_char_string(@md.subtitle)
subtitle=subtitle.gsub(/<(br|p|i)>|<\/\s*(br|p|i)>|<(br|p)\s*\/>/," #{@@tex_backslash*2} ")
subtitle.gsub!(/\$/,"\\$")
subtitle.gsub!(/[,]\s*/,' - ')
subtitle="@subtitle @value{VERSION}, @value{UPDATED}\n" #bugwatch
end
subtitle ||=''
author=@md.author if @md.author
author ||=''
author.gsub!(/[\*]/,'') #if author
v=SiSU_Env::Info_version.instance.get_version
#(version @value{VERSION} #{v[:version]}, @value{UPDATED} #{v[:date]})
head =<|<\/\s*(br|p|i)>|<(br|p)\s*\/>/," #{@@tex_backslash*2} ")
txt.gsub!(/\$/,"\\$")
txt.gsub!(/[,]\s*/,' - ')
"@c %% 4\n" +
"@ifnottex\n" +
"@node Top\n" +
"@top #{txt}\n\n" +
"@insertcopying\n" +
"@end ifnottex\n\n" +
"@menu\n"
end
def dublincore
title=spec_char_string(@md.title) if @md.title
subtitle=spec_char_string(@md.subtitle) if @md.subtitle
full_title="#{title} - #{subtitle}" #dc
author=spec_char_string(@md.author) if @md.author #dc
subject=spec_char_string(@md.subject) if @md.subject #dc
description=spec_char_string(@md.description) if @md.description #dc
publisher=spec_char_string(@md.publisher) if @md.publisher #dc
contributor=spec_char_string(@md.contributor) if @md.contributor #dc
date=spec_char_string(@md.date) if @md.date #dc
date_created=spec_char_string(@md.date_created) if @md.date_created #dc
date_issued=spec_char_string(@md.date_issued) if @md.date_issued #dc
date_available=spec_char_string(@md.date_available) if @md.date_available #dc
date_valid=spec_char_string(@md.date_valid) if @md.date_valid #dc
date_modified=spec_char_string(@md.date_modified) if @md.date_modified #dc
type=spec_char_string(@md.type) if @md.type #dc
format=spec_char_string(@md.format) if @md.format #dc
identifier=spec_char_string(@md.identifier) if @md.identifier #dc
source=spec_char_string(@md.source) if @md.source #dc
language=spec_char_string(@md.language[:name]) if @md.language[:name] #dc
#language_original=spec_char_string(@md.language_original[:name]) if @md.language_original[:name]
relation=spec_char_string(@md.relation) if @md.relation #dc
coverage=spec_char_string(@md.coverage) if @md.coverage #dc
rights=spec_char_string(@md.rights) if @md.rights #dc
full_title="Title: #{full_title}\n\n" if full_title #dc
author="Author: #{author}\n\n" if author #dc
subject="Subject: #{subject}\n\n" if subject #dc
description="Description: #{description}\n\n" if description #dc
publisher="Publisher: #{publisher}\n\n" if publisher #dc
contributor="Contributor: #{contributor}\n\n" if contributor #dc
date="Date: #{date}\n\n" if date #dc
date_created="Date Created: #{date_created}\n\n" if date_created #dc
date_issued="Date Issued: #{date_issued}\n\n" if date_issued #dc
date_available="Date Available: #{date_available}\n\n" if date_available #dc
date_valid="Date Valid: #{date_valid}\n\n" if date_valid #dc
date_modified="Date Modified: #{date_modified}\n\n" if date_modified #dc
format="Format: #{format}\n\n" if format #dc
identifier="Identifier: #{identifier}\n\n" if identifier #watch #dc
source="Source: #{source}\n\n" if source #dc
language="Language: #{language}\n\n" if language #dc
relation="Relation: #{relation}\n\n" if relation #dc
coverage="Coverage: #{coverage}\n\n" if coverage #dc
rights="Rights: #{rights}\n\n" if rights #dc
"@node Dublin Core\n" +
"@unnumbered Dublin Core\n" +
"@cindex chapter, Dublin Core\n\n" +
"#{full_title}" +
"#{author}" +
"#{subject}" +
"#{description}" +
"#{publisher}" +
"#{contributor}" +
"#{date}" +
"#{date_created}" +
"#{date_issued}" +
"#{date_available}" +
"#{date_valid}" +
"#{date_modified}" +
"#{format}" +
"#{identifier}" +
"#{source}" +
"#{language}" +
"#{relation}" +
"#{coverage}" +
"#{rights}" +
"\n\n"
end
def tail
"@c %% 6\n" +
"@node Index\n" +
"@unnumbered Index\n" +
"@printindex cp\n\n" +
"@bye"
end
def clean(para)
para.gsub!(/#{Mx[:id_o]}\\~(\d+);(?:\w|[0-6]:)\d+;\w\d+#{Mx[:id_c]}#{Mx[:id_o]}#@dp:#@dp#{Mx[:id_c]}$/,'<\1>')
para.gsub!(/\s*[,:]\s*/,' - ')
para.gsub!(/<:#>/,'')
para.strip!
para
end
def menu
para=clean(@txt)
para=para.gsub(/@footnote\{.+?\}\s+/,'')
"* #{para}::"
end
def level1
@txt.gsub!(/#{Mx[:lv_o]}1:\S*?#{Mx[:lv_c]}\s*/,'')
para=clean(@txt)
nd=para.gsub(/@footnote\{.+?\}\s+/,'')
para="@node #{nd}\n@unnumbered #{para}\n@cindex chapter, #{nd}\n"
@txt.gsub!(/.+/,"#{para}")
end
def level2
@txt.gsub!(/#{Mx[:lv_o]}2:\S*?#{Mx[:lv_c]}\s*/,'')
para=clean(@txt)
nd=para.gsub(/@footnote\{.+?\}\s+/,'')
para="@node #{nd}\n@unnumbered #{para}\n@cindex chapter, #{nd}\n"
@txt.gsub!(/.+/,"#{para}")
end
def level3
@txt.gsub!(/#{Mx[:lv_o]}3:\S*?#{Mx[:lv_c]}\s*/,'')
para=clean(@txt)
nd=para.gsub(/@footnote\{.+?\}\s+/,'')
#para=para.gsub(/(.+?)\s*(@footnote\{.+?\})\s*(.+)$/,"\\1 \\3\n\\2")
#para=para.gsub(/(.+?)\s*(@footnote\{.+?\})\s*(.+)$/,'\1 \3 \2')
para="@node #{nd}\n@unnumbered #{para}\n@cindex chapter, #{nd}\n"
@txt.gsub!(/.+/,"#{para}")
end
def level4
@txt.gsub!(/#{Mx[:lv_o]}4:\S+?#{Mx[:lv_c]}\s*/,'')
para=clean(@txt)
nd=para.gsub(/@footnote\{.+?\}\s+/,'')
para="@node #{nd}\n@unnumbered #{para}\n@cindex chapter, #{nd}\n"
@txt.gsub!(/.+/,"#{para}")
end
def level5
@txt.gsub!(/#{Mx[:lv_o]}5:\S*?#{Mx[:lv_c]}\s*/,'')
para=clean(@txt)
nd=para.gsub(/@footnote\{.+?\}\s+/,'')
para="@node #{nd}\n@unnumbered #{para}\n@cindex chapter, #{nd}\n"
@txt.gsub!(/.+/,"#{para}")
end
def level6
@txt.gsub!(/#{Mx[:lv_o]}6:\S*?#{Mx[:lv_c]}\s*/,'')
para=clean(@txt)
nd=para.gsub(/@footnote\{.+?\}\s+/,'')
para="@node #{nd}\n@unnumbered #{para}\n@cindex chapter, #{nd}\n"
@txt.gsub!(/.+/,"#{para}")
end
def submenu
@txt=@txt.join("\n")
@txt.gsub!(/[5]\\+~\S+/,'')
para=clean(@txt)
para="@menu\n#{para}\n@end menu\n\n"
@txt.gsub!(/.+/m,"#{para}")
end
def subsubmenu
@txt=@txt.join("\n")
@txt.gsub!(/[6]\\+~\S+/,'')
para=clean(@txt)
para="@menu\n#{para}\n@end menu\n\n"
@txt.gsub!(/.+/m,"#{para}")
end
def indent1
@txt.gsub!(/<:i1>(.*)/,'\1')
end
def indent2
@txt.gsub!(/<:i2>(.*)/,'\1')
end
def spec_char_string(txt) # special characters
txt_obj={:txt =>txt}
SiSU_Texinfo_format::Texinfo.new(@md,txt_obj).spec_char
end
def spec_char # special characters
@txt.gsub!(/#{Mx[:br_eof]}/i,'')
@txt.gsub!(/#{Mx[:gl_o]}#169#{Mx[:gl_c]}/,'(c)')
@txt.gsub!(/#{Mx[:gl_o]}#(?:lt|060)#{Mx[:gl_c]}/,'<'); @txt.gsub!(/#{Mx[:gl_o]}(gt|#062)#{Mx[:gl_c]}/,'>')
@txt.gsub!(/#{Mx[:gl_o]}#123#{Mx[:gl_c]}/,'{'); @txt.gsub!(/#{Mx[:gl_o]}#125#{Mx[:gl_c]}/,'}')
@txt.gsub!(/#{Mx[:gl_o]}#(?:126|152)#{Mx[:gl_c]}/i,'~')
@txt.gsub!(/#{Mx[:gl_o]}#033#{Mx[:gl_c]}/,'!')
@txt.gsub!(/#{Mx[:gl_o]}#035#{Mx[:gl_c]}/,'#')
@txt.gsub!(/#{Mx[:gl_o]}#042#{Mx[:gl_c]}/,'*')
@txt.gsub!(/#{Mx[:gl_o]}#047#{Mx[:gl_c]}/,'/')
@txt.gsub!(/#{Mx[:gl_o]}#095#{Mx[:gl_c]}/,'_')
@txt.gsub!(/&atild;<\/font><\/sup>/,' ')
@txt.gsub!(/\\/,'\\backslash ')
@txt.gsub!(/<:pb>/,'\\newpage')
@txt.gsub!(/\\backslash copyright/,'\\copyright ')
@txt.gsub!(/\^/,'\\wedge ')
@txt.gsub!(/(\$)/,"\\$")
@txt.gsub!(/\~/,'\\~')
@txt.gsub!(/%/,"\\%")
#if @txt !~ /^\s*<:image|\}:image\s/
# @txt.gsub!(/_/,'\_')
#end
@txt.gsub!(/_(https?:\/\/)/,'\1')
@txt.gsub!(/§/i,'\S')
@txt.gsub!(/£/i,'\pounds')
@txt.gsub!(/å/i,'\aa')
@txt.gsub!(/æ/i,'\ae')
@txt.gsub!(/ø/i,'\o')
@txt.gsub!(/Å/i,'\AA')
@txt.gsub!(/Æ/i,'\AE')
@txt.gsub!(/Ø/i,'\O')
@txt.gsub!(//i,' ')
@txt.gsub!(/<\/a>/i,' ')
@txt.gsub!(/<:ee>/i,'')
@txt.gsub!(//i,' ')
@txt.gsub!(/(.+?)<\/b>/,'\*\1\*')
@txt.gsub!(/(.+?)<\/i>/,'\/\1\/')
@txt.gsub!(/(.+?)<\/u>/,'\_\1\_')
@txt.gsub!(/@/i,'@@')
@txt.gsub!(/\{/,'@{'); @txt.gsub!(/\}/,'@}')
#@txt.gsub!(/(^|[\s*!\/#_-])\{/,'\1@{'); @txt.gsub!(/\}([\s*!\/#_-]|$)/,'@}\1')
@txt.gsub!(/(?: |#{Mx[:nbsp]})+/,' ') # ~ character for hardspace
@txt.gsub!(/&(\S+?);/,' ')
@txt.gsub!(/&/,'<=and>')
@txt.gsub!(/(\s+&\s+)/,' and ')
@txt.gsub!(/(\&)/,"\\&")
@txt.gsub!(/"(.+?)"/,"`\\1'") # open & close "
@txt.gsub!(/\s+"/," `") # open "
@txt.gsub!(/^([1-6-]\\+(?:~\S+)?|<.+?>)?\s*"/,'\1`') # open "
@txt.gsub!(/"(\s|\.|,|:|;)/,"'\\1") # close "
@txt.gsub!(/"([1-6-]\\+(?:~\S+)?|<.+?>)?\s*$/,"'\\1") # close "
@txt.gsub!(/"(\.|,)/,"'") # close "
@txt.gsub!(/\s+'/," `") # open '
@txt.gsub!(/^([1-6-]\\+(?:~\S+)?|<.+?>)?\s*'/,'\1`') # open '
@txt.gsub!(/(|<\/font>)/,'')
@txt.gsub!(/\s*(\S+?)<\/sup>/,'^\1')
@txt.gsub!(/(|<\/sup>)/,'')
@txt
end
def longtable
@end_table="\\end{longtable}"
@row_break='\\\\\\'
if @txt[/#{Mx[:gr_o]}Th?#{Mx[:tc_p]}\s+c(\d+);(.+?)#{Mx[:gr_c]}/ui] #CHECK !> closure
no_of_cols,cols_width=$1,$2
@@tableheader=1 if @txt =~ /#{Mx[:gr_o]}Th/i
@w=cols_width.split(/;\s+/)
@@number_of_cols=no_of_cols
@colW=[]
@colW << '{'
@w.each do |x|
col_w=x.gsub(/.+/,'l\|') #unless x.nil?
@colW << "#{col_w}" if col_w
end
@colW << '}'
@colW=@colW.join
@@start_table="\\setlength{\\LTleft}{0pt}\n\\setlength{\\LTright}{\\fill}\n" +
"\\begin{longtable}[hb]#@colW\n"
@txt.gsub!(/#{Mx[:gr_o]}Th?#{Mx[:tc_p]}\s+c\d+?;.+#{Mx[:gr_c]}/u,"#{@@start_table}")
end
if @txt =~/#{Mx[:gr_o]}TZ#{Mx[:gr_c]}/
@txt.gsub!(/#{Mx[:gr_o]}TZ#{Mx[:gr_c]}/," #@end_table")
end
@txt.gsub!(/#{Mx[:tc_o]}#{Mx[:tc_p]}/u,'')
if @@tableheader==1
if @txt =~/#{Mx[:tc_p]}\d+?#{Mx[:tc_p]}(.+?)(?:#{Mx[:tc_p]}|!)/u
tablefoot=para[/\/,1]
@txt.gsub!(/\/,'')
@txt.gsub!(/#{Mx[:tc_p]}\d+?#{Mx[:tc_p]}(.+?)(?:#{Mx[:tc_p]}|!)/u,
"{\\begin{tiny} {\\bfseries \\1}\\end{tiny}}&")
@txt.gsub!(/&>\s*$/,
" #@row_break \\hline\\endhead #@row_break")
@txt="#{@txt} \\multicolumn{#{@@number_of_cols}}{l}{\\tiny #{tablefoot}} \\\\ \\hline\n\\endfoot\n\\hline\n" if tablefoot
@@tableheader=0
@@number_of_cols=0
end
else
if @txt =~/#{Mx[:tc_p]}\d+?#{Mx[:tc_p]}(.+?)(?:#{Mx[:tc_p]}|!)/u
@txt.gsub!(/#{Mx[:tc_p]}\d+?#{Mx[:tc_p]}(.+?)(?:#{Mx[:tc_p]}|!)/u,"\\begin{tiny}\\1\\end{tiny}&")
@txt.gsub!(/&>\s*$/," #@row_break")
end
end
@txt
end
def scopedtable
# some features related to headers have been incorporated in longtable
# that are not included yet here, so until synced is broken on some
# input files, work needs to be done if is to work as before
@end_table="\\end{tabular}"
@row_break='\\\\\\\\'
@break_page="#@row_break\n#@row_break \n"
if @txt[/#{Mx[:gr_o]}Th?#{Mx[:tc_p]}\s+c(\d+);(.+?)#{Mx[:gr_c]}/ui]
no_of_cols,cols_width=$1,$2
@w=cols_width.split(/;\s+/)
@colW=[]
@w.each do |x|
col_w=((x.to_i*12)/100.00).to_s #unless x.nil?
@colW << "p{#{col_w}cm}" if col_w
end
@@start_table="\\begin{tabular}{#@colW}\n"
@txt.gsub!(/#{Mx[:gr_o]}Th?#{Mx[:tc_p]}\s+c\d+?;.+#{Mx[:gr_c]}/u,"#{@@start_table}")
end
if @txt =~/#{Mx[:gr_o]}TZ#{Mx[:gr_c]}/
@txt.gsub!(/#{Mx[:gr_o]}TZ#{Mx[:gr_c]}/,"#@end_table")
@@table_pg_break_counter=1
end
if @txt =~/#{Mx[:tc_o]}#{Mx[:tc_p]}/u
if @@table_pg_break_counter==28 # taken from 34 ideal for portrait to 28 which suits landscape
@txt =
"\n\n#@end_table \n" +
"#@break_page" +
"#{@@start_table}\n"
@@table_pg_break_counter=1
else
@txt.gsub!(/#{Mx[:tc_o]}#{Mx[:tc_p]}/u,'')
@@table_pg_break_counter+=1
tablefoot=@txt[/\/]
@txt.gsub!(/\/,'')
end
end
if @txt =~/#{Mx[:tc_p]}\d+?#{Mx[:tc_p]}(.+?)(?:#{Mx[:tc_p]}|!)/u
@txt.gsub!(/#{Mx[:tc_p]}\d+?#{Mx[:tc_p]}(.+?)(?:#{Mx[:tc_p]}|!)/u,"\\begin{tiny}\\1\\end{tiny}&")
@txt.gsub!(/&>\s*$/,"#@row_break")
end
@txt
end
def graphics
dir=SiSU_Env::Info_env.new(@md.fns)
@txt.gsub!(/<::\s+(\S+?)\s+>/i, #watch
"\\includegraphics*[width=11pt]{#{dir.path.image_source_tex}/c_\\1.png}")
end
def image
dir=SiSU_Env::Info_env.new(@md.fns)
width="100"
width=@txt[/<:image.+?width=``(\d+)''.+?>/im,1]
width=width.to_i*0.4
@txt.gsub!(/<:image\s+((?:https?|file|ftp)\S+)\s+(\S+)\s+.+\s+?>/i,
"\\href{\\1}{\\includegraphics*[width=#{width}pt]{#{dir.path.image_source_tex}/\\2}}")
@txt.gsub!(/<:image\s+(\S+)\s+.+\s+?>/i,
"\\includegraphics*[width=#{width}pt]{#{dir.path.image_source_tex}/\\1}")
end
def png
# very messy clean up ! - work area, testing
z=@txt[/\\\{(.+?)\}(?:image|png)/,1] # match operator for z \\ fragile !
image,w,x,y=z.scan(/\S+/)
image.gsub!(/\\/,'')
@txt.gsub!(/\\\{\S+\.(png|jpg|gif).+?\}(image|png)/,"") # fragile match operator\\ fragile !
end
def http
# very messy clean up ! - work area, testing
z=@txt[/#{Mx[:lnk_o]}(.+?)#{Mx[:lnk_c]}(?:https?|file|ftp):\/\//,1] # match operator for z \\ fragile !
url=@txt[/((?:https?|file|ftp):\S+)/im,1]
if @txt =~/\.(png|jpg|gif)/
image,w,x,y=z.scan(/\S+/)
image.gsub!(/\\/,'')
width=200
width=z[/w=(\d+)/im,1] if z =~/w=(\d+)/
width=width.to_i*0.8
width=400 if width > 400
c=z[/``(.+?)''/im,1]
caption="{\\\\\\\ \n\\begin{scriptsize}#{c}\\end{scriptsize}&}" if c
end
if image
dir=SiSU_Env::Info_env.new(@md.fns)
@txt.gsub!(/#{Mx[:lnk_o]}\S+\.(png|jpg|gif).+?#{Mx[:lnk_c]}(?:https?|file|ftp):\/\/\S+/, # fragile match operator\\ fragile !
"\n\\href{#{url}}{\\includegraphics*[width=#{width}pt]{#{dir.path.image_source_tex}/#{image}}}#{caption}")
else
link=z[/(.+?)\\/im,1]
@txt.gsub!(/#{Mx[:lnk_o]}.+?#{Mx[:lnk_c]}(?:https?|file|ftp):\/\/\S+/,"\n\\noindent\\href{#{url}}{#{link}}") # fragile match operator\\ fragile !
end
end
end
end
__END__
watch title, might need full_title