]> granicus.if.org Git - php/commitdiff
- Add zend_register_internal_namespace() API function.
authorAndrei Zmievski <andrei@php.net>
Wed, 2 Apr 2003 20:27:44 +0000 (20:27 +0000)
committerAndrei Zmievski <andrei@php.net>
Wed, 2 Apr 2003 20:27:44 +0000 (20:27 +0000)
- Add zend_register_internal_class_in_ns() API function.

Zend/zend_API.c
Zend/zend_API.h

index 1ab36bf29e4549efaa7f7f01a7a680831c5c8c63..ce3e89a6206f94da25f78ef4c4ddbf3b2e40d9d2 100644 (file)
@@ -1165,7 +1165,11 @@ int zend_register_functions(zend_class_entry *scope, zend_function_entry *functi
                internal_function->function_name = ptr->fname;
                internal_function->scope = scope;
                internal_function->fn_flags = ZEND_ACC_PUBLIC;
-               internal_function->ns = EG(active_namespace);
+               if (!scope) {
+                       internal_function->ns = EG(active_namespace);
+               } else {
+                       internal_function->ns = NULL;
+               }
                internal_function->prototype = NULL;
                if (!internal_function->handler) {
                        zend_error(error_type, "Null function defined as active function");
@@ -1381,6 +1385,54 @@ ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *orig_c
        return class_entry;
 }
 
+ZEND_API zend_class_entry *zend_register_internal_class_in_ns(zend_class_entry *class_entry, zend_class_entry *parent_ce, zend_namespace *ns, char *ns_name TSRMLS_DC)
+{
+       zend_class_entry *register_class;
+       zend_namespace *orig_namespace = NULL;
+
+       if (!ns && ns_name) {
+               zend_namespace **pns;
+               size_t ns_name_length = strlen(ns_name);
+               char *lowercase_name = zend_strndup(ns_name, ns_name_length);
+               zend_str_tolower(lowercase_name, ns_name_length);
+               if (zend_hash_find(&CG(global_namespace).class_table, lowercase_name, ns_name_length+1, (void **)&pns) == FAILURE) {
+                       free(lowercase_name);
+                       return NULL;
+               } else {
+                       ns = *pns;
+               }
+               free(lowercase_name);
+       }
+
+       if (EG(active_namespace) != ns) {
+               orig_namespace = EG(active_namespace);
+               EG(active_namespace) = ns;
+               CG(class_table) = &ns->class_table;
+       }
+       register_class = zend_register_internal_class_ex(class_entry, parent_ce, NULL TSRMLS_CC);
+       if (orig_namespace) {
+               EG(active_namespace) = orig_namespace;
+               CG(class_table) = &orig_namespace->class_table;
+       }
+
+       return register_class;
+}
+
+ZEND_API zend_namespace *zend_register_internal_namespace(zend_namespace *orig_ns TSRMLS_DC)
+{
+       zend_namespace *ns = malloc(sizeof(zend_namespace));
+       char *lowercase_name = zend_strndup(orig_ns->name, orig_ns->name_length);
+       *ns = *orig_ns;
+
+       ns->type = ZEND_INTERNAL_NAMESPACE;
+       zend_init_namespace(ns TSRMLS_CC);
+
+       zend_str_tolower(lowercase_name, ns->name_length);
+       zend_hash_update(&CG(global_namespace).class_table, lowercase_name, ns->name_length+1, &ns, sizeof(zend_namespace *), NULL);
+       free(lowercase_name);
+
+       return ns;
+}
 
 ZEND_API int zend_set_hash_symbol(zval *symbol, char *name, int name_length,
                                   zend_bool is_ref, int num_symbol_tables, ...)
index 75007c3558736d40c5926741f5c438fec25f7263..2181a483cfe127aa927bace535372912481d28d4 100644 (file)
@@ -101,6 +101,8 @@ BEGIN_EXTERN_C()
                class_container.__set = handle_propset; \
        }
 
+#define INIT_NAMESPACE(ns_container, ns_name) INIT_CLASS_ENTRY(ns_container, ns_name, NULL)
+
 
 
 int zend_next_free_module(void);
@@ -134,6 +136,8 @@ ZEND_API int zend_register_module(zend_module_entry *module_entry);
 
 ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *class_entry TSRMLS_DC);
 ZEND_API zend_class_entry *zend_register_internal_class_ex(zend_class_entry *class_entry, zend_class_entry *parent_ce, char *parent_name TSRMLS_DC);
+ZEND_API zend_class_entry *zend_register_internal_class_in_ns(zend_class_entry *class_entry, zend_class_entry *parent_ce, zend_namespace *ns, char *ns_name TSRMLS_DC);
+ZEND_API zend_namespace *zend_register_internal_namespace(zend_namespace *ns TSRMLS_DC);
 
 ZEND_API int zend_disable_function(char *function_name, uint function_name_length TSRMLS_DC);
 ZEND_API int zend_disable_class(char *class_name, uint class_name_length TSRMLS_DC);