Return-Path: Delivered-To: apmail-httpd-cvs-archive@www.apache.org Received: (qmail 70883 invoked from network); 10 Nov 2010 18:04:18 -0000 Received: from unknown (HELO mail.apache.org) (140.211.11.3) by 140.211.11.9 with SMTP; 10 Nov 2010 18:04:18 -0000 Received: (qmail 71346 invoked by uid 500); 10 Nov 2010 18:04:49 -0000 Delivered-To: apmail-httpd-cvs-archive@httpd.apache.org Received: (qmail 71288 invoked by uid 500); 10 Nov 2010 18:04:49 -0000 Mailing-List: contact cvs-help@httpd.apache.org; run by ezmlm Precedence: bulk Reply-To: dev@httpd.apache.org list-help: list-unsubscribe: List-Post: List-Id: Delivered-To: mailing list cvs@httpd.apache.org Received: (qmail 71265 invoked by uid 99); 10 Nov 2010 18:04:49 -0000 Received: from nike.apache.org (HELO nike.apache.org) (192.87.106.230) by apache.org (qpsmtpd/0.29) with ESMTP; Wed, 10 Nov 2010 18:04:49 +0000 X-ASF-Spam-Status: No, hits=-2000.0 required=10.0 tests=ALL_TRUSTED X-Spam-Check-By: apache.org Received: from [140.211.11.4] (HELO eris.apache.org) (140.211.11.4) by apache.org (qpsmtpd/0.29) with ESMTP; Wed, 10 Nov 2010 18:04:47 +0000 Received: by eris.apache.org (Postfix, from userid 65534) id A00D423889ED; Wed, 10 Nov 2010 18:03:32 +0000 (UTC) Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: svn commit: r1033619 - /httpd/httpd/trunk/server/core.c Date: Wed, 10 Nov 2010 18:03:32 -0000 To: cvs@httpd.apache.org From: sf@apache.org X-Mailer: svnmailer-1.0.8 Message-Id: <20101110180332.A00D423889ED@eris.apache.org> X-Virus-Checked: Checked by ClamAV on apache.org Author: sf Date: Wed Nov 10 18:03:32 2010 New Revision: 1033619 URL: http://svn.apache.org/viewvc?rev=1033619&view=rev Log: When restarting, reset ap_server_config_defines to what was set on the command line. This makes the result more predictable for the user and resolves some string lifetime issues in the implementation of set_define/unset_define. Modified: httpd/httpd/trunk/server/core.c Modified: httpd/httpd/trunk/server/core.c URL: http://svn.apache.org/viewvc/httpd/httpd/trunk/server/core.c?rev=1033619&r1=1033618&r2=1033619&view=diff ============================================================================== --- httpd/httpd/trunk/server/core.c (original) +++ httpd/httpd/trunk/server/core.c Wed Nov 10 18:03:32 2010 @@ -104,6 +104,8 @@ AP_DECLARE_DATA int ap_document_root_che /* magic pointer for ErrorDocument xxx "default" */ static char errordocument_default; +static apr_array_header_t *saved_server_config_defines = NULL; + static void *create_core_dir_config(apr_pool_t *a, char *dir) { core_dir_config *conf; @@ -1054,6 +1056,12 @@ static const char *set_access_name(cmd_p return NULL; } +static int reset_config_defines(void *dummy) +{ + ap_server_config_defines = saved_server_config_defines; + return OK; +} + static const char *set_define(cmd_parms *cmd, void *dummy, const char *optarg) @@ -3941,6 +3949,16 @@ static int core_pre_config(apr_pool_t *p { ap_mutex_init(pconf); + /* + * Make sure we revert the effects of Define/UnDefine when restarting. + * We cannot use apr_array_copy_hdr because it does not protect from the + * way unset_define removes entries. + */ + saved_server_config_defines = ap_server_config_defines; + ap_server_config_defines = apr_array_copy(pconf, ap_server_config_defines); + apr_pool_cleanup_register(pconf, NULL, reset_config_defines, + apr_pool_cleanup_null); + return APR_SUCCESS; }