| 1 | /*    perlvars.h | 
|---|
| 2 | * | 
|---|
| 3 | *    Copyright (C) 1999, 2000, 2001, 2002, by Larry Wall and others | 
|---|
| 4 | * | 
|---|
| 5 | *    You may distribute under the terms of either the GNU General Public | 
|---|
| 6 | *    License or the Artistic License, as specified in the README file. | 
|---|
| 7 | * | 
|---|
| 8 | */ | 
|---|
| 9 |  | 
|---|
| 10 | /****************/ | 
|---|
| 11 | /* Truly global */ | 
|---|
| 12 | /****************/ | 
|---|
| 13 |  | 
|---|
| 14 | /* Don't forget to re-run embed.pl to propagate changes! */ | 
|---|
| 15 |  | 
|---|
| 16 | /* This file describes the "global" variables used by perl | 
|---|
| 17 | * This used to be in perl.h directly but we want to abstract out into | 
|---|
| 18 | * distinct files which are per-thread, per-interpreter or really global, | 
|---|
| 19 | * and how they're initialized. | 
|---|
| 20 | * | 
|---|
| 21 | * The 'G' prefix is only needed for vars that need appropriate #defines | 
|---|
| 22 | * generated in embed*.h.  Such symbols are also used to generate | 
|---|
| 23 | * the appropriate export list for win32. */ | 
|---|
| 24 |  | 
|---|
| 25 | /* global state */ | 
|---|
| 26 | PERLVAR(Gcurinterp,     PerlInterpreter *) | 
|---|
| 27 | /* currently running interpreter | 
|---|
| 28 | * (initial parent interpreter under | 
|---|
| 29 | * useithreads) */ | 
|---|
| 30 | #if defined(USE_5005THREADS) || defined(USE_ITHREADS) | 
|---|
| 31 | PERLVAR(Gthr_key,       perl_key)       /* key to retrieve per-thread struct */ | 
|---|
| 32 | #endif | 
|---|
| 33 |  | 
|---|
| 34 | /* constants (these are not literals to facilitate pointer comparisons) */ | 
|---|
| 35 | PERLVARIC(GYes,         char *, "1") | 
|---|
| 36 | PERLVARIC(GNo,          char *, "") | 
|---|
| 37 | PERLVARIC(Ghexdigit,    char *, "0123456789abcdef0123456789ABCDEF") | 
|---|
| 38 | PERLVARIC(Gpatleave,    char *, "\\.^$@dDwWsSbB+*?|()-nrtfeaxc0123456789[{]}") | 
|---|
| 39 |  | 
|---|
| 40 | /* XXX does anyone even use this? */ | 
|---|
| 41 | PERLVARI(Gdo_undump,    bool,   FALSE)  /* -u or dump seen? */ | 
|---|
| 42 |  | 
|---|
| 43 | #if defined(MYMALLOC) && (defined(USE_5005THREADS) || defined(USE_ITHREADS)) | 
|---|
| 44 | PERLVAR(Gmalloc_mutex,  perl_mutex)     /* Mutex for malloc */ | 
|---|
| 45 | #endif | 
|---|
| 46 |  | 
|---|
| 47 | #if defined(USE_ITHREADS) | 
|---|
| 48 | PERLVAR(Gop_mutex,      perl_mutex)     /* Mutex for op refcounting */ | 
|---|
| 49 | #endif | 
|---|
| 50 |  | 
|---|
| 51 | #if defined(USE_5005THREADS) || defined(USE_ITHREADS) | 
|---|
| 52 | PERLVAR(Gdollarzero_mutex, perl_mutex)  /* Modifying $0 */ | 
|---|
| 53 | #endif | 
|---|
| 54 |  | 
|---|
| 55 | /* This is constant on most architectures, a global on OS/2 */ | 
|---|
| 56 | PERLVARI(Gsh_path,      const char *,   SH_PATH)/* full path of shell */ | 
|---|
| 57 |  | 
|---|
| 58 | #ifndef PERL_MICRO | 
|---|
| 59 | /* If Perl has to ignore SIGPFE, this is its saved state. | 
|---|
| 60 | * See perl.h macros PERL_FPU_INIT and PERL_FPU_{PRE,POST}_EXEC. */ | 
|---|
| 61 | PERLVAR(Gsigfpe_saved,  Sighandler_t) | 
|---|
| 62 | #endif | 
|---|
| 63 |  | 
|---|
| 64 | /* Restricted hashes placeholder value. | 
|---|
| 65 | * The contents are never used, only the address. */ | 
|---|
| 66 | PERLVAR(Gsv_placeholder, SV) | 
|---|
| 67 |  | 
|---|
| 68 | #ifndef PERL_MICRO | 
|---|
| 69 | PERLVARI(Gcsighandlerp, Sighandler_t, Perl_csighandler) /* Pointer to C-level sighandler */ | 
|---|
| 70 | #endif | 
|---|
| 71 |  | 
|---|
| 72 | #ifndef PERL_USE_SAFE_PUTENV | 
|---|
| 73 | PERLVARI(Guse_safe_putenv, int, 1) | 
|---|
| 74 | #endif | 
|---|