X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fstr2filter.c;h=b6aa778c6b85fd71bd1567eeb4d47b7555d596bd;hb=d7396583d5bac01fda89da592824b1c8179984f4;hp=04667cc345b73f4efdf15806ec5b8ea51c950952;hpb=6939c531700652491f4be4688c6a1f35a1ab8a18;p=openldap
diff --git a/servers/slapd/str2filter.c b/servers/slapd/str2filter.c
index 04667cc345..b6aa778c6b 100644
--- a/servers/slapd/str2filter.c
+++ b/servers/slapd/str2filter.c
@@ -1,8 +1,27 @@
-/* str2filter.c - parse an rfc 1588 string filter */
+/* str2filter.c - parse an RFC 2554 string filter */
/* $OpenLDAP$ */
-/*
- * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
- * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
+/* This work is part of OpenLDAP Software .
+ *
+ * Copyright 1998-2005 The OpenLDAP Foundation.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted only as authorized by the OpenLDAP
+ * Public License.
+ *
+ * A copy of this license is available in the file LICENSE in the
+ * top-level directory of the distribution or, alternatively, at
+ * .
+ */
+/* Portions Copyright (c) 1995 Regents of the University of Michigan.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms are permitted
+ * provided that this notice is preserved and that due credit is given
+ * to the University of Michigan at Ann Arbor. The name of the University
+ * may not be used to endorse or promote products derived from this
+ * software without specific prior written permission. This software
+ * is provided ``as is'' without express or implied warranty.
*/
#include "portable.h"
@@ -14,7 +33,6 @@
#include
#include "slap.h"
-#include
#if 0 /* unused */
static char *find_matching_paren( const char *s );
@@ -24,26 +42,24 @@ static Filter *str2simple( const char *str);
static int str2subvals( const char *val, Filter *f);
Filter *
-str2filter( const char *str )
+str2filter_x( Operation *op, const char *str )
{
int rc;
Filter *f = NULL;
- char berbuf[256];
- BerElement *ber = (BerElement *)berbuf;
- Connection conn;
+ BerElementBuffer berbuf;
+ BerElement *ber = (BerElement *)&berbuf;
const char *text = NULL;
-#ifdef NEW_LOGGING
- LDAP_LOG( FILTER, ENTRY, "str2filter: \"%s\"\n", str, 0, 0 );
-#else
Debug( LDAP_DEBUG_FILTER, "str2filter \"%s\"\n", str, 0, 0 );
-#endif
if ( str == NULL || *str == '\0' ) {
return NULL;
}
ber_init2( ber, NULL, LBER_USE_DER );
+ if ( op->o_tmpmemctx ) {
+ ber_set_option( ber, LBER_OPT_BER_MEMCTX, &op->o_tmpmemctx );
+ }
rc = ldap_pvt_put_filter( ber, str );
if( rc < 0 ) {
@@ -52,12 +68,23 @@ str2filter( const char *str )
ber_reset( ber, 1 );
- conn.c_connid = 0;
-
- rc = get_filter( &conn, ber, &f, &text );
+ rc = get_filter( op, ber, &f, &text );
done:
ber_free_buf( ber );
return f;
}
+
+Filter *
+str2filter( const char *str )
+{
+ Operation op = {0};
+ Opheader ohdr = {0};
+
+ op.o_hdr = &ohdr;
+ op.o_tmpmemctx = NULL;
+ op.o_tmpmfuncs = &ch_mfuncs;
+
+ return str2filter_x( &op, str );
+}