From 7f5afe64a73c106637df5f37f42069817227af95 Mon Sep 17 00:00:00 2001 From: kramm Date: Fri, 19 Dec 2008 08:04:27 +0000 Subject: [PATCH 1/1] added TYPE_ macros --- lib/as3/registry.h | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/lib/as3/registry.h b/lib/as3/registry.h index d1f7abb..c77d3f8 100644 --- a/lib/as3/registry.h +++ b/lib/as3/registry.h @@ -68,6 +68,29 @@ class_signature_t* registry_findclass(const char*package, const char*name); void registry_fill_multiname(multiname_t*m, namespace_t*n, class_signature_t*c); multiname_t* class_signature_to_multiname(class_signature_t*cls); + +/* convenience functions */ #define sig2mname(x) class_signature_to_multiname(x) +#define TYPE_ANY registry_getanytype() +#define TYPE_IS_ANY(t) ((t) == registry_getanytype()) +#define TYPE_INT registry_getintclass() +#define TYPE_IS_INT(t) ((t) == registry_getintclass()) +#define TYPE_UINT registry_getuintclass() +#define TYPE_IS_UINT(t) ((t) == registry_getuintclass()) +#define TYPE_FLOAT registry_getnumberclass() +#define TYPE_IS_FLOAT(t) ((t) == registry_getnumberclass()) +#define TYPE_BOOLEAN registry_getbooleanclass() +#define TYPE_IS_BOOLEAN(t)((t) == registry_getbooleanclass()) +#define TYPE_STRING registry_getstringclass() +#define TYPE_IS_STRING(t) ((t) == registry_getstringclass()) +#define TYPE_NULL registry_getnullclass() +#define TYPE_IS_NULL(t) ((t) == registry_getnullclass()) + +#define TYPE_IS_BUILTIN_SIMPLE(type) (TYPE_IS_INT(type) || \ + TYPE_IS_UINT(type) || \ + TYPE_IS_FLOAT(type) || \ + TYPE_IS_BOOLEAN(type) || \ + TYPE_IS_STRING(type)) + #endif -- 1.7.10.4