|  | Qore Programming Language Reference Manual 1.19.0
    | 
Qore supports the use of parse directives in order to set parsing options, load modules, control warnings, and include other files.
Parse directives that set parsing options can be used any time parse options have not been locked on a Program object. They are used most often when it's not possible or desirable to set the parse options in the qore command line.
The following are the recommended parse directives for Qore programming (note that Qore is moving toward establishing %new-style as the default syntax; all examples given in the Qore documentation are given assuming %new-style):
Parse Directives
| Directive | Description | 
| %allow-bare-refs | Prohibits the use of the "$"character in variable names, method calls, and object member references. This makes Qore scripts appear superficially more like C++ or Java programs.This parse option is set by default with %new-style. Name resolution is made in the following order when this option is set: local variables, class constants and static class vars (when parsing in class code), global variables, and (non-class) constants. Note that implicit arguments are still referenced with the "$"character even when this parse option is set; see also %require-dollarSince Qore 0.8.1 | 
| %allow-debugger | Allows debugging actions that could be insecure such as reading the thread local variable stack<br> Since Qore 0.8.13 | 
| %allow-injection | Allows code and dependency injections into the given Program object | 
| %allow-returns | Allows the use of the deprecated returnskeyword<br>Since Qore 0.9.4 | 
| %allow-weak-references | Allows the use of the weak assignment operator (:=) Since Qore 0.8.13 | 
| %append-include-path | Appends the given directories to qore's include path; also performs environment variable substitution | 
| %append-module-path | Appends the given directories to qore's module path; also performs environment variable substitution Since Qore 0.8.6 | 
| %assume-global | Resets the default Qore behavior of assuming global variable scope when variables are first referenced if no my or our is present; use after %assume-local to reset the default parsing behavior. This parse option is also set with %old-style Since Qore 0.8.4 | 
| %assume-local | Assume local variable scope when variables are first referenced if no my or our is present. When used with %allow-bare-refs, local variables without my must be declared with a data type restriction (can be any). This parse option is set by default with %new-style; see also %assume-global Since Qore 0.8.1 | 
| %broken-cast | Use old pre-0.9.4 broken cast<> operator handling where NOTHING would be accepted without an error | 
| %broken-int-assignments | Use old pre-0.8.12 broken int and softint runtime handling where type errors were ignored at runtime | 
| %broken-list-parsing | Use old pre-0.8.12 broken list parsing where certain lists without parentheses would be rewritten to make top-level statements like list l = 1, 2, 3;valid | 
| %broken-logic-precedence | Use old pre-0.8.12 precedence of logical and bitwise operators | 
| %broken-loop-statement | Accept break and continue outside of loops as with pre-0.8.13 | 
| %broken-operators | Accept spaces in multi-character operators as with pre-0.8.12 | 
| %broken-range | Include the upper limit in range() and xrange() as with pre-0.9.5 | 
| %broken-references | Do not enforce reference and *reference type restrictions as with pre-0.8.13 | 
| %broken-sprintf | Use pre-0.9 sprintf format handling where no argument is handled differently than NOTHING | 
| %broken-varargs | Assume varargs for all abstract methods as with pre-1.17 | 
| %correct-cast | revert the effect of the %broken-cast parse option | 
| %correct-int-assignments | revert the effect of the %broken-int-assignments parse option | 
| %correct-list-parsing | revert the effect of the %broken-list-parsing parse option | 
| %correct-logic-precedence | revert the effect of the %broken-logic-precedence parse option | 
| %correct-loop-statement | revert the effect of the %broken-loop-statement parse option | 
| %correct-operators | revert the effect of the %broken-operators parse option | 
| %correct-range | revert the effect of the %broken-range parse option | 
| %correct-references | revert the effect of the %broken-references parse option | 
| %correct-sprintf | revert the effect of the %broken-sprintf parse option | 
| %correct-varargs | revert the effect of the %broken-varargs parse option | 
| %define | Creates and optionally sets a value for a parse define Since Qore 0.8.3 | 
| %disable-all-warnings | Turns off all warnings | 
| %disable-warning warning-code | Disables the named warning until %enable-warning is encountered with the same code or %enable-all-warnings is encountered | 
| %else | Allows for parsing an alternate block when used with the %ifdef or %ifndef parse directives (for conditional parsing based on parse defines) Since Qore 0.8.3 | 
| %enable-all-warnings | Turns on all warnings | 
| %enable-warning warning-code | Enables the named warning | 
| %endif | Closes a conditionally-parsed block started by the %ifdef or %ifndef parse directives Since Qore 0.8.3 | 
| %endtry | Closes a %try-module or %try-reexport-module block Since Qore 0.8.6 | 
| %exec-class class_name | Instantiates the named class as the application class; also turns on %no-top-level. If the program is read from stdin or from the command line, an argument must be given specifying the class name. Any top level statements before this directive are silently ignored | 
| %ifdef | Opens a conditionally-parsed block; if the given parse define is defined, then the block after the %ifdef is parsed until either an %else or an %endif Since Qore 0.8.3 | 
| %ifndef | Opens a conditionally-parsed block; if the given parse define is not defined, then the block after the %ifdef is parsed until either an %else or an %endif Since Qore 0.8.3 | 
| %include file_name | Starts parsing file_name immediately. Parsing resumes with the current input after file_name has been completely parsed | 
| %lockdown | Made up of %no-external-access, %no-threads, and %no-io; equivalent to parse option Qore::PO_LOCKDOWN and the –lockdowncommand line option | 
| %lock-options | Prohibits further changes to parse options (equivalent to the --lock-optionscommand line option) | 
| %lock-warnings | Prohibits further changes to the warning mask (equivalent to the --lock-warningscommand line option) | 
| %loose-args | reverts the effect of the %strict-args parse options | 
| %loose-types | reverts the effect of the %strict-types parse options | 
| %new-style | Sets both %allow-bare-refs and %assume-local. These two options together make programming in Qore superficially more like programming in C++ or Java programs; use this if you dislike programming with the "$"sign, for example; see also %old-styleSince Qore 0.8.1 | 
| %old-style | Resets default Qore parsing behavior by setting %require-dollar and %assume-global; this option is the opposite of %new-style Since Qore 0.8.4 | 
| %no-debugging | Forbids debugging of the current Program object Since Qore 0.8.13 | 
| %no-class-defs | Disallows class definitions; equivalent to Qore::PO_NO_CLASS_DEFS and the --no-class-defscommand line option | 
| %no-child-restrictions | Allows child program objects to have parse option restrictions that are not a strict subset of the parents'; equivalent to parse option Qore::PO_NO_CHILD_PO_RESTRICTIONS and the --no-child-restrictionscommand line option | 
| %no-constant-defs | Disallows constant definitions; equivalent to parse option Qore::PO_NO_CONSTANT_DEFS and the --no-constant-defscommand line option | 
| %no-database | Disallows access to database functionality (for example the Datasource class; equivalent to parse option Qore::PO_NO_DATABASE and the --no-databasecommand line option | 
| %no-external-access | made up of %no-process-control, %no-network, %no-filesystem, %no-database, %no-external-info, and %no-modules; equivalent to parse option Qore::PO_NO_EXTERNAL_ACCESS and the --no-external-accesscommand line option | 
| %no-external-info | Disallows any access to functionality that provides external information (see %no-external-info for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_EXTERNAL_INFO and the --no-external-infocommand line option | 
| %no-external-process | Disallows any access to external processes (see %no-external-process for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_EXTERNAL_PROCESS and the --no-external-processcommand line option | 
| %no-filesystem | Disallows access to the local filesystem; equivalent to parse option Qore::PO_NO_FILESYSTEM and the --no-filesystemcommand line option | 
| %no-global-vars | Disallows the use of global variables; equivalent to parse option Qore::PO_NO_GLOBAL_VARS and the --no-global-varscommand line option | 
| %no-gui | Disallows functionality that draws graphics to the display; equivalent to parse option Qore::PO_NO_GUI and the -pno-guicommand line option | 
| %no-io | Made up of %no-gui | %no-terminal-io | %no-filesystem | %no-network | %no-database; equivalent to parse option Qore::PO_NO_IO and the –no-iocommand line option | 
| %no-locale-control | Disallows access to functionality that changes locale information (see no-locale-control for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_LOCALE_CONTROL and the --no-locale-controlcommand line option | 
| %no-modules | Disallows loading modules with the %requires, %try-module, and %try-reexport-module parse directive or at runtime with load_module(); equivalent to Qore::PO_NO_MODULES and the -pno-modulescommand line optionSince Qore 0.8.4 | 
| %no-namespace-defs | Disallows new namespace definitions; equivalent to Qore::PO_NO_NAMESPACE_DEFS and the --no-namespace-defscommand line option | 
| %no-network | Disallows access to the network; equivalent to parse option Qore::PO_NO_NETWORK and the --no-networkcommand line option | 
| %no-new | Disallows use of the new operator; equivalent to parse option Qore::PO_NO_NEW and the --no-newcommand line option | 
| %no-process-control | Disallows access to functions that would affect the current process (see %no-process-control for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_PROCESS_CONTROL and the --no-process-controlcommand line option | 
| %no-reflection | Disallows access to the reflection API provided by the reflection module; equivalent to parse option Qore::PO_NO_REFLECTION Since Qore 0.9 | 
| %no-subroutine-defs | Disallows subroutine (function) definitions; equivalent to parse option Qore::PO_NO_SUBROUTINE_DEFS and the --no-subroutine-defscommand line option | 
| %no-terminal-io | Disallows access to terminal I/O (see %no-terminal-io for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_TERMINAL_IO and the -pno-terminal-iocommand line option | 
| %no-thread-classes | Disallows access to thread classes (see %no-thread-classes for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_THREAD_CLASSES and the --no-thread-classescommand line option | 
| %no-thread-control | Disallows access to thread control operations (see %no-thread-control for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_THREAD_CONTROL and the --no-thread-controlcommand line option | 
| %no-thread-info | Disallows any access to functionality that provides threading information (see %no-thread-info for a list of features not available with this parse option); equivalent to parse option Qore::PO_NO_THREAD_INFO and the --no-thread-infocommand line option | 
| %no-threads | Disallows access to all thread control operations and thread classes (equivalent to --no-thread-controland--no-thread-classestogether); equivalent to parse option Qore::PO_NO_THREADS and the--no-threadscommand line option | 
| %no-top-level | Disallows any further top level code; equivalent to parse option Qore::PO_NO_TOP_LEVEL_STATEMENTS and the --no-top-levelcommand line option | 
| %no-transient | Removes the Transient Members keyword for backwards-compatibility; equivalent to parse option Qore::PO_NO_TRANSIENT | 
| %no-uncontrolled-apis | Disallows access to uncontrolled APIs such as external language bindings or direct generic system call APIs that could bypass Qore's sandboxing controls | 
| %perl-bool-eval | Set to mimic perl's boolean evaluation; this is the default with qore >= 0.8.6; prior to this version, by default qore used strict mathematic boolean evaluation, where any value converted to 0 is False and otherwise it's is True. As of Qore 0.8.6+, this parse option is only needed if %strict-bool-eval is set. When this option is set, boolean evaluation follows the same rules as <value>::val(); see also %strict-bool-eval Since Qore 0.8.6 | 
| %push-parse-options | Stores parse options so that they will be restored when the current file is done parsing; use in include files to ensure parse options are set appropriately for the file being parsed | 
| %require-dollar | Resets the default Qore behavior where the use of the "$"character in variable names, method calls, and object member references is required; use after %allow-bare-refs to reset the default parsing behaviorSince Qore 0.8.4 | 
| %require-our | Requires global variables to be declared with our prior to use (like perl's use strict varspragma); equivalent to parse option Qore::PO_REQUIRE_OUR and the--require-ourcommand line option | 
| %require-prototypes | Requires type declarations for all function and method parameters and return types. Variables and object members do not need to have type declarations; equivalent to parse option Qore::PO_REQUIRE_PROTOTYPES and the --require-prototypescommand line optionSince Qore 0.8.0 | 
| %require-types | Requires type declarations for all function and method parameters, return types, variables, and object members; equivalent to parse option Qore::PO_REQUIRE_TYPES and the --require-typescommand line option; also implies %strict-argsSince Qore 0.8.0 | 
| %requires [(reexport)] feature [<|<=|=|>=|> version] | If the named feature is not already present in Qore, then the QORE_MODULE_DIRenvironment variable is used to provide a list of directories to seach for a module with the same name (feature[-api-x.y].qmodfor binary modules or feature.qmfor user modules). If the module is not found, then the qore default module directory is checked.This directive must be used to load modules providing parse support (i.e. modules providing classes, constants, functions, etc that are resolved at parse time). If version information is provided, then it is compared with the module's version information, and if it does not match a parse exception is raised. See also Qore::load_module() for a function providing run-time module loading and %try-module and %try-reexport-module for a similar parse directive that allows module loading errors to be handled at runtime | 
| %set-time-zone | Sets the time zone for the current program from a UTC offset (with format "+/-[00[:00[:00]]";":"characters are optional) or a time zone region name (ex:"Europe/Prague")Since Qore 0.8.3 | 
| %strict-args | Prohibits access to builtin functions and methods flagged with RUNTIME_NOOP and also causes errors to be raised if excess arguments are given to functions that do not access excess arguments and if a non-list lvalue is passed to the Push Operator (push), Pop Operator (pop), or Shift Operator (shift) Since Qore 0.8.0 | 
| %strict-bool-eval | Sets qore's default strict mathematic boolean evaluation mode, where any value converted to 0 is False and otherwise it's is True; this was how qore behaved by default prior to v0.8.6. Equivalent to parse option Qore::PO_STRICT_BOOLEAN_EVAL and the -pstrict-bool-evalcommand line option.See also %perl-bool-eval Since Qore 0.8.6 | 
| %strict-types | Sets strict type checking and automatically sets default values for lvalues with type restrictions that have default values | 
| %strong-encapsulation | Disallows out-of-line class and namespace declarations. Since Qore 0.8.13 | 
| %try-module [(var_decl)] feature [<|<=|=|>=|>version] | If the named feature is not already present in Qore, then the QORE_MODULE_DIRenvironment variable is used to provide a list of directories to seach for a module with the same name (feature[-api-x.y].qmodfor binary modules or feature.qmfor user modules). If the module is not found, then the qore default module directory is checked.If an error occurs loading the module, then the variable declared after %try-moduleis instantiated with the exception information, and the code up to the %endtry parse declaration is parsed into the program, allowing for the qore script/program to handle module loading errors at parse time for modules that must be loaded at parse time.If version information is provided, then it is compared with the module's version information, and if it does not match a parse exception is raised that is handled like any other load error. See also Qore::load_module() for a function providing run-time module loading and %requires for a similar declaration that does not allow for parse-time module loading error handling. Since Qore 0.8.6 | 
| %try-reexport-module [(var_decl)] feature [<|<=|=|>=|>version] | The same as %try-module except that if used in a user module, the module is reexported to the importing code<br> Since Qore 0.8.13 | 
%allow-bare-refs–allow-bare-refs, -B"$" character in variable names, method calls, and object member references. This makes Qore scripts appear superficially more like C++ or Java programs. This parse option is set by default with %new-style and is the opposite of %require-dollar."$" character even when this parse option is set.%allow-debugger%allow-injection-pallow-injection%allow-returns-pallow-returnsreturns keyword.%allow-weak-references-pallow-weak-references%append-include-path dir1[:dir2...]%append-module-path dir1[:dir2...]%assume-global%assume-local--assume-local%broken-cast-pbroken-cast%broken-int-assignments-pbroken-int-assignments%broken-list-parsing-pbroken-list-parsinglist l = 1, 2, 3; valid.%broken-logic-precedence-pbroken-logic-precedenceAn example of impact of %broken-logic-precedence directive:
%broken-loop-statement--broken-loop-statement%broken-operators-pbroken-operators%broken-range--pbroken-range%broken-references--pbroken-references%broken-sprintf--pbroken-sprintf%broken-varargs--pbroken-varargs%correct-loop-statement%correct-operators%correct-range%correct-references%correct-sprintf%correct-varargs%define--define, -D%disable-all-warnings%disable-warning%else%enable-all-warnings--enable-all-warnings, -W%enable-warning--enable-warning, -w%endif%endtry%exec-class--exec-class, -x%ifdef%ifdef is parsed until either an %else or an %endif%ifndef%ifndef is parsed until either an %else or an %endif%include""/"), then files are searched first in the directory of the currently-executing script (if known), then in each path in the environment variable \c QORE_INCLUDE_DIR.\n
    If the first character of the include target is \c '$', then environment variable substitution is performed on the leading environment variable
    @since %Qore 0.8.9 added environment variable substitution
    <hr>
@section lockdown %lockdown
    @par Parse Directive:
    <tt>%%lockdown</tt>
    @par Command Line:
    <tt>-</tt><tt>-lockdown</tt>
    @par Parse Option Constant:
    @ref Qore::PO_LOCKDOWN
    @par Description:
    The most restrictive parse restriction, making any external access, threading, i/o, etc illegal.  Made up of @ref no-external-access "no-external-access", @ref no-threads "no-threads", and @ref no-io "no-io"
    <hr>
@section lock-options %lock-options
    @par Parse Directive:
    <tt>%%lock-options</tt>
    @par Command Line:
    <tt>-</tt><tt>-lock-options, -K</tt>
    @par Parse Option Constant:
    n/a
    @par Description:
    Prohibits further changes to parse options.
    <hr>
@section lock-warnings %lock-warnings
    @par Parse Directive:
    <tt>%%lock-warnings</tt>
    @par Command Line:
    <tt>-</tt><tt>-lock-warnings, -A</tt>
    @par Parse Option Constant:
    @ref Qore::PO_LOCK_WARNINGS
    @par Description:
    Prohibits further changes to the warning mask.
    <hr>
@section loose-args %loose-args
    @par Parse Directive:
    <tt>%%loose-args</tt>
    @par Command Line:
    n/a
    @par Parse Option Constant:
    n/a
    @par Description:
    Reverts the effect of the @ref strict-args "strict-args" parse option.
    @see @ref loose-args "loose-args"
    <hr>
@section loose-types %loose-types
    @par Parse Directive:
    <tt>%%loose-types</tt>
    @par Parse Option Constant:
    n/a
    @par Description:
    Reverts the effect of the @ref strict-types "strict-types" parse option.
    @see strict-types "strict-types"
    @since %Qore 0.9.4
    <hr>
@section new-style %new-style
    @par Parse Directive:
    <tt>%%new-style</tt>
    @par Command Line:
    <tt>-</tt><tt>-new-style, -n</tt>
    @par Parse Option Constant:
    @ref Qore::PO_NEW_STYLE
    @par Description:
    Sets both @ref allow-bare-refs "allow-bare-refs" and @ref assume-local "assume-local". These two options together make programming in %Qore superficially more like programming in C++ or Java programs; use this if you dislike programming with the \c "$" sign, for example.
    @see @ref old-style "old-style"
    @note
    - %Qore is moving toward establishing @ref new-style "new-style" as the default syntax; all examples given in the %Qore documentation are given assuming @ref new-style "new-style".
    - when using this option (or @ref allow-bare-refs "allow-bare-refs) the lack of "$" characters in variable names makes it necessary to declare local variables before using them%old-style%no-debugging%no-child-restrictions--no-child-restrictions, -I%no-class-defs--no-class-defsclass will result in a parse exception.%no-constant-defs--no-constant-defsconst will result in a parse exception.%no-database--no-database%no-external-access--no-external-access%no-external-info--no-external-info%no-external-process--no-external-process, -E%no-filesystem--no-filesystem, -F%no-global-vars--no-global-vars, -G%no-gui--no-gui, –set-parse-option=no-gui, -pno-gui%no-io--no-io, –set-parse-option=no-io, -pno-io%no-locale-control--no-locale-control, -P%no-modules-pno-modules%no-namespace-defs--no-namespace-defs, -M%no-network--no-network, -Y%no-new--no-new, -N%no-process-control--no-process-control, -P%no-reflection--pno-reflection%no-subroutine-defs--no-subroutine-defs, -S%no-terminal-io--no-terminal-io,--set-parse-option=no-terminal-io, -pno-terminal-io%no-thread-classes--no-thread-classes%no-thread-control--no-thread-control, -R%no-thread-info--no-thread-info%no-threads--no-threads, -T%no-top-level--no-top-level, -L%no-transient--pno-transientno-uncontrolled-apis-p=no-uncontrolled-apis%perl-bool-eval%perl-bool-eval is the default behavior and therefore only needs to be set if %strict-bool-eval was set first.string is: "hello"When it's not set (i.e. %strict-bool-eval is set), nothing is printed out as the string expression evaluates to False due to qore's old strict mathematical boolean evaluation.
"0" and empty strings, integer, float, and number 0 (zero), absolute date 1970-01-01Z (ie the start of the epoch with an offset of 0), relative date PT0H (ie any relative date with a 0 duration), NULL, empty binary objects, empty hashes, and empty lists. All other values are True.%push-parse-options%require-dollar"$" character in variable names, method calls, and object member references is required; use after %allow-bare-refs to reset the default parsing behavior%require-our--require-our, -O%require-prototypes--require-prototypes%require-types--require-typesCALL-WITH-TYPE-ERRORS exceptions to be thrown if a function, method, or code call is made with excess arguments not handled by the target. In case calls are made to user code over a Program barrier, the parse options of the target code determine if this exception is raised;%requires[(reexport)] feature [<|<=|=|>=|> version]--load, -l(reexport) option is used in a user module, then any modules loaded with this form of the %requires parse directive will also be imported into the importing Program.<, <=, =, >=, or >) and version information after the module name as well. Version numbers are compared via integer comparisons of each element, where elements are separated by a ".". If one of the versions does not have as many elements as another, the missing elements are assumed to be "0" (i.e. version "1.0" compared with version "1.0.1" will be extended to "1.0.0")."qore". This pseudo-feature can be used to check the minimum Qore version; if this feature is requested with version information, then the Qore library's version information is used for the version number comparison.%set-time-zone--time-zone, -z"+/-00[:00[:00]]"; ":"" characters are optional) or a time zone region name (ex: \c "Europe/Prague").
    <hr>
@section strict-args %strict-args
    @par Parse Directive:
    <tt>%%strict-args</tt>
    @par Command Line:
    <tt>-</tt><tt>-strict-args</tt>
    @par Parse Option Constant:
    @ref Qore::PO_STRICT_ARGS
    @par Description:
    Prohibits access to builtin functions and methods flagged with @ref RUNTIME_NOOP and also causes errors to be raised if excess
    arguments are given to functions that do not access excess arguments and if a non-list lvalue is passed to the @ref push,
    @ref pop, or @ref shift.
    Additionally, If a function, method, or @ref code_type "code" call is made with excess arguments not handled by the target, a
    \c CALL-WITH-TYPE-ERRORS exception is thrown.  In case calls are made to user code over a @ref Qore::Program "Program" barrier,
    the parse options of the target code determine if this exception is raised;
    @see @ref loose-args "loose-args"
    <hr>
@section strict-bool-eval %strict-bool-eval
    @par Parse Directive:
    <tt>%%strict-bool-eval</tt>
    @par Command Line:
    <tt>-pstrict-bool-eval</tt>
    @par Parse Option Constant:
    @ref Qore::PO_STRICT_BOOLEAN_EVAL
    @par Description:
    When set, this option enables qore's default strict mathematic boolean evaluation, where any value converted to 0 is @ref False "False" and otherwise it's is @ref True "True".\n\n
    This option takes effect at runtime.\n\n
    For example:\n
    @code{.py} 
string str = "hello";
if (str)
    printf("string is: y