diff options
| author | Hans Hagen <pragma@wxs.nl> | 2012-06-05 09:16:00 +0200 | 
|---|---|---|
| committer | Hans Hagen <pragma@wxs.nl> | 2012-06-05 09:16:00 +0200 | 
| commit | 1cbef76ff4aa6cc1f7dc1d38c4b0514e94ad59a5 (patch) | |
| tree | f825c9515b1d51e48dddd9a3bc0d0c51c6b407ed /tex/generic | |
| parent | c3efc6042c5a5a4d0f1a80bc3a097f0ae2963f7c (diff) | |
| download | context-1cbef76ff4aa6cc1f7dc1d38c4b0514e94ad59a5.tar.gz | |
beta 2012.06.05 09:16
Diffstat (limited to 'tex/generic')
| -rw-r--r-- | tex/generic/context/luatex/luatex-fonts-merged.lua | 63 | 
1 files changed, 53 insertions, 10 deletions
| diff --git a/tex/generic/context/luatex/luatex-fonts-merged.lua b/tex/generic/context/luatex/luatex-fonts-merged.lua index ea509c338..96a34326e 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  : 05/30/12 11:26:34 +-- merge date  : 06/05/12 09:16:10  do -- begin closure to overcome local limits and interference @@ -1331,12 +1331,16 @@ function lpeg.split(separator,str)  end  function string.split(str,separator) -    local c = cache[separator] -    if not c then -        c = tsplitat(separator) -        cache[separator] = c +    if separator then +        local c = cache[separator] +        if not c then +            c = tsplitat(separator) +            cache[separator] = c +        end +        return match(c,str) +    else +        return { str }      end -    return match(c,str)  end  local spacing  = patterns.spacer^0 * newline -- sort of strip @@ -2468,14 +2472,14 @@ else      io.fileseparator, io.pathseparator = "/" , ":"  end -function io.loaddata(filename,textmode) +function io.loaddata(filename,textmode) -- return nil if empty      local f = io.open(filename,(textmode and 'r') or 'rb')      if f then          local data = f:read('*all')          f:close() -        return data -    else -        return nil +        if #data > 0 then +            return data +        end      end  end @@ -2497,6 +2501,45 @@ function io.savedata(filename,data,joiner)      end  end +function io.loadlines(filename,n) -- return nil if empty +    local f = io.open(filename,'r') +    if f then +        if n then +            local lines = { } +            for i=1,n do +                local line = f:read("*lines") +                if line then +                    lines[#lines+1] = line +                else +                    break +                end +            end +            f:close() +            lines = concat(lines,"\n") +            if #lines > 0 then +                return lines +            end +        else +            local line = f:read("*line") or "" +            assert(f:close()) +            if #line > 0 then +                return line +            end +        end +    end +end + +function io.loadchunk(filename,n) +    local f = io.open(filename,'rb') +    if f then +        local data = f:read(n or 1024) +        f:close() +        if #data > 0 then +            return data +        end +    end +end +  function io.exists(filename)      local f = io.open(filename)      if f == nil then | 
