summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHans Hagen <pragma@wxs.nl>2011-05-12 15:19:00 +0200
committerHans Hagen <pragma@wxs.nl>2011-05-12 15:19:00 +0200
commit4bfd1949398de94ab92544f2c4c49b9c41c1189f (patch)
treec4682b5224fd861b9d833092e0bd0e78bbf28a66
parent7b7f140fd9e06487b7eca4efe37b13c54df5bb29 (diff)
downloadcontext-4bfd1949398de94ab92544f2c4c49b9c41c1189f.tar.gz
beta 2011.05.12 15:19
-rw-r--r--tex/context/base/cont-new.mkii2
-rw-r--r--tex/context/base/cont-new.mkiv2
-rw-r--r--tex/context/base/context.mkii2
-rw-r--r--tex/context/base/context.mkiv2
-rw-r--r--tex/context/base/font-con.lua11
-rw-r--r--tex/context/base/font-ctx.lua33
-rw-r--r--tex/context/base/font-ini.mkiv33
-rw-r--r--tex/context/base/node-inj.lua3
-rw-r--r--tex/context/base/status-files.pdfbin23541 -> 23572 bytes
-rw-r--r--tex/context/base/status-lua.pdfbin154319 -> 154274 bytes
-rw-r--r--tex/context/base/type-otf.mkiv27
-rw-r--r--tex/generic/context/luatex-fonts-merged.lua16
12 files changed, 81 insertions, 50 deletions
diff --git a/tex/context/base/cont-new.mkii b/tex/context/base/cont-new.mkii
index dabf23b77..e73e00f0b 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{2011.05.10 19:20}
+\newcontextversion{2011.05.12 15:19}
%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 f18429a55..aefb7d43a 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{2011.05.10 19:20}
+\newcontextversion{2011.05.12 15:19}
%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/context.mkii b/tex/context/base/context.mkii
index 5c71cd25b..4c33eba16 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{2011.05.10 19:20}
+\edef\contextversion{2011.05.12 15:19}
%D For those who want to use this:
diff --git a/tex/context/base/context.mkiv b/tex/context/base/context.mkiv
index 4e616920d..17dde0702 100644
--- a/tex/context/base/context.mkiv
+++ b/tex/context/base/context.mkiv
@@ -20,7 +20,7 @@
%D your styles an modules.
\edef\contextformat {\jobname}
-\edef\contextversion{2011.05.10 19:20}
+\edef\contextversion{2011.05.12 15:19}
%D For those who want to use this:
diff --git a/tex/context/base/font-con.lua b/tex/context/base/font-con.lua
index 0da0e8e46..5d30842ef 100644
--- a/tex/context/base/font-con.lua
+++ b/tex/context/base/font-con.lua
@@ -995,15 +995,17 @@ a helper function.</p>
--ldx]]--
function constructors.checkedfeatures(what,features)
+ local defaults = handlers[what].features.defaults
if features and next(features) then
- for key, value in next, handlers[what].features.defaults do
+ features = fastcopy(features) -- can be inherited
+ for key, value in next, defaults do
if features[key] == nil then
features[key] = value
end
end
return features
else
- return fastcopy(defaults)
+ return fastcopy(defaults) -- we can change features in place
end
end
@@ -1019,6 +1021,7 @@ function constructors.initializefeatures(what,tfmdata,features,trace,report)
-- properties.mode can be enforces (for instance in font-otd)
local mode = properties.mode or (whatmodechecker and whatmodechecker(tfmdata,features,features.mode)) or features.mode or "base"
properties.mode = mode -- also status
+ features.mode = mode -- both properties.mode or features.mode can be changed
--
local done = { }
while true do
@@ -1028,6 +1031,7 @@ function constructors.initializefeatures(what,tfmdata,features,trace,report)
for i=1,#initializers do
local step = initializers[i]
local feature = step.name
+-- we could intercept mode here .. needs a rewrite of this whole loop then btu it's cleaner that way
local value = features[feature]
if not value then
-- disabled
@@ -1040,9 +1044,10 @@ function constructors.initializefeatures(what,tfmdata,features,trace,report)
tostring(value),mode or 'unknown', tfmdata.properties.fullname or 'unknown')
end
action(tfmdata,value,features) -- can set mode (e.g. goodies) so it can trigger a restart
- if mode ~= properties.mode then
+ if mode ~= properties.mode or mode ~= features.mode then
if whatmodechecker then
properties.mode = whatmodechecker(tfmdata,features,properties.mode) -- force checking
+ features.mode = properties.mode
end
if mode ~= properties.mode then
mode = properties.mode
diff --git a/tex/context/base/font-ctx.lua b/tex/context/base/font-ctx.lua
index 7d7b1253b..1bc3f3db9 100644
--- a/tex/context/base/font-ctx.lua
+++ b/tex/context/base/font-ctx.lua
@@ -48,6 +48,8 @@ local texattribute = tex.attribute
local otffeatures = fonts.constructors.newfeatures("otf")
local registerotffeature = otffeatures.register
+local baseprocessors = otffeatures.processors.base
+local baseinitializers = otffeatures.initializers.base
specifiers.contextsetups = specifiers.contextsetups or { }
specifiers.contextnumbers = specifiers.contextnumbers or { }
@@ -137,32 +139,49 @@ setmetatableindex(xheightdata, function(t,k)
end)
-- this cannot be a feature initializer as there is no auto namespace
--- so we never enter the loop then
+-- so we never enter the loop then; we can store the defaults in the tma
+-- file (features.gpos.mkmk = 1 etc)
+
+local needsnodemode = {
+ gpos_mark2mark = true,
+ gpos_mark2base = true,
+ gpos_mark2ligature = true,
+}
local function modechecker(tfmdata,features,mode) -- we cannot adapt features as they are shared!
if mode == "auto" then
- local script = features.script
- local language = features.language
local rawdata = tfmdata.shared.rawdata
- local sequences = rawdata and rawdata.resources.sequences
- if script and language and sequences and #sequences > 0 then
+ local resources = rawdata and rawdata.resources
+ local sequences = resources.sequences
+ if sequences and #sequences > 0 then
+ local script = features.script or "dflt"
+ local language = features.language or "dflt"
for feature, value in next, features do
if value then
local found = false
for i=1,#sequences do
- local features = sequences[i].features
+ local sequence = sequences[i]
+ local features = sequence.features
if features then
local scripts = features[feature]
if scripts then
local languages = scripts[script]
if languages and languages[language] then
if found then
+ -- more than one lookup
+ if trace_automode then
+ report_defining("forcing node mode in font %s for feature %s, script %s, language %s (multiple lookups)",file.basename(tfmdata.properties.name),feature,script,language)
+ end
features.mode = "node"
+ return "node"
+ elseif needsnodemode[sequence.type] then
if trace_automode then
- report_defining("forcing node mode due to features %s, script %s, language %s",feature,script,language)
+ report_defining("forcing node mode in font %s for feature %s, script %s, language %s (no base support)",file.basename(tfmdata.properties.name),feature,script,language)
end
+ features.mode = "node"
return "node"
else
+ -- at least one lookup
found = true
end
end
diff --git a/tex/context/base/font-ini.mkiv b/tex/context/base/font-ini.mkiv
index 8eb10e3ae..1c9cdcd32 100644
--- a/tex/context/base/font-ini.mkiv
+++ b/tex/context/base/font-ini.mkiv
@@ -2871,45 +2871,48 @@
{\global\expandafter\chardef\csname\??fq=#1\endcsname % beware () needed as we get two values returned
\ctxsprint{((fonts.specifiers.presetcontext("#1","#2","#3")))}\relax}
+\definefontfeature % experiment, this might move to the lua code
+ [always]
+ [mode=auto,
+ kern=yes,
+ mark=yes,
+ mkmk=yes,
+ curs=yes]
+
\definefontfeature
[default]
- [mode=auto, % was nothing
- liga=yes,
- kern=yes,
+ [always]
+ [liga=yes,
tlig=yes,
trep=yes] % texligatures=yes,texquotes=yes
\definefontfeature
[smallcaps]
- [mode=auto, % was nothing
- smcp=yes,
- kern=yes,
+ [always]
+ [smcp=yes,
tlig=yes,
trep=yes] % texligatures=yes,texquotes=yes
\definefontfeature
[oldstyle]
- [mode=auto, % was nothing
- onum=yes,
+ [always]
+ [onum=yes,
liga=yes,
- kern=yes,
tlig=yes,
trep=yes] % texligatures=yes,texquotes=yes
\definefontfeature % == default unless redefined
[ligatures]
- [mode=auto, % was nothing
- liga=yes,
- kern=yes,
+ [always]
+ [liga=yes,
tlig=yes,
trep=yes]
\definefontfeature % can be used for type1 fonts
[complete]
- [mode=auto, % was nothing
+ [always]
+ [compose=yes,
liga=yes,
- kern=yes,
- compose=yes,
tlig=yes,
trep=yes]
diff --git a/tex/context/base/node-inj.lua b/tex/context/base/node-inj.lua
index aee2d1575..b9ef9188f 100644
--- a/tex/context/base/node-inj.lua
+++ b/tex/context/base/node-inj.lua
@@ -321,8 +321,7 @@ function injections.handler(head,where,keep)
local d = mrks[index]
if d then
local rlmode = d[3]
- -- maybe better swap and "rlmode and rlmode < 0" as lr (1) is default
- if rlmode and rlmode > 0 then
+ if rlmode and rlmode >= 0 then
-- new per 2010-10-06, width adapted per 2010-02-03
-- we used to negate the width of marks because in tfm
-- that makes sense but we no longer do that so as a
diff --git a/tex/context/base/status-files.pdf b/tex/context/base/status-files.pdf
index 196f218e7..ad9e92d69 100644
--- a/tex/context/base/status-files.pdf
+++ b/tex/context/base/status-files.pdf
Binary files differ
diff --git a/tex/context/base/status-lua.pdf b/tex/context/base/status-lua.pdf
index 229ab2c5f..234a294af 100644
--- a/tex/context/base/status-lua.pdf
+++ b/tex/context/base/status-lua.pdf
Binary files differ
diff --git a/tex/context/base/type-otf.mkiv b/tex/context/base/type-otf.mkiv
index 224e6d980..9bb2d3e47 100644
--- a/tex/context/base/type-otf.mkiv
+++ b/tex/context/base/type-otf.mkiv
@@ -20,10 +20,10 @@
%
% \starttypescript [serif] [myserif] [name]
% \setups[font:fallback:serif]
-% \definefontsynonym [Serif] [file:myserif.ttf] [features=default]
-% \definefontsynonym [SerifBold] [file:myserifbold.ttf] [features=default]
-% \definefontsynonym [SerifItalic] [file:myserifitalic.ttf] [features=default]
-% \definefontsynonym [SerifBoldItalic] [file:myserifbolditalic.ttf] [features=default]
+% \definefontsynonym [Serif] [\s!file:myserif.ttf] [features=default]
+% \definefontsynonym [SerifBold] [\s!file:myserifbold.ttf] [features=default]
+% \definefontsynonym [SerifItalic] [\s!file:myserifitalic.ttf] [features=default]
+% \definefontsynonym [SerifBoldItalic] [\s!file:myserifbolditalic.ttf] [features=default]
% \stoptypescript
%
% \starttypescript[myfont]
@@ -223,6 +223,7 @@
\starttypescript [math] [modern,latin-modern,computer-modern,default] [name]
\definefontsynonym [MathRoman] [LMMathRoman-Regular]
+ \definefontsynonym [MathRomanBold] [LMMathRoman-Bold]
%definefontsynonym [MathExtension] [LMMathExtension-Regular]
%definefontsynonym [MathItalic] [LMMathItalic-Italic]
%definefontsynonym [MathSymbol] [LMMathSymbols-Italic]
@@ -373,14 +374,14 @@
\stoptypescript
\starttypescript [math] [modern,latin-modern,default]
- % isn't this obsolete now?
- \definefontsynonym [LMMathRoman-Regular] [LMMathRoman10-Regular]
- \definefontsynonym [LMMathRoman-Bold] [LMMathRoman10-Bold]
- %definefontsynonym [LMMathSymbols-BoldItalic] [LMMathSymbols10-BoldItalic]
- %definefontsynonym [LMMathSymbols-Italic] [LMMathSymbols10-Italic]
- %definefontsynonym [LMMathExtension-Regular] [LMMathExtension10-Regular]
- %definefontsynonym [LMMathItalic-Italic] [LMMathItalic10-Italic]
- %definefontsynonym [LMMathItalic-BoldItalic] [LMMathItalic10-BoldItalic]
+ \definefontsynonym [LMMathRoman-Regular] [LMMathRoman10-Regular]
+ \definefontsynonym [LMMathRoman-Bold] [LMMathRoman10-Bold]
+ \stoptypescript
+
+ \starttypescript [math] [modern,latin-modern,default]
+ % \loadfontgoodies[lm-math]
+ \definefontsynonym [LMMathRoman-Regular] [\v!file:lmmath.otf] [\s!features=\s!math]
+ % \definefontsynonym [LMMathRoman-Bold] [\v!file:lmmathbold.otf] [\s!features=\s!math]
\stoptypescript
\starttypescript [modern,default]
@@ -1847,7 +1848,7 @@
% use with LaTeX, will follow in 2011. So, we are on our own anyway.
\starttypescript [math] [xits] [name]
- \definefontsynonym[MathRoman][file:xits-math.otf][\s!features=\s!math\mathsizesuffix,\s!goodies=xits-math]
+ \definefontsynonym[MathRoman][\s!file:xits-math.otf][\s!features=\s!math\mathsizesuffix,\s!goodies=xits-math]
\stoptypescript
\starttypescript [serif] [xits] [name]
diff --git a/tex/generic/context/luatex-fonts-merged.lua b/tex/generic/context/luatex-fonts-merged.lua
index 224ca24c7..61f19becf 100644
--- a/tex/generic/context/luatex-fonts-merged.lua
+++ b/tex/generic/context/luatex-fonts-merged.lua
@@ -1,6 +1,6 @@
-- merged file : luatex-fonts-merged.lua
-- parent file : luatex-fonts.lua
--- merge date : 05/10/11 19:20:23
+-- merge date : 05/12/11 15:19:18
do -- begin closure to overcome local limits and interference
@@ -3905,15 +3905,17 @@ a helper function.</p>
--ldx]]--
function constructors.checkedfeatures(what,features)
+ local defaults = handlers[what].features.defaults
if features and next(features) then
- for key, value in next, handlers[what].features.defaults do
+ features = fastcopy(features) -- can be inherited
+ for key, value in next, defaults do
if features[key] == nil then
features[key] = value
end
end
return features
else
- return fastcopy(defaults)
+ return fastcopy(defaults) -- we can change features in place
end
end
@@ -3929,6 +3931,7 @@ function constructors.initializefeatures(what,tfmdata,features,trace,report)
-- properties.mode can be enforces (for instance in font-otd)
local mode = properties.mode or (whatmodechecker and whatmodechecker(tfmdata,features,features.mode)) or features.mode or "base"
properties.mode = mode -- also status
+ features.mode = mode -- both properties.mode or features.mode can be changed
--
local done = { }
while true do
@@ -3938,6 +3941,7 @@ function constructors.initializefeatures(what,tfmdata,features,trace,report)
for i=1,#initializers do
local step = initializers[i]
local feature = step.name
+-- we could intercept mode here .. needs a rewrite of this whole loop then btu it's cleaner that way
local value = features[feature]
if not value then
-- disabled
@@ -3950,9 +3954,10 @@ function constructors.initializefeatures(what,tfmdata,features,trace,report)
tostring(value),mode or 'unknown', tfmdata.properties.fullname or 'unknown')
end
action(tfmdata,value,features) -- can set mode (e.g. goodies) so it can trigger a restart
- if mode ~= properties.mode then
+ if mode ~= properties.mode or mode ~= features.mode then
if whatmodechecker then
properties.mode = whatmodechecker(tfmdata,features,properties.mode) -- force checking
+ features.mode = properties.mode
end
if mode ~= properties.mode then
mode = properties.mode
@@ -7692,8 +7697,7 @@ function injections.handler(head,where,keep)
local d = mrks[index]
if d then
local rlmode = d[3]
- -- maybe better swap and "rlmode and rlmode < 0" as lr (1) is default
- if rlmode and rlmode > 0 then
+ if rlmode and rlmode >= 0 then
-- new per 2010-10-06, width adapted per 2010-02-03
-- we used to negate the width of marks because in tfm
-- that makes sense but we no longer do that so as a