summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicholas Clark <nick@ccl4.org>2005-08-17 09:06:33 +0000
committerNicholas Clark <nick@ccl4.org>2005-08-17 09:06:33 +0000
commit43e6e717d18ccf9c351f44370ef56abe09dc1cc4 (patch)
treed4a494b13c1c139229e46fa7017e3d35765dfab4
parent724e67cb5119c18364c1131d2478435750263a24 (diff)
downloadperl-43e6e717d18ccf9c351f44370ef56abe09dc1cc4.tar.gz
Given that we now have a union, there's no need for all the HvARRAY()
casting games. p4raw-id: //depot/perl@25297
-rw-r--r--hv.h6
-rw-r--r--sv.h11
2 files changed, 12 insertions, 5 deletions
diff --git a/hv.h b/hv.h
index 956f949fc1..1ec5d5613b 100644
--- a/hv.h
+++ b/hv.h
@@ -8,10 +8,6 @@
*
*/
-/* typedefs to eliminate some typing */
-typedef struct he HE;
-typedef struct hek HEK;
-
/* entry in hash value chain */
struct he {
/* Keep hent_next first in this structure, because sv_free_arenas take
@@ -209,7 +205,7 @@ C<SV*>.
#define Nullhv Null(HV*)
-#define HvARRAY(hv) (*(HE***)&((hv)->sv_u.svu_array))
+#define HvARRAY(hv) ((hv)->sv_u.svu_hash)
#define HvFILL(hv) ((XPVHV*) SvANY(hv))->xhv_fill
#define HvMAX(hv) ((XPVHV*) SvANY(hv))->xhv_max
/* This quite intentionally does no flag checking first. That's your
diff --git a/sv.h b/sv.h
index 6983f45f27..003e0418df 100644
--- a/sv.h
+++ b/sv.h
@@ -62,6 +62,11 @@ typedef enum {
SVt_PVIO /* 15 */
} svtype;
+
+/* typedefs to eliminate some typing */
+typedef struct he HE;
+typedef struct hek HEK;
+
/* Using C's structural equivalence to help emulate C++ inheritance here... */
struct STRUCT_SV { /* struct sv { */
@@ -74,6 +79,7 @@ struct STRUCT_SV { /* struct sv { */
SV* svu_rv; /* pointer to another SV */
char* svu_pv; /* pointer to malloced string */
SV** svu_array;
+ HE** svu_hash;
} sv_u;
#ifdef DEBUG_LEAKING_SCALARS
unsigned sv_debug_optype:9; /* the type of OP that allocated us */
@@ -94,6 +100,7 @@ struct gv {
SV* svu_rv;
char* svu_pv;
SV** svu_array;
+ HE** svu_hash;
} sv_u;
};
@@ -107,6 +114,7 @@ struct cv {
SV* svu_rv;
char* svu_pv;
SV** svu_array;
+ HE** svu_hash;
} sv_u;
};
@@ -120,6 +128,7 @@ struct av {
SV* svu_rv;
char* svu_pv; /* pointer to first array element */
SV** svu_array;
+ HE** svu_hash;
} sv_u;
};
@@ -133,6 +142,7 @@ struct hv {
SV* svu_rv;
char* svu_pv;
SV** svu_array;
+ HE** svu_hash;
} sv_u;
};
@@ -146,6 +156,7 @@ struct io {
SV* svu_rv;
char* svu_pv;
SV** svu_array;
+ HE** svu_hash;
} sv_u;
};