summaryrefslogtreecommitdiff
path: root/server
diff options
context:
space:
mode:
authorJim Jagielski <jim@apache.org>2005-09-09 12:23:56 +0000
committerJim Jagielski <jim@apache.org>2005-09-09 12:23:56 +0000
commitcb68a807de7ed66def803b8cb8c4fd2c035047df (patch)
treead00c2f10c83fade1fcc74b097563d05ad5140fb /server
parent41bab0086f80ab7d0349e388d66986b18281e5fa (diff)
downloadhttpd-cb68a807de7ed66def803b8cb8c4fd2c035047df.tar.gz
New provider function, ap_list_provider_names(), which lists all
available registered providers for a specified group and version number. Visible change so add CHANGES entry. git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@279750 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'server')
-rw-r--r--server/provider.c71
1 files changed, 69 insertions, 2 deletions
diff --git a/server/provider.c b/server/provider.c
index 97d2a0f9f4..00d6954e89 100644
--- a/server/provider.c
+++ b/server/provider.c
@@ -16,14 +16,19 @@
#include "apr_pools.h"
#include "apr_hash.h"
+#include "apr_tables.h"
+#include "apr_strings.h"
#include "ap_provider.h"
static apr_hash_t *global_providers = NULL;
+static apr_hash_t *global_providers_names = NULL;
+
static apr_status_t cleanup_global_providers(void *ctx)
{
global_providers = NULL;
+ global_providers_names = NULL;
return APR_SUCCESS;
}
@@ -33,15 +38,16 @@ AP_DECLARE(apr_status_t) ap_register_provider(apr_pool_t *pool,
const char *provider_version,
const void *provider)
{
- apr_hash_t *provider_group_hash;
- apr_hash_t *provider_version_hash;
+ apr_hash_t *provider_group_hash, *provider_version_hash;
if (global_providers == NULL) {
global_providers = apr_hash_make(pool);
+ global_providers_names = apr_hash_make(pool);;
apr_pool_cleanup_register(pool, NULL, cleanup_global_providers,
apr_pool_cleanup_null);
}
+ /* First, deal with storing the provider away */
provider_group_hash = apr_hash_get(global_providers, provider_group,
APR_HASH_KEY_STRING);
@@ -66,6 +72,31 @@ AP_DECLARE(apr_status_t) ap_register_provider(apr_pool_t *pool,
apr_hash_set(provider_version_hash, provider_version, APR_HASH_KEY_STRING,
provider);
+ /* Now, tuck away the provider names in an easy-to-get format */
+ provider_group_hash = apr_hash_get(global_providers_names, provider_group,
+ APR_HASH_KEY_STRING);
+
+ if (!provider_group_hash) {
+ provider_group_hash = apr_hash_make(pool);
+ apr_hash_set(global_providers_names, provider_group, APR_HASH_KEY_STRING,
+ provider_group_hash);
+
+ }
+
+ provider_version_hash = apr_hash_get(provider_group_hash, provider_version,
+ APR_HASH_KEY_STRING);
+
+ if (!provider_version_hash) {
+ provider_version_hash = apr_hash_make(pool);
+ apr_hash_set(provider_group_hash, provider_version, APR_HASH_KEY_STRING,
+ provider_version_hash);
+
+ }
+
+ /* just set it. no biggy if it was there before. */
+ apr_hash_set(provider_version_hash, provider_name, APR_HASH_KEY_STRING,
+ provider_name);
+
return APR_SUCCESS;
}
@@ -96,3 +127,39 @@ AP_DECLARE(void *) ap_lookup_provider(const char *provider_group,
return apr_hash_get(provider_name_hash, provider_version,
APR_HASH_KEY_STRING);
}
+
+AP_DECLARE(apr_array_header_t *) ap_list_provider_names(apr_pool_t *pool,
+ const char *provider_group,
+ const char *provider_version)
+{
+ apr_array_header_t *ret = apr_array_make(pool, 10, sizeof(ap_list_provider_names_t));
+ ap_list_provider_names_t *entry;
+ apr_hash_t *provider_group_hash, *h;
+ apr_hash_index_t *hi;
+ char *val, *key;
+
+ if (global_providers_names == NULL) {
+ return ret;
+ }
+
+ provider_group_hash = apr_hash_get(global_providers_names, provider_group,
+ APR_HASH_KEY_STRING);
+
+ if (provider_group_hash == NULL) {
+ return ret;
+ }
+
+ h = apr_hash_get(provider_group_hash, provider_version,
+ APR_HASH_KEY_STRING);
+
+ if (h == NULL) {
+ return ret;
+ }
+
+ for (hi = apr_hash_first(pool, h); hi; hi = apr_hash_next(hi)) {
+ apr_hash_this(hi, (void *)&key, NULL, (void *)&val);
+ entry = apr_array_push(ret);
+ entry->provider_name = apr_pstrdup(pool, val);
+ }
+ return ret;
+}