diff options
Diffstat (limited to 'tex')
| -rw-r--r-- | tex/context/base/cont-new.mkii | 2 | ||||
| -rw-r--r-- | tex/context/base/cont-new.mkiv | 2 | ||||
| -rw-r--r-- | tex/context/base/context-version.pdf | bin | 4148 -> 4152 bytes | |||
| -rw-r--r-- | tex/context/base/context-version.png | bin | 40426 -> 40647 bytes | |||
| -rw-r--r-- | tex/context/base/context.mkii | 2 | ||||
| -rw-r--r-- | tex/context/base/context.mkiv | 2 | ||||
| -rw-r--r-- | tex/context/base/data-lua.lua | 4 | ||||
| -rw-r--r-- | tex/context/base/phys-dim.lua | 15 | ||||
| -rw-r--r-- | tex/context/base/status-files.pdf | bin | 24538 -> 24539 bytes | |||
| -rw-r--r-- | tex/context/base/status-lua.pdf | bin | 198684 -> 198711 bytes | |||
| -rw-r--r-- | tex/context/base/util-prs.lua | 50 | ||||
| -rw-r--r-- | tex/generic/context/luatex/luatex-fonts-merged.lua | 2 | 
12 files changed, 66 insertions, 13 deletions
| diff --git a/tex/context/base/cont-new.mkii b/tex/context/base/cont-new.mkii index 546aabf02..1156b3e27 100644 --- a/tex/context/base/cont-new.mkii +++ b/tex/context/base/cont-new.mkii @@ -11,7 +11,7 @@  %C therefore copyrighted by \PRAGMA. See mreadme.pdf for  %C details. -\newcontextversion{2012.11.22 18:09} +\newcontextversion{2012.11.23 17:35}  %D This file is loaded at runtime, thereby providing an  %D excellent place for hacks, patches, extensions and new diff --git a/tex/context/base/cont-new.mkiv b/tex/context/base/cont-new.mkiv index 58282d5e9..06127c68b 100644 --- a/tex/context/base/cont-new.mkiv +++ b/tex/context/base/cont-new.mkiv @@ -11,7 +11,7 @@  %C therefore copyrighted by \PRAGMA. See mreadme.pdf for  %C details. -\newcontextversion{2012.11.22 18:09} +\newcontextversion{2012.11.23 17:35}  %D This file is loaded at runtime, thereby providing an excellent place for  %D hacks, patches, extensions and new features. diff --git a/tex/context/base/context-version.pdf b/tex/context/base/context-version.pdfBinary files differ index 3349ae881..d17c41110 100644 --- a/tex/context/base/context-version.pdf +++ b/tex/context/base/context-version.pdf diff --git a/tex/context/base/context-version.png b/tex/context/base/context-version.pngBinary files differ index d02983feb..43687ee49 100644 --- a/tex/context/base/context-version.png +++ b/tex/context/base/context-version.png diff --git a/tex/context/base/context.mkii b/tex/context/base/context.mkii index 9d04afb8e..9520ff3ff 100644 --- a/tex/context/base/context.mkii +++ b/tex/context/base/context.mkii @@ -20,7 +20,7 @@  %D your styles an modules.  \edef\contextformat {\jobname} -\edef\contextversion{2012.11.22 18:09} +\edef\contextversion{2012.11.23 17:35}  %D For those who want to use this: diff --git a/tex/context/base/context.mkiv b/tex/context/base/context.mkiv index 94dcd3c94..3f6175d13 100644 --- a/tex/context/base/context.mkiv +++ b/tex/context/base/context.mkiv @@ -25,7 +25,7 @@  %D up and the dependencies are more consistent.  \edef\contextformat {\jobname} -\edef\contextversion{2012.11.22 18:09} +\edef\contextversion{2012.11.23 17:35}  %D For those who want to use this: diff --git a/tex/context/base/data-lua.lua b/tex/context/base/data-lua.lua index 87d346201..c63851525 100644 --- a/tex/context/base/data-lua.lua +++ b/tex/context/base/data-lua.lua @@ -115,6 +115,10 @@ function package.extraclibpath(...)      end  end +if not package.loaders then +    package.loaders = package.searchers -- 5.2 +end +  if not package.loaders[-2] then      -- use package-path and package-cpath      package.loaders[-2] = package.loaders[2] diff --git a/tex/context/base/phys-dim.lua b/tex/context/base/phys-dim.lua index 5b883ac88..88a522195 100644 --- a/tex/context/base/phys-dim.lua +++ b/tex/context/base/phys-dim.lua @@ -82,8 +82,16 @@ local space          = P(" ")  local lparent        = P("(")  local rparent        = P(")") +local lbrace         = P("{") +local rbrace         = P("}") +  local digits         = digit^1 +local powerdigits    = plus  * C(digits) / context.digitspowerplus +                     + minus * C(digits) / context.digitspowerminus +                     +         C(digits) / context.digitspower + +  local ddigitspace    = digitspace  / "" / context.digitsspace  local ddigit         = digits           / context.digitsdigit  local dsemicomma     = semicolon   / "" / context.digitsseparatorspace @@ -100,11 +108,8 @@ local dnegative      = negative    / "" / context.digitsnegative  local dhighspace     = highspace   / "" / context.digitshighspace  local dsomesign      = plus        / "" / context.digitsplus                       + minus       / "" / context.digitsminus -local dpower         = power       / "" * ( -                           plus  * C(digits) / context.digitspowerplus -                         + minus * C(digits) / context.digitspowerminus -                         +         C(digits) / context.digitspower -                     ) +local dpower         = power       / "" * ( powerdigits + lbrace * powerdigits * rbrace ) +  local dpadding       = padding     / "" / context.digitszeropadding -- todo  local dleader        = (dpositive + dnegative + dhighspace + dsomesign + dsignspace)^0 diff --git a/tex/context/base/status-files.pdf b/tex/context/base/status-files.pdfBinary files differ index 965f9ab05..83936aba1 100644 --- a/tex/context/base/status-files.pdf +++ b/tex/context/base/status-files.pdf diff --git a/tex/context/base/status-lua.pdf b/tex/context/base/status-lua.pdfBinary files differ index aa44ac99f..736cc36fc 100644 --- a/tex/context/base/status-lua.pdf +++ b/tex/context/base/status-lua.pdf diff --git a/tex/context/base/util-prs.lua b/tex/context/base/util-prs.lua index 4166fca25..3cfb3e5f3 100644 --- a/tex/context/base/util-prs.lua +++ b/tex/context/base/util-prs.lua @@ -8,7 +8,7 @@ if not modules then modules = { } end modules ['util-prs'] = {  local lpeg, table, string = lpeg, table, string -local P, R, V, S, C, Ct, Cs, Carg, Cc, Cg, Cf = lpeg.P, lpeg.R, lpeg.V, lpeg.S, lpeg.C, lpeg.Ct, lpeg.Cs, lpeg.Carg, lpeg.Cc, lpeg.Cg, lpeg.Cf +local P, R, V, S, C, Ct, Cs, Carg, Cc, Cg, Cf, Cp = lpeg.P, lpeg.R, lpeg.V, lpeg.S, lpeg.C, lpeg.Ct, lpeg.Cs, lpeg.Carg, lpeg.Cc, lpeg.Cg, lpeg.Cf, lpeg.Cp  local lpegmatch, patterns = lpeg.match, lpeg.patterns  local concat, format, gmatch, find = table.concat, string.format, string.gmatch, string.find  local tostring, type, next, rawset = tostring, type, next, rawset @@ -305,10 +305,13 @@ end  -- inspect(lpeg.match(pattern,[[key="value"]])) -local newline = S('\r\n') +local defaultspecification = { separator = ",", quote = '"' } + +-- this version accepts multiple separators and quotes as used in the +-- database module  function parsers.csvsplitter(specification) -    specification   = specification or { } +    specification     = specification and table.setmetatableindex(specification,defaultspecification) or defaultspecification      local separator = specification.separator      local quotechar = specification.quote      local separator = S(separator ~= "" and separator or ",") @@ -331,3 +334,44 @@ function parsers.csvsplitter(specification)          return lpegmatch(parser,data)      end  end + +-- and this is a slightly patched version of a version posted by Philipp Gesang + +-- local mycsvsplitter = utilities.parsers.rfc4180splitter() +-- +-- local crap = [[ +-- first,second,third,fourth +-- "1","2","3","4" +-- "a","b","c","d" +-- "foo","bar""baz","boogie","xyzzy" +-- ]] +-- +-- local list, names = mycsvsplitter(crap,true)   inspect(list) inspect(names) +-- local list, names = mycsvsplitter(crap)        inspect(list) inspect(names) + +function parsers.rfc4180splitter(specification) +    specification     = specification and table.setmetatableindex(specification,defaultspecification) or defaultspecification +    local separator   = specification.separator --> rfc: COMMA +    local quotechar   = P(specification.quote)  -->      DQUOTE +    local dquotechar  = quotechar * quotechar   -->      2DQUOTE +                      / specification.quote +    local separator   = S(separator ~= "" and separator or ",") +    local escaped     = quotechar +                      * Cs((dquotechar + (1 - quotechar))^0) +                      * quotechar +    local non_escaped = C((1 - quotechar - newline - separator)^1) +    local field       = escaped + non_escaped +    local record      = Ct((field * separator^-1)^1) +    local headerline  = record * Cp() +    local wholeblob   = Ct((newline^-1 * record)^0) +    return function(data,getheader) +        if getheader then +            local header, position = lpegmatch(headerline,data) +            local data = lpegmatch(wholeblob,data,position) +            return data, header +        else +            return lpegmatch(wholeblob,data) +        end +    end +end + diff --git a/tex/generic/context/luatex/luatex-fonts-merged.lua b/tex/generic/context/luatex/luatex-fonts-merged.lua index 287c85996..9bd7f8297 100644 --- a/tex/generic/context/luatex/luatex-fonts-merged.lua +++ b/tex/generic/context/luatex/luatex-fonts-merged.lua @@ -1,6 +1,6 @@  -- merged file : luatex-fonts-merged.lua  -- parent file : luatex-fonts.lua --- merge date  : 11/22/12 18:09:16 +-- merge date  : 11/23/12 17:35:57  do -- begin closure to overcome local limits and interference | 
