Provided by: liblexical-var-perl_0.009-3build7_amd64 bug

NAME

       Lexical::Var - static variables without namespace pollution

SYNOPSIS

               use Lexical::Var '$foo' => \$Remote::foo;
               use Lexical::Var '$const' => \123;
               use Lexical::Var '@bar' => [];
               use Lexical::Var '%baz' => { a => 1, b => 2 };
               use Lexical::Var '&quux' => sub { $_[0] + 1 };
               use Lexical::Var '*wibble' => Symbol::gensym();

DESCRIPTION

       This module implements lexical scoping of static variables and subroutines.  Although it can be used
       directly, it is mainly intended to be infrastructure for modules that manage namespaces.

       This module influences the meaning of single-part variable names that appear directly in code, such as
       "$foo".  Normally, in the absence of any particular declaration, or under the effect of an "our"
       declaration, this would refer to the scalar variable of that name located in the current package.  A
       "Lexical::Var" declaration can change this to refer to any particular scalar, bypassing the package
       system entirely.  A variable name that includes an explicit package part, such as "$main::foo", always
       refers to the variable in the specified package, and is unaffected by this module.  A symbolic reference
       through a string value, such as ""${'foo'}"", also looks in the package system, and so is unaffected by
       this module.

       The types of name that can be influenced are scalar ("$foo"), array ("@foo"), hash ("%foo"), subroutine
       ("&foo"), and glob ("*foo").  A definition for any of these names also affects code that logically refers
       to the same entity, even when the name is spelled without its usual sigil.  For example, any definition
       of "@foo" affects element references such as "$foo[0]".  Barewords in filehandle context actually refer
       to the glob variable.  Bareword references to subroutines, such as ""foo(123)"", only work on Perl 5.11.2
       and later; on earlier Perls you must use the "&" sigil, as in ""&foo(123)"".

       Where a scalar name is defined to refer to a constant (read-only) scalar, references to the constant
       through the lexical namespace can participate in compile-time constant folding.  This can avoid the need
       to check configuration values (such as whether debugging is enabled) at runtime.

       A name definition supplied by this module takes effect from the end of the definition statement up to the
       end of the immediately enclosing block, except where it is shadowed within a nested block.  This is the
       same lexical scoping that the "my", "our", and "state" keywords supply.  Definitions from Lexical::Var
       and from "my"/"our"/"state" can shadow each other.  These lexical definitions propagate into string
       "eval"s, on Perl versions that support it (5.9.3 and later).

       This module only manages variables of static duration (the kind of duration that "our" and "state"
       variables have).  To get a fresh variable for each invocation of a function, use "my".

PACKAGE METHODS

       These methods are meant to be invoked on the "Lexical::Var" package.

       Lexical::Var->import(NAME => REF, ...)
           Sets  up lexical variable declarations, in the lexical environment that is currently compiling.  Each
           NAME must be a variable name (e.g., "$foo") including sigil, and each REF must be a  reference  to  a
           variable/value  of  the  appropriate  type.   The  name  is  lexically associated with the referenced
           variable/value.

           Scalar::Construct can be helpful in generating appropriate  REFs,  especially  to  create  constants.
           There are Perl core bugs to beware of around compile-time constants; see "BUGS".

       Lexical::Var->unimport(NAME [=> REF], ...)
           Sets  up  negative  lexical  variable  declarations,  in  the  lexical  environment that is currently
           compiling.  Each NAME must be a variable name (e.g., "$foo") including sigil.  If the name  is  given
           on  its  own,  it  is lexically dissociated from any value.  Within the resulting scope, the variable
           name will not be recognised.  If a REF (which must be a reference to a value of the appropriate type)
           is specified with a name, the name will be dissociated if and only if it is currently associated with
           that value.

BUGS

       Subroutine invocations without the "&" sigil cannot be correctly processed on Perl versions earlier  than
       5.11.2.   This is because the parser needs to look up the subroutine early, in order to let any prototype
       affect parsing, and it looks up the subroutine by a different mechanism than is used to generate the call
       op.  (Some forms of sigilless call have other complications of a similar nature.)  If an attempt is  made
       to  call a lexical subroutine via a bareword on an older Perl, this module will probably still be able to
       intercept the call op, and will throw an exception to indicate that the parsing has gone wrong.  However,
       in some cases compilation goes further wrong before this module can  catch  it,  resulting  in  either  a
       confusing  parse  error  or (in rare situations) silent compilation to an incorrect op sequence.  On Perl
       5.11.2 and later, sigilless subroutine calls work correctly, except for an issue noted below.

       Subroutine calls that have neither sigil nor parentheses (around the argument list)  are  subject  to  an
       ambiguity  with  indirect  object  syntax.   If the first argument expression begins with a bareword or a
       scalar variable reference then the Perl parser is liable to interpret the  call  as  an  indirect  method
       call.   Normally  this syntax would be interpreted as a subroutine call if the subroutine exists, but the
       parser doesn't look at lexically-defined subroutines for this purpose.  The call  interpretation  can  be
       forced  by  prefixing the first argument expression with a "+", or by wrapping the whole argument list in
       parentheses.

       On Perls built for threading (even if threading is not actually used), scalar constants that are  defined
       by literals in the Perl source don't reliably maintain their object identity.  What appear to be multiple
       references  to a single object can end up behaving as references to multiple objects, in surprising ways.
       The multiple objects all initially have the correct value, but they  can  be  writable  even  though  the
       original  object is a constant.  See Perl bug reports [perl #109744] and [perl #109746].  This can affect
       objects that are placed in the lexical namespace, just as it can affect those in  package  namespaces  or
       elsewhere.   "Lexical::Var"  avoids  contributing to the problem itself, but certain ways of building the
       parameters to "Lexical::Var" can result in the object in the lexical namespace not being the one that was
       intended, or can damage  the  named  object  so  that  later  referencing  operations  on  it  misbehave.
       Scalar::Construct can be used to avoid this problem.

       Bogus  redefinition  warnings occur in some cases when "our" declarations and "Lexical::Var" declarations
       shadow each other.

       Package hash entries get created for subroutine and glob names that are used, even though the subroutines
       and globs are not actually being stored or looked up in the package.  This can occasionally result  in  a
       "used only once" warning failing to occur when it should.

       On  Perls prior to 5.15.5, if this package's "import" or "unimport" method is called from inside a string
       "eval" inside a "BEGIN" block, it does not have proper access to  the  compiling  environment,  and  will
       complain  that  it is being invoked outside compilation.  Calling from the body of a "require"d or "do"ed
       file causes the same problem on the same Perl versions.  Other kinds  of  indirection  within  a  "BEGIN"
       block, such as calling via a normal function, do not cause this problem.

SEE ALSO

       Attribute::Lexical, Lexical::Import, Lexical::Sub, Scalar::Construct

AUTHOR

       Andrew Main (Zefram) <zefram@fysh.org>

COPYRIGHT

       Copyright (C) 2009, 2010, 2011, 2012, 2013 Andrew Main (Zefram) <zefram@fysh.org>

LICENSE

       This  module  is  free  software;  you  can redistribute it and/or modify it under the same terms as Perl
       itself.

perl v5.34.0                                       2022-02-06                                  Lexical::Var(3pm)