GLOBALS

The GLOBALS / END GLOBALS block and the GLOBALS instruction.

Important:

Defining global symbols (variables, constants, types) is deprecated and should be avoided. Instead of GLOBALS, use PUBLIC symbols in modules to be imported with IMPORT FGL.

Syntax 1: Global block declaration

GLOBALS
  declaration-statement
  [,...]
END GLOBALS
  1. declaration-statement is a variable, constant or type declaration.

Syntax 2: Importing definitions from a globals file

GLOBALS "filename"
  1. filename is the file containing the definition of globals. filename can be a relative or an absolute path. To specify a path, the slash (/) directory separator can be used for UNIX™ and Windows® platforms.
  2. Use this syntax to include global declarations in the current module.

Usage

To extend the scope of variables, constants or user types to the whole program, define a module containing a GLOBALS ... END GLOBALS block and include this global module with the GLOBALS "filename" statement in other modules.

Initialization of global variables (DEFINE x INT = 100) is not supported.

The filename should contain the .4gl suffix. However, the compiler uses the filename as it is. Therefore it can accept other file extensions such as GLOBALS "stock.glb".

The filename can be a relative or an absolute path. To specify a path, the slash (/) directory separator can be used for UNIX and Windows platforms.

When the filename specified by GLOBALS defines a relative file path, the globals file will be searched relatively to the location of the source provided to fglcomp.

For compatibility, fglcomp searches globals files in pwd first, then the search is relative to the source file path. This can simplify build scripts: the compiler can be called from any directory.