de.dante.extex.interpreter.primitives.conditional
Class Ifdefined
java.lang.Object
de.dante.extex.interpreter.type.AbstractCode
de.dante.extex.interpreter.primitives.conditional.AbstractIf
de.dante.extex.interpreter.primitives.conditional.Ifdefined
- All Implemented Interfaces:
- Code, ExpandableCode, Localizable, java.io.Serializable
- public class Ifdefined
- extends AbstractIf
This class provides an implementation for the primitive \if
.
The Primitive \unless
Copied from the eTeX reference:
similar in effect to \unless \ifx
\undefined, but does not require \undefined
to actually be undefined, since no explicit comparison is made with any
particular control sequence.
Syntax
The formal description of this primitive is the following:
〈ifdefined〉
→ \ifdefined ...\else...\fi
| \ifdefined ...\else...\fi
Examples
\ifdefined\TESTNAME\else not\fi defined
- Version:
- $Revision: 1.14 $
- Author:
- Gerd Neugebauer, Sebastian Waschik
- See Also:
- Serialized Form
Field Summary |
protected static long |
serialVersionUID
The constant serialVersionUID contains the id for serialization. |
Constructor Summary |
Ifdefined(java.lang.String name)
Creates a new object. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
serialVersionUID
protected static final long serialVersionUID
- The constant serialVersionUID contains the id for serialization.
- See Also:
- Constant Field Values
Ifdefined
public Ifdefined(java.lang.String name)
- Creates a new object.
- Parameters:
name
- the name for debugging
conditional
protected boolean conditional(Context context,
TokenSource source,
Typesetter typesetter)
throws InterpreterException
- Description copied from class:
AbstractIf
- This method computes the boolean value of the conditional.
If the result is
true
then the then branch is expanded and
the else branch is skipped. Otherwise the then branch is skipped and the
else branch is expanded.
- Specified by:
conditional
in class AbstractIf
- Parameters:
context
- the interpreter contextsource
- the source for new tokenstypesetter
- the typesetter
- Returns:
- the boolean value
- Throws:
InterpreterException
- in case of en error- See Also:
AbstractIf.conditional(
de.dante.extex.interpreter.context.Context,
de.dante.extex.interpreter.TokenSource,
de.dante.extex.typesetter.Typesetter)