summaryrefslogtreecommitdiff
path: root/tex/context/base/attr-lay.lua
diff options
context:
space:
mode:
authorMarius <mariausol@gmail.com>2011-12-16 18:20:15 +0200
committerMarius <mariausol@gmail.com>2011-12-16 18:20:15 +0200
commita656aad1f74278e65b30bbe7493dcd5b143ffaaa (patch)
tree7412d084b997a20f1081734615a528bc0547dd7d /tex/context/base/attr-lay.lua
parentc444fd017ef64c84f0f8660af523009d88d5361c (diff)
downloadcontext-a656aad1f74278e65b30bbe7493dcd5b143ffaaa.tar.gz
beta 2011.12.16 17:07
Diffstat (limited to 'tex/context/base/attr-lay.lua')
-rw-r--r--tex/context/base/attr-lay.lua64
1 files changed, 42 insertions, 22 deletions
diff --git a/tex/context/base/attr-lay.lua b/tex/context/base/attr-lay.lua
index e12938fa4..bcdc541f7 100644
--- a/tex/context/base/attr-lay.lua
+++ b/tex/context/base/attr-lay.lua
@@ -98,20 +98,6 @@ local function initializer(...)
return states.initialize(...)
end
-local function register(name,lw) -- if not inimode redefine data[n] in first call
- local stamp = format(template,name)
- local n = registered[stamp]
- if not n then
- n = #values + 1
- values[n] = name
- registered[stamp] = n
- listwise[n] = lw or false
- end
- return registered[stamp] -- == n
-end
-
-viewerlayers.register = register
-
attributes.viewerlayers.handler = nodes.installattributehandler {
name = "viewerlayer",
namespace = viewerlayers,
@@ -120,11 +106,19 @@ attributes.viewerlayers.handler = nodes.installattributehandler {
processor = states.stacked,
}
+local stack, enabled, global = { }, false, false
+
function viewerlayers.enable(value)
if value == false or not viewerlayers.supported then
- tasks.disableaction("shipouts","attributes.viewerlayers.handler")
+ if enabled then
+ tasks.disableaction("shipouts","attributes.viewerlayers.handler")
+ end
+ enabled = false
else
- tasks.enableaction("shipouts","attributes.viewerlayers.handler")
+ if not enabled then
+ tasks.enableaction("shipouts","attributes.viewerlayers.handler")
+ end
+ enabled = true
end
end
@@ -134,16 +128,31 @@ function viewerlayers.forcesupport(value)
viewerlayers.enable(value)
end
+local function register(name,lw) -- if not inimode redefine data[n] in first call
+ if not enabled then
+ viewerlayers.enable(true)
+ end
+ local stamp = format(template,name)
+ local n = registered[stamp]
+ if not n then
+ n = #values + 1
+ values[n] = name
+ registered[stamp] = n
+ listwise[n] = lw or false -- lw forces a used
+ end
+ return registered[stamp] -- == n
+end
+
+viewerlayers.register = register
+
function viewerlayers.setfeatures(hasorder)
viewerlayers.hasorder = hasorder
end
-local stack, enabled, global = { }, false, false
-
function viewerlayers.start(name)
- if not enabled then
- viewerlayers.enable(true)
- end
+-- if not enabled then
+-- viewerlayers.enable(true)
+-- end
insert(stack,texgetattribute(a_viewerlayer))
local a = register(name) or unsetvalue
if global or scopes[name] == v_global then
@@ -188,4 +197,15 @@ function viewerlayers.define(settings)
end
end
-commands.defineviewerlayer = viewerlayers.define
+commands.defineviewerlayer = viewerlayers.define
+commands.startviewerlayer = viewerlayers.start
+commands.stopviewerlayer = viewerlayers.stop
+
+function commands.definedviewerlayer(settings)
+ viewerlayers.define(settings)
+ context(register(settings.tag,true)) -- true forces a use
+end
+
+function commands.registeredviewerlayer(name)
+ context(register(name,true)) -- true forces a use
+end