summaryrefslogtreecommitdiff
path: root/gv.c
diff options
context:
space:
mode:
Diffstat (limited to 'gv.c')
-rw-r--r--gv.c130
1 files changed, 110 insertions, 20 deletions
diff --git a/gv.c b/gv.c
index 9e1f5337d4..0d22007011 100644
--- a/gv.c
+++ b/gv.c
@@ -43,6 +43,8 @@
#include "EXTERN.h"
#include "perl.h"
+extern char* rcsid;
+
GV *
gv_AVadd(gv)
register GV *gv;
@@ -72,7 +74,7 @@ char *name;
gv = gv_fetchpv(tmpbuf, TRUE);
sv_setpv(GvSV(gv), name);
if (perldb)
- (void)gv_HVadd(gv_AVadd(gv));
+ hv_magic(GvHVn(gv_AVadd(gv)), gv, 'L');
return gv;
}
@@ -188,6 +190,8 @@ I32 add;
name = sawquote+1;
*sawquote = '\'';
}
+ if (!stash)
+ fatal("Global symbol \"%s\" requires explicit package name", name);
len = namend - name;
gvp = (GV**)hv_fetch(stash,name,len,add);
if (!gvp || *gvp == (GV*)&sv_undef)
@@ -197,26 +201,112 @@ I32 add;
SvMULTI_on(gv);
return gv;
}
- else {
- sv_upgrade(gv, SVt_PVGV);
- if (SvLEN(gv))
- Safefree(SvPV(gv));
- Newz(602,gp, 1, GP);
- GvGP(gv) = gp;
- GvREFCNT(gv) = 1;
- GvSV(gv) = NEWSV(72,0);
- GvLINE(gv) = curcop->cop_line;
- GvEGV(gv) = gv;
- sv_magic((SV*)gv, (SV*)gv, '*', name, len);
- GvSTASH(gv) = stash;
- GvNAME(gv) = nsavestr(name, len);
- GvNAMELEN(gv) = len;
- if (isDIGIT(*name) && *name != '0')
- sv_magic(GvSV(gv), (SV*)gv, 0, name, len);
- if (add & 2)
- SvMULTI_on(gv);
- return gv;
+
+ /* Adding a new symbol */
+
+ sv_upgrade(gv, SVt_PVGV);
+ if (SvLEN(gv))
+ Safefree(SvPV(gv));
+ Newz(602,gp, 1, GP);
+ GvGP(gv) = gp;
+ GvREFCNT(gv) = 1;
+ GvSV(gv) = NEWSV(72,0);
+ GvLINE(gv) = curcop->cop_line;
+ GvEGV(gv) = gv;
+ sv_magic((SV*)gv, (SV*)gv, '*', name, len);
+ GvSTASH(gv) = stash;
+ GvNAME(gv) = nsavestr(name, len);
+ GvNAMELEN(gv) = len;
+ if (isDIGIT(*name) && *name != '0')
+ sv_magic(GvSV(gv), (SV*)gv, 0, name, len);
+ if (add & 2)
+ SvMULTI_on(gv);
+
+ /* set up magic where warranted */
+ switch (*name) {
+ case 'S':
+ if (strEQ(name, "SIG")) {
+ HV *hv;
+ siggv = gv;
+ SvMULTI_on(siggv);
+ hv = GvHVn(siggv);
+ hv_magic(hv, siggv, 'S');
+
+ /* initialize signal stack */
+ signalstack = newAV();
+ av_store(signalstack, 32, Nullsv);
+ av_clear(signalstack);
+ AvREAL_off(signalstack);
+ }
+ break;
+
+ case '&':
+ ampergv = gv;
+ sawampersand = TRUE;
+ goto magicalize;
+
+ case '`':
+ leftgv = gv;
+ sawampersand = TRUE;
+ goto magicalize;
+
+ case '\'':
+ rightgv = gv;
+ sawampersand = TRUE;
+ goto magicalize;
+
+ case ':':
+ sv_setpv(GvSV(gv),chopset);
+ goto magicalize;
+
+ case '!':
+ case '#':
+ case '?':
+ case '^':
+ case '~':
+ case '=':
+ case '-':
+ case '%':
+ case '.':
+ case '+':
+ case '*':
+ case '(':
+ case ')':
+ case '<':
+ case '>':
+ case ',':
+ case '\\':
+ case '/':
+ case '[':
+ case '|':
+ case '\004':
+ case '\t':
+ case '\020':
+ case '\024':
+ case '\027':
+ case '\006':
+ magicalize:
+ sv_magic(GvSV(gv), (SV*)gv, 0, name, 1);
+ break;
+
+ case '\014':
+ sv_setpv(GvSV(gv),"\f");
+ formfeed = GvSV(gv);
+ break;
+ case ';':
+ sv_setpv(GvSV(gv),"\034");
+ break;
+ case ']': {
+ SV *sv;
+ sv = GvSV(gv);
+ sv_upgrade(sv, SVt_PVNV);
+ sv_setpv(sv,rcsid);
+ SvNV(sv) = atof(patchlevel);
+ SvNOK_on(sv);
+ }
+ break;
}
+ return gv;
}
void