diff options
author | Marius <mariausol@gmail.com> | 2013-03-15 20:40:14 +0200 |
---|---|---|
committer | Marius <mariausol@gmail.com> | 2013-03-15 20:40:14 +0200 |
commit | 792b2ca2d206c2c90cc9967a8ae4916f53f902d7 (patch) | |
tree | 61a6b50fcad361326d0a7e6c305ab9d291d699e7 /tex/context/base/lpdf-col.lua | |
parent | 5649bfe8b7ccdd5a8b02951fc9f6a0dbbdf48256 (diff) | |
download | context-792b2ca2d206c2c90cc9967a8ae4916f53f902d7.tar.gz |
beta 2013.03.15 19:22
Diffstat (limited to 'tex/context/base/lpdf-col.lua')
-rw-r--r-- | tex/context/base/lpdf-col.lua | 90 |
1 files changed, 40 insertions, 50 deletions
diff --git a/tex/context/base/lpdf-col.lua b/tex/context/base/lpdf-col.lua index 0109ca602..b358d0820 100644 --- a/tex/context/base/lpdf-col.lua +++ b/tex/context/base/lpdf-col.lua @@ -6,10 +6,11 @@ if not modules then modules = { } end modules ['lpdf-col'] = { license = "see context related readme files" } -local type, next, tostring = type, next, tostring +local type, next, tostring, tonumber = type, next, tostring, tonumber local char, byte, format, gsub, rep, gmatch = string.char, string.byte, string.format, string.gsub, string.rep, string.gmatch local concat = table.concat local round = math.round +local formatters = string.formatters local backends, lpdf, nodes = backends, lpdf, nodes @@ -43,10 +44,18 @@ local forcedmodel = colors.forcedmodel local c_transparency = pdfconstant("Transparency") -local f_gray = formatters["%.3f g %.3f G"] -local f_rgb = formatters["%.3f %.3f %.3f rg %.3f %.3f %.3f RG"] -local f_cmyk = formatters["%.3f %.3f %.3f %.3f k %.3f %.3f %.3f %.3f K"] -local f_cm = formatters["q %f %f %f %f %f %f cm"] +local f_gray = formatters["%.3f g %.3f G"] +local f_rgb = formatters["%.3f %.3f %.3f rg %.3f %.3f %.3f RG"] +local f_cmyk = formatters["%.3f %.3f %.3f %.3f k %.3f %.3f %.3f %.3f K"] +local f_spot = formatters["/%s cs /%s CS %s SCN %s scn"] +local f_tr = formatters["Tr%s"] +local f_cm = formatters["q %f %f %f %f %f %f cm"] +local f_effect = formatters["%s Tc %s w %s Tr"] +local f_tr_gs = formatters["/Tr%s gs"] +local f_num_1 = tostring +local f_num_2 = formatters["%s %s"] +local f_num_3 = formatters["%s %s %s"] +local f_num_4 = formatters["%s %s %s %s"] local report_color = logs.reporter("colors","backend") @@ -120,11 +129,11 @@ function nodeinjections.spotcolor(n,f,d,p) if type(p) == "string" then p = gsub(p,","," ") -- brr misuse of spot end - return register(pdfliteral(format("/%s cs /%s CS %s SCN %s scn",n,n,p,p))) + return register(pdfliteral(f_spot(n,n,p,p))) end function nodeinjections.transparency(n) - return register(pdfliteral(format("/Tr%s gs",n))) + return register(pdfliteral(f_tr_gs(n))) end -- a bit weird but let's keep it here for a while @@ -143,7 +152,7 @@ function nodeinjections.effect(effect,stretch,rulethickness) -- always, no zero test (removed) rulethickness = bp * rulethickness effect = effects[effect] or effects['normal'] - return register(pdfliteral(format("%s Tc %s w %s Tr",stretch,rulethickness,effect))) -- watch order + return register(pdfliteral(f_effect(stretch,rulethickness,effect))) -- watch order end -- spot- and indexcolors @@ -199,12 +208,12 @@ local function registersomespotcolor(name,noffractions,names,p,colorspace,range, Range = range, } local calculations = pdfflushstreamobject(format("{ %s }",funct),dictionary) - -- local calculations = pdfobject { - -- type = "stream", - -- immediate = true, - -- string = format("{ %s }",funct), - -- attr = dictionary(), - -- } + -- local calculations = pdfobject { + -- type = "stream", + -- immediate = true, + -- string = format("{ %s }",funct), + -- attr = dictionary(), + -- } local array = pdfarray { pdf_separation, pdfconstant(spotcolornames[name] or name), @@ -353,7 +362,7 @@ function registrations.rgbspotcolor(name,noffractions,names,p,r,g,b) if noffractions == 1 then registersomespotcolor(name,noffractions,names,p,pdf_device_rgb,pdf_rbg_range,f_rgb_function(r,g,b)) else - registersomespotcolor(name,noffractions,names,p,pdf_device_rgb,pdf_rbg_range,format("%s %s %s",r,g,b)) + registersomespotcolor(name,noffractions,names,p,pdf_device_rgb,pdf_rbg_range,f_num_3(r,g,b)) end delayindexcolor(name,names,function() return registersomeindexcolor(name,noffractions,names,p,pdf_device_rgb,pdf_rgb_range,f_rgb_function(r,g,b)) @@ -364,7 +373,7 @@ function registrations.cmykspotcolor(name,noffractions,names,p,c,m,y,k) if noffractions == 1 then registersomespotcolor(name,noffractions,names,p,pdf_device_cmyk,pdf_cmyk_range,f_cmyk_function(c,m,y,k)) else - registersomespotcolor(name,noffractions,names,p,pdf_device_cmyk,pdf_cmyk_range,format("%s %s %s %s",c,m,y,k)) + registersomespotcolor(name,noffractions,names,p,pdf_device_cmyk,pdf_cmyk_range,f_num_4(c,m,y,k)) end delayindexcolor(name,names,function() return registersomeindexcolor(name,noffractions,names,p,pdf_device_cmyk,pdf_cmyk_range,f_cmyk_function(c,m,y,k)) @@ -375,7 +384,7 @@ function registrations.grayspotcolor(name,noffractions,names,p,s) if noffractions == 1 then registersomespotcolor(name,noffractions,names,p,pdf_device_gray,pdf_gray_range,f_gray_function(s)) else - registersomespotcolor(name,noffractions,names,p,pdf_device_gray,pdf_gray_range,s) + registersomespotcolor(name,noffractions,names,p,pdf_device_gray,pdf_gray_range,f_num_1(s)) end delayindexcolor(name,names,function() return registersomeindexcolor(name,noffractions,names,p,pdf_device_gray,pdf_gray_range,f_gray_function(s)) @@ -461,7 +470,7 @@ function registrations.transparency(n,a,t) local mr = pdfreference(m) transparencyhash[n] = m documenttransparencies[n] = mr - lpdf.adddocumentextgstate(format("Tr%s",n),mr) + lpdf.adddocumentextgstate(f_tr(n),mr) end end @@ -499,7 +508,7 @@ local function lpdfcolor(model,ca,default) -- todo: use gray when no color if type(p) == "string" then p = gsub(p,","," ") -- brr misuse of spot end - return format("/%s cs /%s CS %s SCN %s scn",n,n,p,p) + return f_spot(n,n,p,p) end else return f_gray(default or 0,default or 0) @@ -545,9 +554,9 @@ function lpdf.transparency(ct,default) -- kind of overlaps with transparencycode if transparencies.supported then local ct = transparenciesvalue(ct) if ct then - return format("/Tr%s gs",registertransparancy(nil,ct[1],ct[2],true)) + return f_tr_gs(registertransparancy(nil,ct[1],ct[2],true)) else - return "/Tr0 gs" + return f_tr_gs(0) end else return "" @@ -562,40 +571,19 @@ function lpdf.colorvalue(model,ca,default) end model = forcedmodel(model) if model == 2 then - return format("%s",cv[2]) + return f_num_1(cv[2]) elseif model == 3 then - return format("%s %s %s",cv[3],cv[4],cv[5]) + return f_num_3(cv[3],cv[4],cv[5]) elseif model == 4 then - return format("%s %s %s %s",cv[6],cv[7],cv[8],cv[9]) + return f_num_4(cv[6],cv[7],cv[8],cv[9]) else - return format("%s",cv[13]) + return f_num_1(cv[13]) end else - return format("%s",default or 0) + return f_num_1(default or 0) end end ---~ function lpdf.fdfcolor(model,ca,default) ---~ local cv = colorsvalue(ca) ---~ if cv then ---~ if model == 1 then ---~ model = cv[1] ---~ end ---~ model = forcedmodel(model) ---~ if model == 2 then ---~ return format("[%s]",cv[2]) ---~ elseif model == 3 then ---~ return format("[%s %s %s]",cv[3],cv[4],cv[5]) ---~ elseif model == 4 then ---~ return format("[%s %s %s %s]",cv[6],cv[7],cv[8],cv[9]) ---~ elseif model == 4 then ---~ return format("[%s]",cv[13]) ---~ end ---~ else ---~ return format("[%s]",default or 0) ---~ end ---~ end - function lpdf.colorvalues(model,ca,default) local cv = colorsvalue(ca) if cv then @@ -684,7 +672,7 @@ end function lpdf.transparencycode(a,t) if transparencies.supported then intransparency = true - return format("/Tr%s gs",registertransparancy(nil,a,t,true)) -- true forces resource + return f_tr_gs(registertransparancy(nil,a,t,true)) -- true forces resource else return "" end @@ -693,7 +681,7 @@ end function lpdf.finishtransparencycode() if transparencies.supported and intransparency then intransparency = false - return "/Tr0 gs" -- we happen to know this -) + return f_tr_gs(0) -- we happen to know this -) else return "" end @@ -701,6 +689,8 @@ end -- this will move to lpdf-spe.lua +local f_slant = formatters["pdf: q 1 0 %f 1 0 0 cm"] + backends.pdf.tables.vfspecials = allocate { -- todo: distinguish between glyph and rule color red = { "special", 'pdf: 1 0 0 rg 1 0 0 RG' }, @@ -721,7 +711,7 @@ backends.pdf.tables.vfspecials = allocate { -- todo: distinguish between glyph a palegray = { "special", 'pdf: .75 g' }, }, - startslant = function(a) return { "special", format("pdf: q 1 0 %f 1 0 0 cm",a) } end, + startslant = function(a) return { "special", f_slant(a) } end, stopslant = { "special", "pdf: Q" }, } |