Don't warn on use of CCFLAGS
[p5sagit/p5-mst-13.2.git] / av.c
diff --git a/av.c b/av.c
index cad6eae..67f7880 100644 (file)
--- a/av.c
+++ b/av.c
@@ -179,10 +179,13 @@ SV *val;
 
     if (!av)
        return 0;
+    if (!val)
+       val = &sv_undef;
 
     if (SvRMAGICAL(av)) {
        if (mg_find((SV*)av,'P')) {
-           mg_copy((SV*)av, val, 0, key);
+           if (val != &sv_undef)
+               mg_copy((SV*)av, val, 0, key);
            return 0;
        }
     }
@@ -192,14 +195,12 @@ SV *val;
        if (key < 0)
            return 0;
     }
-    if (!val)
-       val = &sv_undef;
-
+    if (SvREADONLY(av) && key >= AvFILL(av))
+       croak(no_modify);
     if (key > AvMAX(av))
        av_extend(av,key);
-    if (AvREIFY(av))
+    if (!AvREAL(av) && AvREIFY(av))
        av_reify(av);
-
     ary = AvARRAY(av);
     if (AvFILL(av) < key) {
        if (!AvREAL(av)) {
@@ -362,6 +363,8 @@ register AV *av;
 
     if (!av || AvFILL(av) < 0)
        return &sv_undef;
+    if (SvREADONLY(av))
+       croak(no_modify);
     retval = AvARRAY(av)[AvFILL(av)];
     AvARRAY(av)[AvFILL(av)--] = &sv_undef;
     if (SvSMAGICAL(av))
@@ -379,12 +382,10 @@ register I32 num;
 
     if (!av || num <= 0)
        return;
-    if (!AvREAL(av)) {
-       if (AvREIFY(av))
-           av_reify(av);
-       else
-           croak("Can't unshift");
-    }
+    if (SvREADONLY(av))
+       croak(no_modify);
+    if (!AvREAL(av) && AvREIFY(av))
+       av_reify(av);
     i = AvARRAY(av) - AvALLOC(av);
     if (i) {
        if (i > num)
@@ -422,6 +423,8 @@ register AV *av;
 
     if (!av || AvFILL(av) < 0)
        return &sv_undef;
+    if (SvREADONLY(av))
+       croak(no_modify);
     retval = *AvARRAY(av);
     if (AvREAL(av))
        *AvARRAY(av) = &sv_undef;