# coding: utf-8
=begin
* Name: SiSU
* Description: a framework for document structuring, publishing and search
* Author: Ralph Amissah
* Copyright: (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
2007, 2008 Ralph Amissah All Rights Reserved.
* License: GPL 3 or later:
SiSU, a framework for document structuring, publishing and search
Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
2007, 2008 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: LaTeX formatting template, unicode utf-8 version, used for pdf
=end
module SiSU_TeX_Pdf
@@table_pg_break_counter=1
require "#{SiSU_lib}/param"
include SiSU_Param
include SiSU_Viz
class Use_TeX
attr_accessor :url,:txt,:date
def initialize(md)
@md=md
@vz=SiSU_Env::Get_init.instance.skin
@date=SiSU_Env::Info_date.new # #{@date.year}
@copymark='{\\begin{footnotesize}\\raisebox{1ex}{\\copyright}\\end{footnotesize}}'
@url_brace=SiSU_Viz::Skin.new.url_decoration
end
def skip
"\n\\vspace*{\\smallskipamount} \n"
end
def paraskip_normal
'\setlength{\parskip}{1ex plus0.5ex minus0.2ex}'
end
def paraskip_small
'\setlength{\parskip}{0.5ex plus0.2ex minus0.1ex}'
end
def skip_small
#"\\smallskip{}"
end
def skip_small_vspace
"\n\\vspace*{\\smallskipamount} \n"
end
def skip_small_footnote
#"\n\\smallskip{}\n"
end
def skip_medium
"\n\\medskip{}\n\n"
end
def skip_dummy
"\n"
end
def header
"\\lhead[ ]{ }\n" +
"\\chead[ \\fancyplain{} \\bfseries \\footnotesize \\leftmark ]{ \\fancyplain{} \\bfseries \\footnotesize \\rightmark }\n" +
"\\rhead[ ]{ }\n"
end
def footer
base_prog_txt=if @md.base_program
case @md.base_program
when /kdissert/i; " \\\\ \\href{http://freehackers.org/~tnagy/kdissert/}{Kdissert}"
else ''
end
else ''
end
"\\lfoot[\\textrm{\\thepage}]{\\tiny \\href{#{@vz.url_sisu}}{#{@vz.txt_signature}}#{base_prog_txt}}\n" +
"\\cfoot[\\href{#{@vz.url_home}}{#{@vz.url_txt}}]{\\href{#{@vz.url_home}}{#{@vz.url_txt}}}\n" +
"\\rfoot[\\tiny \\href{#{@vz.url_sisu}}{#{@vz.txt_signature}}]{\\textrm{\\thepage}}\n"
end
def site
"\\href{#{@vz.url_home}}{#{@vz.url_txt}}"
end
def sitename #owners site, eg freeculture, free.for.all, gutenberg etc.
"\\href{#{@vz.url_home}}{#{@vz.txt_home}}"
end
def owner_chapter
"Contact Details for Original Promulgating Authority"
end
#BOOK standard dimensions - 229x156
def newpage(orientation)
case orientation
when /landscape/ # using longtable latex package
< 0, :l => 0 }
@@sys=SiSU_Env::System_call.new
@@flag_code=false
@@dp=nil
def initialize(md,string,string1=nil)
@md,@string,@string1=md,string,string1
if defined? @md.image \
and @md.image =~/center/
@center_begin,@center_end='\begin{center}','\end{center}'
else @center_begin,@center_end='',''
end
@start_table=''
@dp=@@dp ||=SiSU_Env::Info_env.new.digest.pattern
@tx=SiSU_Env::Get_init.instance.tex
@url_brace=SiSU_Viz::Skin.new.url_decoration
@tex2pdf=@@tex3pdf ||=SiSU_Env::System_call.new.tex2pdf_engine
end
def longtable_landscape
@end_table='\end{longtable}'
@row_break='\\\\\\'
if @string[//u]
no_of_cols,cols_width,ocn=$1,$2,$3
tw=case @md.papersize
when /a4/i; @tx.a4.landscape.w #European default, SiSU default
when /letter/i; @tx.letter.landscape.w #U.S. default
when /legal/i; @tx.legal.landscape.w #U.S. alternative
when /book|b5/i; @tx.b5.landscape.w #book default - larger
when /a5/i; @tx.a5.landscape.w
else @tx.a4.landscape.w #default currently A4
end
textwidth=(tw.to_i/2) - 24
@@tableheader[:l]=1 if @string =~/\n\\setlength{\\LTleft}{0pt}\n\\setlength{\\LTright}{\\fill}\n" +
"\\begin{tiny}\n\\begin{longtable}#@colW\n"
@string.gsub!(//u,@start_table)
end
if @string =~//
@string.gsub!(//," #@end_table\n\\end{tiny}")
end
@string.gsub!(//,1]
@string.gsub!(/\/,'')
@string.gsub!(/¡\d+?¡(.+?)(?:¡|!)/u,'\bfseries \1&')
@string.gsub!(/&>\s*$/," #@row_break \\hline\\endhead #@row_break")
@string="#@string \\multicolumn{#{@@number_of_cols}}{l}{\\tiny #{tablefoot}} \\\\ \\hline\n\\endfoot\n\\hline\n" if tablefoot
@@tableheader[:l],@@number_of_cols=0,0
end
else
if @string =~/¡\d+?¡(.+?)(?:¡|!)/u
@string.gsub!(/¡\d+?¡(.+?)(?:¡|!)/u,'\1&')
@string.gsub!(/&>\s*$/," #@row_break")
end
end
@string=if ocn; "<~#{ocn}>" + @string
else @string
end
end
def longtable_portrait
@end_table='\end{longtable}'
@row_break='\\\\\\'
if @string[//u]
no_of_cols,cols_width,ocn=$1,$2,$3
tw=case @md.papersize
when /a4/i; @tx.a4.portrait.w #European default, SiSU default
when /letter/i; @tx.letter.portrait.w #U.S. default
when /legal/i; @tx.legal.portrait.w #U.S. alternative
when /book|b5/i; @tx.b5.portrait.w #book default - larger
when /a5/i; @tx.a5.portrait.w
else @tx.a4.portrait.w #default currently A4
end
textwidth=tw.to_i - 20
@@tableheader[:p]=1 if @string =~/\n\\setlength{\\LTleft}{0pt}\n\\setlength{\\LTright}{\\fill}\n" +
"\\begin{tiny}\n\\begin{longtable}#@colW\n"
@string.gsub!(//u,"#@start_table")
end
if @string =~//
@string.gsub!(//," #@end_table\n\\end{tiny}")
end
@string.gsub!(//,1]
@string.gsub!(/\/,'')
@string.gsub!(/¡\d+?¡(.+?)(?:¡|!)/u,'\bfseries \1&')
@string.gsub!(/&>\s*$/," #@row_break \\hline\\endhead #@row_break")
@string="#@string \\multicolumn{#{@@number_of_cols}}{l}{\\tiny #{tablefoot}} \\\\ \\hline\n\\endfoot\n\\hline\n" if tablefoot
@@tableheader[:p],@@number_of_cols=0,0
end
else
if @string =~/¡\d+?¡(.+?)(?:¡|!)/u
@string.gsub!(/¡\d+?¡(.+?)(?:¡|!)/u,'\1&')
@string.gsub!(/&>\s*$/," #@row_break")
end
end
@string=if ocn; "<~#{ocn}>" + @string
else @string
end
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 @string[//u]
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"
@string.gsub!(//u,"#@start_table}")
end
if @string =~//
@string.gsub!(//,"#@end_table")
@@table_pg_break_counter=1
end
if @string =~//,1]
@string.gsub!(/\/,'')
end
end
if @string =~/¡\d+?¡(.+?)(?:¡|!)/u
@string.gsub!(/¡\d+?¡(.+?)(?:¡|!)/u,"\\1&")
@string.gsub!(/&>\s*$/,"#@row_break")
end
@string
end
def pdftex_special_characters_1(string) # ~ ^ $ & % _ { } #LaTeX special characters - KEEP list
#p @@utf_8.list
#@string=Iconv.conv('ISO-8859-1', 'UTF-8', @string)
word=string.scan(/\S+|\n/) #unless line =~/^(?:0~\S|%+\s)/
para_array=[]
string=if word
word.each do |w| # _ - / # | : ! ^ ~
unless string =~/^(?:0~|%+ |') unless w=~/^[1-6]~|~\{|\}~|~\[|\]~|^\^~\s|~\^|\*~\S+|~#|\{t~|<~\d+;(?:[ohmu]|[0-6]:)\d+;\w\d+>/
w.gsub!(/(?:126|152);/,'<=tilde>') #126 usual
#w.gsub!(/(?:126|152);/,'<=tilde>') unless w=~/https?:\/\/\S+/ #126 usual
w.gsub!(/\\?\|||/,'<=pipe>') #unless w=~/<~\d+;(?:[ohmu]|[0-6]:)\d+;\w\d+>/ # | SiSU not really special sisu character but done, also LaTeX
end
para_array << w
end
string=para_array.join(' ')
string=string.strip
string
else ''
end
string.gsub!(/<~\d+;(?:\w|[0-6]:)\d+;[umdv]\d+><#@dp:#@dp>/,'')
string.gsub!(/.+?<-#>/,'')
string.gsub!(//,'')
string.gsub!(//,'')
#problem sequence ->
string.gsub!(/&(?:nbsp);/,'<=hardspace>') # < SiSU special character also LaTeX
string.gsub!(/&(?:lt|#060);/,'<=lt>') # < SiSU special character also LaTeX
string.gsub!(/&(?:gt|#062);/,'<=gt>') # > SiSU special character also LaTeX
string.gsub!(/{/,'<=curlyopen>') # { SiSU special character also LaTeX
string.gsub!(/}/,'<=curlyclose>') # } SiSU special character also LaTeX
string.gsub!(/(?:126|152);/,'<=tilde>') # ~ SiSU special character also LaTeX
string.gsub!(/#/,'\#') # # SiSU special character also LaTeX
string.gsub!(/!/,'!') # ! SiSU not really special sisu character but done, also LaTeX
string.gsub!(/*/,'*') # * should you wish to escape astrisk e.g. describing \*{bold}*
string.gsub!(/-/,'-') # - SiSU special character also LaTeX
string.gsub!(/+/,'+') # + SiSU special character also LaTeX
string.gsub!(/,/,',') # + SiSU special character also LaTeX
string.gsub!(/&/,'<=amp>') #unless @string=~/<:code>/ # / SiSU special character also LaTeX
string.gsub!(///,'<=slash>') # / SiSU special character also LaTeX
string.gsub!(/\/,'<=backslash>') # \ SiSU special character also LaTeX
string.gsub!(/_/,'<=underscore>') # _ SiSU special character also LaTeX
string.gsub!(/|/,'|') # | SiSU not really special sisu character but done, also LaTeX
string.gsub!(/:/,':') # : SiSU not really special sisu character but done, also LaTeX
string.gsub!(/^|\^/,'<=caret>') # ^ SiSU not really special sisu character but done, also LaTeX
string.gsub!(/\#/,'<=hash>')
##watch placement, problem sequence ^
string.gsub!(/&atild;<\/font><\/sup>/,' ')
string.gsub!(/<:pb>/,'\newpage')
string.gsub!(/<:pn>/,'\clearpage')
string.gsub!(/\\copy(right|mark)?/,'<=copymark>') # ok problem with superscript
string
end
def pdftex_special_characters_2(string)
string.gsub!(//,'\oe ')
string.gsub!(/\$/,'\$')
string.gsub!(/\#/,'\#')
string.gsub!(/\%/,'\%')
string.gsub!(/\~/,'\~') #revist, should not be necessary to mark remaining tildes
if string !~/^\s*<:image|\}:image\s/
string.gsub!(/_/,'\_')
end
string.gsub!(/\{/,'\{')
string.gsub!(/\}/,'\}')
string.gsub!(/ /,'~') # ~ character for hardspace
# sequence important must appear after removal of { and }
string.gsub!(/&\S+?;/,'') #hmmm
# sequence imortant place before removal of &
if string=~/<:code>/; @@flag_code=true
elsif string=~/<:code-end>/; @@flag_code=false
end
if @@flag_code; string.gsub!(/&/,'{\\\&}')
else string.gsub!(/(\s+&\s+)/,' and ')
end
string.gsub!(/§/u,'\S') #latex: space between next character not preserved? #string.gsub!(/§ /,'\S ')
string.gsub!(/£/u,'\pounds')
string.gsub!(/&\S+?;/,' ')
string.gsub!(//,' ')
string.gsub!(/<\/a>/,' ')
string.gsub!(/[^\}>_]((?:https?|file|ftp):\/\/\S+?)(<\/\S>)/,' \begin{scriptsize}\href{\1}{\1} \end{scriptsize}\2') #special case
string.gsub!(/((?:^|\s)[}])((?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?)([;.,]?(?:\s|$))/,'\1\begin{scriptsize}\\href{\2}{\2}\end{scriptsize}\3') #special case \{ e.g. \}http://url
string.gsub!(/\B(?:\\_|\\)((?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?)([;.,]?(?:\s|$))/,'\begin{scriptsize}\\href{\1}{\1}\end{scriptsize}\2') #specially escaped url no decoration
unless @@flag_code
string.gsub!(/(^|\s)((?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?)([;.,]?(?=\s|$))/,"\\1#{@url_brace.tex_open}\\begin{scriptsize}\\href{\\2}{\\2}\\end{scriptsize}#{@url_brace.tex_close}\\3") #url matching with decoration positive lookahead, sequence issue with { linked }http://url cannot use \b at start
else #code-block: angle brackets special characters, note _ already escaped
string.gsub!(/\\_,'{\UseTextSymbol{OML}{<}}')
string.gsub!(/\\_>/,'{\UseTextSymbol{OML}{>}}')
end
string.gsub!(/<:ee>/,'')
string.gsub!(//,' ')
#proposed change, insert, but may be redundant
string.gsub!(/ \/><:i[12]>(.+?)(?:\}~|
|<\/\s*(br|p)>|<(br|p)\s*\/>/," #{@@tex_backslash*2} ") # Work Area
string.gsub!(/(.+?)<\/b>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/(.+?)<\/em>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/<(bold|strong)>(.+?)<\/(bold|strong)>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/(.+?)<\/h\d+>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/(.+?)<\/i>/,'\emph{\1}')
string.gsub!(/(.+?)<\/italic>/,'\emph{\1}')
string.gsub!(/(.+?)<\/u>/,'\uline{\1}') # ulem
string.gsub!(/(.+?)<\/cite>/,"``\\1''") # quote
string.gsub!(/(.+?)<\/ins>/,'\uline{\1}') # ulem
string.gsub!(/(.+?)<\/del>/,'\sout{\1}') # ulem
string.gsub!(/(.+?)<\/sub>/,"\$_{\\textrm{\\1}}\$")
string.gsub!(/(.+?)<\/sup>/,"\$^{\\textrm{\\1}}\$")
unless @@flag_code
string.gsub!(/"(.+?)"/,'“\1”') # quote marks / quotations open & close " need condition exclude for code
string.gsub!(/\s+"/,' “') # open "
string.gsub!(/^([1-6-]#{@@tilde}\S*|<.+?>)?\s*"/,'\1“') # open "
string.gsub!(/"(\s|\.|,|:|;)/,'”\1') # close "
string.gsub!(/"([1-6-]#{@@tilde}\S*|<.+?>)?\s*$/,'”\1') # close "
string.gsub!(/"(\.|,)/,'”') # close "
string.gsub!(/\s+'/,' `') # open '
string.gsub!(/^([1-6-]#{@@tilde}\S*|<.+?>)?\s*'/,'\1`') # open '
end
string.gsub!(/^(<:i[1-9]>)?\s*\\_\*\s*/,'\1 \begin{math} \bullet \end{math}~~') #bullets - added 2004w17 watch \\_
string.gsub!(/(|<\/font>)/,'')
string.gsub!(/\s*(\S+?)<\/sup>/,'^\1')
string.gsub!(/(|<\/sup>)/,'')
string
end
def pdftex_special_characters_3(string)
string.gsub!(/
])/,'\1') # clean up, incredibly messy :-( footnote indents, problems if match exists in ordinary paragraphs? check! Work Area 200501 a bit tricky as must be able to match multiple times, and to clean remainder
string.gsub!(/([^<][^b][^r]\s+)\/>/,'\1') # clean up, incredibly messy :-( footnote indents, problems if match exists in ordinary paragraphs? check! Work Area 200501 a bit tricky as must be able to match multiple times, and to clean remainder
#problem sequence (another kludge) ->
string.gsub!(/<=lt>/,'{\UseTextSymbol{OML}{<}}')
string.gsub!(/<=gt>/,'{\UseTextSymbol{OML}{>}}')
#string.gsub!(/<=lt>/,'\<')
#string.gsub!(/<=gt>/,'\>')
string.gsub!(/<=underscore>/,'\_')
string.gsub!(/(\href\{http:\/\/\S+?)(?:(?:<=tilde>)(\S+))+\}/,'\1\~\2}') #tildes in urls \href treated differently from text
string.gsub!(/<=tilde>/,'{\~~}')
string.gsub!(/<=pipe>/,'{\textbar}')
string.gsub!(/<=caret>/,'{\^{~}}')
#string.gsub!(/<=caret>/,'\^{}')
string.gsub!(/<=exclaim>/,'\Verbatim{!}')
string.gsub!(/<=hash>/,'{\#}')
#string.gsub!(/<=hash>/,'{\UseTextSymbol{OT1}{#}}')
#string.gsub!(/<=slash>/,'{\slash}')
string.gsub!(/<=hardspace>/,'{~}') #changed ... 2005
string.gsub!(/<=amp>/,'{\\\&}') #changed ... 2005
#string.gsub!(/<=amp>/,'{\UseTextSymbol{OT1}{&}}')
string.gsub!(/<=slash>/,'{/}')
string.gsub!(/<=backslash>/,'{\textbackslash}')
#string.gsub!(/<=asterisk>/,'*')
#string.gsub!(/<=exclaim>/,'!')
#string.gsub!(/<=asterisk>/,'{\ast}')
#string.gsub!(/<=copymark>/,"^{\\copyright} ") # watch has been problematic
#copymark='{\\begin{small}\\raisebox{1ex}{\\copyright}\\end{small}} '
string.gsub!(/<=copymark>\s*(.+)?\s+(<\\~\d+;\w(?:[0-6]:)?\d+;\w\d+><#@dp:#@dp>)/,"^\\copyright \\textnormal{\\1} \\2") # watch likely to be problematic
string
end
def xetex_special_characters_1(string) # ~ ^ $ & % _ { } #LaTeX special characters - KEEP list
#p @@utf_8.list
#string=Iconv.conv('ISO-8859-1', 'UTF-8', @string)
word=string.scan(/\S+|\n/) #unless line =~/^(?:0~\S|%+\s)/
para_array=[]
string=if word
word.each do |w| # _ - / # | : ! ^ ~
unless string =~/^(?:0~|%+ |') unless w=~/^[1-6]~|~\{|\}~|~\[|\]~|^\^~\s|~\^|\*~\S+|~#|\{t~|<~\d+;(?:[ohmu]|[0-6]:)\d+;\w\d+>/
w.gsub!(/(?:126|152);/,'<=tilde>') #126 usual
#w.gsub!(/(?:126|152);/,'<=tilde>') unless w=~/https?:\/\/\S+/ #126 usual
w.gsub!(/\\?\|||/,'<=pipe>') #unless w=~/<~\d+;(?:[ohmu]|[0-6]:)\d+;\w\d+>/ # | SiSU not really special sisu character but done, also LaTeX
end
para_array << w
end
string=para_array.join(' ')
string=string.strip
string
else ''
end
string.gsub!(/<~\d+;(?:\w|[0-6]:)\d+;[umdv]\d+><#@dp:#@dp>/,'')
string.gsub!(/.+?<-#>/,'')
string.gsub!(//,'')
string.gsub!(//,'')
#problem sequence ->
string.gsub!(/&(?:nbsp);/,'<=hardspace>') # < SiSU special character also LaTeX
string.gsub!(/&(?:lt|#060);/,'<=lt>') # < SiSU special character also LaTeX
string.gsub!(/&(?:gt|#062);/,'<=gt>') # > SiSU special character also LaTeX
string.gsub!(/{/,'<=curlyopen>') # { SiSU special character also LaTeX
string.gsub!(/}/,'<=curlyclose>') # } SiSU special character also LaTeX
string.gsub!(/(?:126|152);/,'<=tilde>') # ~ SiSU special character also LaTeX
string.gsub!(/#/,'\#') # # SiSU special character also LaTeX
string.gsub!(/!/,'!') # ! SiSU not really special sisu character but done, also LaTeX
string.gsub!(/*/,'*') # * should you wish to escape astrisk e.g. describing \*{bold}*
string.gsub!(/-/,'-') # - SiSU special character also LaTeX
string.gsub!(/+/,'+') # + SiSU special character also LaTeX
string.gsub!(/,/,',') # + SiSU special character also LaTeX
string.gsub!(/&/,'<=amp>') #unless @string=~/<:code>/ # / SiSU special character also LaTeX
string.gsub!(///,'<=slash>') # / SiSU special character also LaTeX
string.gsub!(/\/,'<=backslash>') # \ SiSU special character also LaTeX
string.gsub!(/_/,'<=underscore>') # _ SiSU special character also LaTeX
string.gsub!(/|/,'|') # | SiSU not really special sisu character but done, also LaTeX
string.gsub!(/:/,':') # : SiSU not really special sisu character but done, also LaTeX
string.gsub!(/^|\^/,'<=caret>') # ^ SiSU not really special sisu character but done, also LaTeX
string.gsub!(/\#/,'<=hash>')
##watch placement, problem sequence ^
string.gsub!(/&atild;<\/font><\/sup>/,' ')
string.gsub!(/<:pb>/,'\newpage')
string.gsub!(/<:pn>/,'\clearpage')
string.gsub!(/\\copy(right|mark)?/,'<=copymark>') # ok problem with superscript
string
end
def xetex_special_characters_2(string)
string.gsub!(//,'\oe ')
string.gsub!(/\$/,'\$')
string.gsub!(/\#/,'\#')
string.gsub!(/\%/,'\%')
string.gsub!(/\~/,'\~') #revist, should not be necessary to mark remaining tildes
if string !~/^\s*<:image|\}:image\s/
string.gsub!(/_/,'\_')
end
string.gsub!(/\{/,'\{')
string.gsub!(/\}/,'\}')
string.gsub!(/ /,'~') # ~ character for hardspace
# sequence important must appear after removal of { and }
string.gsub!(/&\S+?;/,'') #hmmm
# sequence imortant place before removal of &
if string=~/<:code>/; @@flag_code=true
elsif string=~/<:code-end>/; @@flag_code=false
end
if @@flag_code; string.gsub!(/&/,'{\\\&}')
else string.gsub!(/(\s+&\s+)/,' and ')
end
string.gsub!(/§/u,'\S') #latex: space between next character not preserved? #string.gsub!(/§ /,'\S ')
string.gsub!(/£/u,'\pounds')
string.gsub!(/&\S+?;/,' ')
string.gsub!(//,' ')
string.gsub!(/<\/a>/,' ')
string.gsub!(/[^\}>_]((?:https?|file|ftp):\/\/\S+?)(<\/\S>)/,' \begin{scriptsize}\href{\1}{\1} \end{scriptsize}\2') #special case
string.gsub!(/((?:^|\s)[}])((?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?)([;.,]?(?:\s|$))/,'\1\begin{scriptsize}\\href{\2}{\2}\end{scriptsize}\3') #special case \{ e.g. \}http://url
string.gsub!(/\B(?:\\_|\\)((?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?)([;.,]?(?:\s|$))/,'\begin{scriptsize}\\href{\1}{\1}\end{scriptsize}\2') #specially escaped url no decoration
unless @@flag_code
string.gsub!(/(^|\s)((?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?)([;.,]?(?=\s|$))/,"\\1#{@url_brace.tex_open}\\begin{scriptsize}\\href{\\2}{\\2}\\end{scriptsize}#{@url_brace.tex_close}\\3") #url matching with decoration positive lookahead, sequence issue with { linked }http://url cannot use \b at start
else #code-block: angle brackets special characters, note _ already escaped
string.gsub!(/\\_,'{\UseTextSymbol{OML}{<}}')
string.gsub!(/\\_>/,'{\UseTextSymbol{OML}{>}}')
end
string.gsub!(/<:ee>/,'')
string.gsub!(//,' ')
#proposed change, insert, but may be redundant
string.gsub!(/ \/><:i[12]>(.+?)(?:\}~|
|<\/\s*(br|p)>|<(br|p)\s*\/>/," #{@@tex_backslash*2} ") # Work Area
string.gsub!(/(.+?)<\/b>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/(.+?)<\/em>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/<(bold|strong)>(.+?)<\/(bold|strong)>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/(.+?)<\/h\d+>/,'\begin{bfseries}\1 \end{bfseries}')
string.gsub!(/(.+?)<\/i>/,'\emph{\1}')
string.gsub!(/(.+?)<\/italic>/,'\emph{\1}')
string.gsub!(/(.+?)<\/u>/,'\uline{\1}') # ulem
string.gsub!(/(.+?)<\/cite>/,"``\\1''") # quote
string.gsub!(/(.+?)<\/ins>/,'\uline{\1}') # ulem
string.gsub!(/(.+?)<\/del>/,'\sout{\1}') # ulem
string.gsub!(/(.+?)<\/sub>/,"\$_{\\textrm{\\1}}\$")
string.gsub!(/(.+?)<\/sup>/,"\$^{\\textrm{\\1}}\$")
unless @@flag_code
string.gsub!(/"(.+?)"/,'“\1”') # quote marks / quotations open & close " need condition exclude for code
string.gsub!(/\s+"/,' “') # open "
string.gsub!(/^([1-6-]#{@@tilde}\S*|<.+?>)?\s*"/,'\1“') # open "
string.gsub!(/"(\s|\.|,|:|;)/,'”\1') # close "
string.gsub!(/"([1-6-]#{@@tilde}\S*|<.+?>)?\s*$/,'”\1') # close "
string.gsub!(/"(\.|,)/,'”') # close "
string.gsub!(/\s+'/,' `') # open '
string.gsub!(/^([1-6-]#{@@tilde}\S*|<.+?>)?\s*'/,'\1`') # open '
end
#string.gsub!(/^(<:i[1-9]>)?\s*\\_\*\s*/,'\1 \begin{math} \bullet \end{math}~~') #bullets - added 2004w17 watch \\_
string.gsub!(/^(<:i[1-9]>)?\s*\\_\*\s*/,'\1 ● ~~')
string.gsub!(/(|<\/font>)/,'')
string.gsub!(/\s*(\S+?)<\/sup>/,'^\1')
string.gsub!(/(|<\/sup>)/,'')
string
end
def xetex_special_characters_3(string)
string.gsub!(/
])/,'\1') # clean up, incredibly messy :-( footnote indents, problems if match exists in ordinary paragraphs? check! Work Area 200501 a bit tricky as must be able to match multiple times, and to clean remainder
string.gsub!(/([^<][^b][^r]\s+)\/>/,'\1') # clean up, incredibly messy :-( footnote indents, problems if match exists in ordinary paragraphs? check! Work Area 200501 a bit tricky as must be able to match multiple times, and to clean remainder
#problem sequence (another kludge) ->
string.gsub!(/<=lt>/,'{\UseTextSymbol{OML}{<}}')
string.gsub!(/<=gt>/,'{\UseTextSymbol{OML}{>}}')
#string.gsub!(/<=lt>/,'\<')
#string.gsub!(/<=gt>/,'\>')
string.gsub!(/<=underscore>/,'\_')
string.gsub!(/(\href\{http:\/\/\S+?)(?:(?:<=tilde>)(\S+))+\}/,'\1\~\2}') #tildes in urls \href treated differently from text
string.gsub!(/<=tilde>/,'{\~~}')
string.gsub!(/<=pipe>/,'{\textbar}')
string.gsub!(/<=caret>/,'{\^{~}}')
#string.gsub!(/<=caret>/,'\^{}')
string.gsub!(/<=exclaim>/,'\Verbatim{!}')
string.gsub!(/<=hash>/,'{\#}')
#string.gsub!(/<=hash>/,'{\UseTextSymbol{OT1}{#}}')
#string.gsub!(/<=slash>/,'{\slash}')
string.gsub!(/<=hardspace>/,'{~}') #changed ... 2005
string.gsub!(/<=amp>/,'{\\\&}') #changed ... 2005
#string.gsub!(/<=amp>/,'{\UseTextSymbol{OT1}{&}}')
string.gsub!(/<=slash>/,'{/}')
string.gsub!(/<=backslash>/,'{\textbackslash}')
#string.gsub!(/<=asterisk>/,'*')
#string.gsub!(/<=exclaim>/,'!')
#string.gsub!(/<=asterisk>/,'{\ast}')
#string.gsub!(/<=copymark>/,"^{\\copyright} ") # watch has been problematic
#copymark='{\\begin{small}\\raisebox{1ex}{\\copyright}\\end{small}} '
string.gsub!(/<=copymark>\s*(.+)?\s+(<\\~\d+;\w(?:[0-6]:)?\d+;\w\d+><#@dp:#@dp>)/,"^\\copyright \\textnormal{\\1} \\2") # watch likely to be problematic
string
end
def special_characters_curly(string)
string.gsub!(/<=curlyopen>/,'\{')
string.gsub!(/<=curlyclose>/,'\}')
string
end
def special_characters_unsafe_1(string) #depreciated, make obsolete
# some substitutions are sequence sensitive, rearrange with care.
string.gsub!(/\\backslash (copyright|clearpage|newpage)/,"\\\\\\1") #kludge bad solution, find out where tail is sent through specChar !
string
end
def special_characters #special characters - some substitutions are sequence sensitive, rearrange with care.
string=@string
case @tex2pdf
when /pdf/
string=pdftex_special_characters_1(string) unless string.nil?
string=special_characters_unsafe_1(string) unless string.nil? #pdftex_special_characters_unsafe_1(@string)
string=pdftex_special_characters_2(string) unless string.nil?
string=pdftex_special_characters_3(string) unless string.nil?
when /xe/
string=xetex_special_characters_1(string) unless string.nil?
string=special_characters_unsafe_1(string) unless string.nil? #xetex_special_characters_unsafe_1(@string)
string=xetex_special_characters_2(string) unless string.nil? #issues with xetex
string=xetex_special_characters_3(string) unless string.nil?
end
@string=string
end
def special_characters_safe #special characters - some substitutions are sequence sensitive, rearrange with care.
string=@string
case @tex2pdf
when /pdf/
string=pdftex_special_characters_1(@string) unless string.nil?
string=pdftex_special_characters_2(@string) unless string.nil?
#special_characters_3(@string)
when /xe/
string=xetex_special_characters_1(@string) unless string.nil?
string=xetex_special_characters_2(@string) unless string.nil? # remove this to start with, causes issues
end
@string=string
end
def heading_major(para,lev)
title=@md.title
para.strip! if para
para.gsub!(/(?:\\begin\{bfseries\}|\\begin\{itshape\})(.+?)(?:\\end\{bfseries\}|\\end\{itshape\})/m,'\1')
cont_ln=para.dup
cont_ln.gsub!(/#{@@tex_pattern_margin_number}/,'')
cont_ln.gsub!(/#{lev}#{@@tilde}(?:\S+)?\s+/,'')
if para =~/\\[Ff]ootnote/ #and para =~/^[1-6]#{@@tilde}/ # removing footnotes from headings!
cont_ln.gsub!(/\s*\\footnote\[\d+\]\{%\n .+? \}\s*/,' ')
cont_ln.gsub!(/\s*\\Footnote[A]\{[*+]+\d*\}\{%\n .+? \}\s*/,' ')
end
para.gsub!(/(#{@md.lev}.*)\n?$/m,"\\part*{\\1}
\\addcontentsline{toc}{section}{#{cont_ln}}
\\markboth{#{title}}\n") if (para !~/#{lev}#{@@tilde}/)
para.gsub!(/^#{lev}#{@@tilde}\s*(.*)\n?$/m,
"\\part*{\\1}
\\addcontentsline{toc}{section}{#{cont_ln}}
\\markboth{#{title}}\n")
end
def level1
heading_major(@string,1)
end
def level2
heading_major(@string,2)
end
def level3
heading_major(@string,3)
end
def level4
@string.strip! if @string
@string.gsub!(/(?:\\begin\{bfseries\}|\\begin\{itshape\})(.+?)(?:\\end\{bfseries\}|\\end\{itshape\})/m,'\1')
cont_ln=@string.dup
cont_ln.gsub!(/#{@@tex_pattern_margin_number}/,'')
cont_ln.gsub!(/#{@@tex_backslash*2}/,"#{@@tex_backslash*4}") # added w42
cont_ln.gsub!(/4#{@@tilde}\S+\s+/,'')
cont_ln.gsub!(/\\footnote\[\d+\]\{%.+?\\end\{scriptsize\}\s*\}/m,'') #arbitrary bugfix, revisit should not be necessary, eg. wta.1994 2004w22
cont_ln.gsub!(/\\Footnote[A]\{[*+]+\d*\}\{%.+?\\end\{scriptsize\}\s*\}/m,'') #arbitrary bugfix, revisit should not be necessary, eg. wta.1994 2004w22
title=@md.title
@string.gsub!(/#{@md.lv4}\s+(#{@md.lv4})/m,'\1')
if @string =~/4#{@@tilde}endnotes|<:4-endnotes>/
# watch exclusion removes endnotes marker from pdf 2003w03
@string.gsub!(/.+/m,'')
end
if @string =~/\\footnote/ #and para =~/^[1-6]#{@@tilde}/ # removing footnotes from headings!
cont_ln.gsub!(/\s*\\footnote\[\d+\]\{%\n .+? \}\s*/,' ')
cont_ln.gsub!(/\s*\\Footnote[A]\{[*+]+\d*\}\{%\n .+? \}\s*/,' ')
end
if @string !~/4#{@@tilde}/
@string.gsub!(/(#{@md.lv4}.*)\n?$/m,"\\subsubsection*{\\1}
\\addcontentsline{toc}{subsection}{#{cont_ln}}
\\markright{#{title}}")
else
@string.gsub!(/^\s*4#{@@tilde}\S+\s*(.*)?\n?$/m,"\\subsubsection*{\\1}
\\addcontentsline{toc}{subsection}{#{cont_ln}}
\\markright{#{title}}")
end
@string.gsub!(/#{@md.lv4}\s*(.marginpar)/m,'\1')
end
def level5
# there is a problem here with creation of headers does not do what you would want it to header starts with a * and is not in bold work on \\@string*, same for next section 2002w46
@string.strip! if @string
@string.gsub!(/(?:\\begin\{bfseries\}|\\begin\{itshape\})(.+?)(?:\\end\{bfseries\}|\\end\{itshape\})/m,'\1')
cont_ln=@string.dup
cont_ln.gsub!(/#{@@tex_pattern_margin_number}/,'')
cont_ln.gsub!(/5#{@@tilde}\S*\s+/,'')
cont_ln.gsub!(/\\footnote\[\d+\]\{%.+?\\end\{scriptsize\}\s*\}/m,'') #arbitrary bugfix, revisit should not be necessary, eg. wta.1994 2004w22
cont_ln.gsub!(/\\Footnote[A]\{[*+]+\d*\}\{%.+?\\end\{scriptsize\}\s*\}/m,'') #arbitrary bugfix, revisit should not be necessary, eg. wta.1994 2004w22
cont_ln.gsub!(/\\\&/,' and ') #revisit: tmp bugfix 200507, substitutes & with 'and' in toc, needed e.g. for AT&T, see ffa
@string.gsub!(/#{@md.lv5}\s+(#{@md.lv5})/m,'\1')
if @string =~/\\footnote/ #and para =~/^[1-6]#{@@tilde}/ # removing footnotes from headings!
cont_ln.gsub!(/\s*\\footnote\[\d+\]\{%\n .+? \}\s*/,' ')
cont_ln.gsub!(/\s*\\Footnote[A]\{[*+]+\d*\}\{%\n .+? \}\s*/,' ')
end
if @string !~/5#{@@tilde}/
@string.gsub!(/(#{@md.lv5}.*?)\n?$/m,"\\subsubsection*{\\1}
\\addcontentsline{toc}{subsubsection}{#{cont_ln} \\\\
}")
else
@string.gsub!(/^\s*5#{@@tilde}\S*\s*(.*)?\n?$/m,"\\subsubsection*{\\1}
\\addcontentsline{toc}{subsubsection}{#{cont_ln} \\\\
}")
end
@string.gsub!(/#{@md.lv5}\s*(.marginpar)/m,'\1')
end
def level6
# there is a problem here with creation of headers does not do what you would want it to header starts with a * and is not in bold work on \\sub@string*, same for previous section 2002w46
@string.strip! if @string
@string.gsub!(/(?:\\begin\{bfseries\}|\\begin\{itshape\})(.+?)(?:\\end\{bfseries\}|\\end\{itshape\})/m,'\1')
cont_ln=@string.dup
cont_ln.gsub!(/#{@@tex_pattern_margin_number}/,'')
cont_ln.gsub!(/6#{@@tilde}\S*\s+/,'')
cont_ln.gsub!(/\\footnote\[\d+\]\{%.+?\\end\{scriptsize\}\s*\}/m,'') #arbitrary bugfix, revisit should not be necessary, eg. wta.1994 2004w22
cont_ln.gsub!(/\\Footnote[A]\{[*+]+\d*\}\{%.+?\\end\{scriptsize\}\s*\}/m,'') #arbitrary bugfix, revisit should not be necessary, eg. wta.1994 2004w22
@string.gsub!(/#{@md.lv6}\s+(#{@md.lv6})/m,'\1')
if @string =~/\\footnote/ #and para =~/^[1-6]#{@@tilde}/ # removing footnotes from headings!
cont_ln.gsub!(/\s*\\footnote\[\d+\]\{%\n .+? \}\s*/,' ')
cont_ln.gsub!(/\s*\\Footnote[A]\{[*+]+\d*\}\{%\n .+? \}\s*/,' ')
end
@string.gsub!(/(#{@md.lv6}.*)\n?$/m,
"\\subsubsection*{\\1}") if (@string !~/6#{@@tilde}/)
@string.gsub!(/^\s*6#{@@tilde}\S*\s*(.*)?\n?$/m,
'\subsubsection*{\1}')
@string.gsub!(/#{@md.lv6}\s*(.marginpar)/m,'\1')
#end BUGWATCH
end
def indent(lev)
indent=case lev
when /1/; '0mm'
when /2/; '10mm'
when /3/; '20mm'
when /4/; '30mm'
when /5/; '40mm'
when /6/; '50mm'
when /7/; '60mm'
when /8/; '70mm'
when /9/; '80mm'
end
@string.gsub!(/<:i#{lev}>\s*(.*)/m,
"\\begin{ParagraphIndent}{#{indent}}\\1
\\end{ParagraphIndent}}")
end
def symbol_graphic
dir=SiSU_Env::Info_env.new(@md.fns)
image='c_' + /<:=\s*(\S+?)\s*>/m.match(@string).captures.join + '.png' #watch
if FileTest.file?("#{dir.path.image_source_tex}/#{image}")
@string.gsub!(/<:=\s*(\S+?)\s*>/,
"\\includegraphics*[width=11pt]{#{dir.path.image_source_tex}/c_\\1.png}")
else
tell=SiSU_Screen::Ansi.new(@md.cmd,"ERROR - image:",%{"#{image}" missing},"search path: #{dir.path.image_source_tex}")
tell.error2 unless @md.cmd =~/q/
@string.gsub!(/\{\S+\.(png|jpg|gif).+?\}(?:https?|file|ftp):\/\/\S+/,'') # fragile match operator\\ fragile !
end
end
def image
dir=SiSU_Env::Info_env.new(@md.fns)
image,m=/<:image\s+(\S+)\s+.+?width=``(\d+)''.+?>/m.match(@string).captures
width=m[1] || '100'
width=width.to_i*0.4
image_source=if @md.fns =~/\.(?:ssm\.)?sst$/ \
and FileTest.file?("#{dir.path.image_source_local_tex}/#{image}")
dir.path.image_source_local_tex
elsif @md.fns =~/\.-ss[tm]$/ \
and FileTest.file?("#{dir.path.image_source_remote_tex}/#{image}")
dir.path.image_source_remote_tex
elsif FileTest.file?("#{dir.path.image_source_tex}/#{image}")
dir.path.image_source_tex
else
tell=SiSU_Screen::Ansi.new(@md.cmd,"ERROR - image:",%{"#{image}" missing},"search locations: #{dir.path.image_source_local_tex},#{dir.path.image_source_remote_tex} and #{dir.path.image_source_tex}")
tell.error2 unless @md.cmd =~/q/
nil
end
if image_source
@string.gsub!(/<:image\s+((?:https?|file|ftp)\S+)\s+(\S+)\s+.+\s+?>/,
@center_begin + "\\href{\\1}{\\includegraphics*[width=#{width}pt]{#{image_source}/\\2}}" + @center_end )
@string.gsub!(/<:image\s+(\S+)\s+.+\s+?>/,
@center_begin + "\\includegraphics*[width=#{width}pt]{#{image_source}/\\1}" + @center_end )
else @string.gsub!(/<:image\s+(\S+)\s+.+\s+?>/,'\1}')
end
end
def png #fc missing image check
dir=SiSU_Env::Info_env.new(@md.fns)
# messy clean up
z=@string[/\\\{(\S.+?)\}(?:image|png)/,1].strip if @string =~ /\\\{\S.+?\}(?:image|png)/ # match operator for z \\ fragile !
if z #debug 2004w14
image=z[/(\S+?\.(?:png|jpg|gif)\b)/m]
image.gsub!(/\\/,'')
width=if z =~ /\d+x\d*/
w=(z[/(\d+)x\d*/,1]).to_i
w*0.8
else '100' #revisit, is bug for small images/icons
end
width='380' if width.to_i > 380
c=z[/``(.+?)''/m]
end
hsp="\n{\\color{mywhite} .}&~\n" # ~ character for hardspace
caption="{\\\\\\\ \n\\begin{scriptsize}#{hsp*3}#{c}\\end{scriptsize}&}" if c
#caption="{\\\\\\\ \n\\begin{scriptsize}#{hsp*3}#{c[1]}\\end{scriptsize}&}" if c
image_source=if @md.fns =~/\.(?:ssm\.)?sst$/ \
and FileTest.file?("#{dir.path.image_source_local_tex}/#{image}")
dir.path.image_source_local_tex
elsif @md.fns =~/\.-ss[tm]$/ \
and FileTest.file?("#{dir.path.image_source_remote_tex}/#{image}")
dir.path.image_source_remote_tex
elsif FileTest.file?("#{dir.path.image_source_tex}/#{image}")
dir.path.image_source_tex
else
unless image.nil? \
or image.length < 2
tell=SiSU_Screen::Ansi.new(@md.cmd,"ERROR - image:",%{"#{image}" missing},"search locations: #{dir.path.image_source_local_tex},#{dir.path.image_source_remote_tex} and #{dir.path.image_source_tex}")
tell.error2 unless @md.cmd =~/q/
end
nil
end
if image_source
@string.gsub!(/\\\{\S+\.(png|jpg|gif).+?\}(image|png)/, # fragile match operator\\ fragile !
"#@center_begin\n\\includegraphics*[width=#{width}pt]{#{image_source}/#{image}}#{caption}#@center_end")
else
@string.gsub!(/\\\{\S+\.(png|jpg|gif).+?\}(image|png)/,'') # fragile match operator\\ fragile !
end
end
def http_word_mode #(orientation='')
# clean up ! - work area, testing
dir=SiSU_Env::Info_env.new(@md.fns)
@words=[]
@url_generic_rgx=/\\\{.+?\\?\}(?:https?|file|ftp):\S+/
@string.each do |word|
@words << if word=~@url_generic_rgx
if word =~/\\\{(?:.+?)\\?\}(?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?(?:[;.,]?(?:\s|$)|(?:\s|$))/
regx_url=%r/\\\{(.+?)\\?\}((?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?)(?:[;.,]?(?:\s|$)|(?:\s|$))/
punctuate=/\\\{.+?\\?\}(?:https?|file|ftp):\/\/\S+?\.[^'"><\s]+?([;.,]?(?:\s|$))/.match(word).captures.join
else
regx_url=%r/\\\{(.+?)\\?\}((?:https?|file|ftp):\S+)/
punctuate=''
end
z,url=regx_url.match(word).captures if word =~regx_url
url=url.strip
if word =~/\{\s*\S+\.?(?:png|jpg|gif)/ \
and word=~/\s+\d+x\d+\s+/
image,x,y=z.scan(/\S+/)
image.gsub!(/\\/,'')
width=if z =~/(\d+)x\d*/
z[/(\d+)x\d*/,1]
else 200
end
dm=case @md.papersize
when /a4/; @tx.a4
when /letter/; @tx.letter
when /legal/; @tx.legal
when /b5/; @tx.b5
when /a5/; @tx.a5
else @tx.a4
end
width=if width.to_i > dm.landscape.img_px
dm.landscape.img_px
else width
end
c=z[/``(.+?)''/m,1]
hsp="\n{\\color{mywhite} .}&~\n" # ~ character for hardspace
caption=if c
"{\\\\\ \n\\begin{scriptsize}#{hsp*3}#{c}\\end{scriptsize}&}"
else ''
end
elsif word =~/\{\s*(\S+\.?\.(?:png|jpg|gif))/
tell=SiSU_Screen::Ansi.new(@md.cmd,%{document built without image: "#{$1}" as image dimensions not provided (& librmagick-ruby is not installed)?\n})
tell.print_grey #unless @opt.cmd =~/q/
end
word=if image #most images fc etc. #% clean up !
word=if @md.fns =~/\.(?:ssm\.)?sst$/ \
and FileTest.file?("#{dir.path.image_source_local_tex}/#{image}")
word=if word =~ /(\{[a-zA-Z0-9_\\]+\.(?:png|jpg|gif).+?\}(?:https?|file|ftp):\/\/\S+)/
"#@center_begin\\\n\\href{#{url}}{\\includegraphics*[width=#{width}pt]{#{dir.path.image_source_local_tex}/#{image}}}#{caption} #@center_end"
end
word
elsif @md.fns =~/\.-ss[tm]$/ \
and FileTest.file?("#{dir.path.image_source_remote_tex}/#{image}")
word=if word =~ /(\{[a-zA-Z0-9_\\]+\.(?:png|jpg|gif).+?\}(?:https?|file|ftp):\/\/\S+)/
"#@center_begin\\\n\\href{#{url}}{\\includegraphics*[width=#{width}pt]{#{dir.path.image_source_remote_tex}/#{image}}}#{caption}#@center_end"
end
word
elsif FileTest.file?("#{dir.path.image_source_tex}/#{image}")
word=if word =~/(\{[a-zA-Z0-9_\\]+\.(?:png|jpg|gif).+?\}(?:https?|file|ftp):\/\/\S+)/
"#@center_begin\\\n\\href{#{url}}\n{\\includegraphics*[width=#{width}pt]{#{dir.path.image_source_tex}/#{image}}}#{caption}#@center_end"
end
word
else
tell=SiSU_Screen::Ansi.new(@md.cmd,"ERROR - image:",%{"#{image}" missing},"search locations: #{dir.path.image_source_local_tex},#{dir.path.image_source_remote_tex} and #{dir.path.image_source_tex}")
tell.error2 unless @md.cmd =~/q/
word='' if word =~ /\{\S+\.(png|jpg|gif).+?\}(?:https?|file|ftp):\/\/\S+/
word
end
else
link=z.strip #[/(.+?)\\/m,1]
word="\\href{#{url}}{#{link}}#{punctuate}" if word =~/\\\{.+?\\\}(?:https?|file|ftp):\/\/\S+/
word
end
else word
end
end
@words=@words.join
@words
end
def http
wm=@string.dup.scan(/\\\{.+?\\\}(?:(?:https?|file|ftp):\S+|image)|\w+\s*|./m)
@string=SiSU_TeX_Pdf::Format_text_object.new(@md,wm).http_word_mode #(orientation)
end
def language
@lang=if @md.dc_language[:code]
case @md.dc_language[:code]
when 'en'; 'english'
when 'us'; 'USenglish' # depreciated, see iso-639-2
when 'fr'; 'french'
when 'de'; 'ngerman'
when 'it'; 'italian'
when 'es'; 'spanish'
when 'pt'; 'portuges'
#when 'br'; 'brazilian' # depreciated, see iso-639-2
when 'sv'; 'swedish'
when 'da'; 'danish'
when 'fi'; 'finnish'
when 'no'; 'norske,nynorsk'
when 'is'; 'icelandic'
when 'nl'; 'dutch'
when 'et'; 'estonian'
when 'hu'; 'magyar'
when 'pl'; 'polish'
when 'ro'; 'romanian'
when 'ru'; 'russian'
when 'gl'; 'greek'
when 'uk'; 'ukrainian'
when 'tr'; 'turkish'
when 'sk'; 'slovak'
when 'sl'; 'slovenian'
when 'hr'; 'croatian'
when 'cs'; 'czech'
when 'bg'; 'bulgarian'
else 'english'
end
else 'english'
end
end
def title
@string=Format_text_object.new(@md,@string).special_characters_safe
if @string1
@string1=Format_text_object.new(@md,@string1).special_characters_safe
@string1.gsub!(/\$/,"\\$")
"\n\\title{#@string#{@@tex_backslash*2} \\textbf{\\normalsize #@string1}\\normalsize}"
else "\n\\title{#@string}"
end
end
def title_landscape
title
end
def title_portrait
title
end
def tex_head_lang #babel 18n
language
#@md.dc_language[:name]
lang=if @lang =~/^(?:en)$/; @lang
else "#@lang,english"
end
end
def tex_head_encode
case @tex2pdf
when /xe/
<|#{@md.lv1}|#{@md.lv2}|#{@md.lv3}|#{@md.lv4}|#{@md.lv5}|#{@md.lv6})/
@string.gsub!(/^\s*(.+)/m,"#{paranumber_display}\\1\n") #watch - in 1-6 is suspect
else
if (@string =~/^(?:[1-6a-z-]#{@@tilde}\S*|<:.+?>)/) #watch - in 1-6 is suspect
@string.gsub!(/^([1-6a-z-]#{@@tilde}\S*)\s*(.+)/m,"\\1 #{paranumber_display} \\2\n") #watch - in 1-6 is suspect
@string.gsub!(/^(<:.+?>)\s*(.+)/m,"\\1 #{paranumber_display}\\2\n")
else
@string.gsub!(/((#{@md.lv1}|#{@md.lv2}|#{@md.lv3}|#{@md.lv4}|#{@md.lv5}|#{@md.lv6}).+)$/,"\\2 #{paranumber_display}\\1\n")
end
end
@string
end
end
end
__END__