NAME

define - Perl pragma to declare global constants

SYNOPSIS

#--- in package/file main ---#
package main;

# the most frequenly used application of this pragma
use define DEBUG => 0;

# define a constant list
use define DWARVES => qw(happy sneezy grumpy);

# define several at a time via a hashref list, like constant.pm
use define {
  FOO => 1,
  BAR => 2,
  BAZ => 3,
};

use Some::Module;
use My::Module;

#--- in package/file Some::Module ---#
package Some::Module
no define DEBUG =>;
no define DWARVES =>;

# define a master object that any package can import
sub new { ... }
use define OBJECT => __PACKAGE__->new;

# if DEBUG is false, the following statement isn't even compiled
warn "debugging stuff here" if DEBUG;

my $title = "Snow white and the " . scalar DWARVES . " dwarves";

#--- in package/file My::Module ---#
package My::Module
no define;

warn "I prefer these dwarves: " join " ", DWARVES if DEBUG;
OBJECT->method(DWARVES);

DESCRIPTION

This pragma is used to define global constants.

USAGE

Defining constants

Global constants are defined with the same calling conventions as constant.pm:

use define FOO => 3;
use define BAR => ( 1, 2, 3 );
use define { 
  BAZ => 'dogs',
  QUX => 'cats',
};

Importing constants by name

To use a global constant, you first have to import it into your package:

no define FOO =>;

This imports FOO into the calling package. If FOO has not been defined, it is set to undef. Note that the reason for the '=>' operator is to parse FOO as a string literal rather than a bareword (you could also do no define 'FOO').

Importing constants willy-nilly

To import ALL defined constants into your package, you can do the following:

no define;

This is quick, but dirty, as you can't predict what symbols may clash with those in your package's namespace.

NOTES

See "constant.pm" in constant. Most of the same caveats apply here.

Your code should be arranged so that any no define statements are executed after the use define statement for a given symbol. If the order is reversed, a warning will be emitted.

As a rule, modules shouldn't be defining global constants; they should import constants defined by the main body of your program.

If a module does define a global constant (eg. a master object), the module should be use'd before any other modules (or lines of code) that refer to the constant.

If you <use define> the same symbol more than once, a warning will be emitted.

AUTHOR

Gary Gurevich (garygurevich at gmail)

COPYRIGHT AND LICENSE

Copyright (C) 2004 by Gary Gurevich

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

SEE ALSO

constant(3), perl(1).