Noriko Hosoi wrote:
Looks good. I notice you have some unrelated fixes in this patch too - those look ok - be sure to document those. You can edit your commit message by using git commit --amend to amend the last commit you made.Subject: Use thread aware library for complex regex searchesLink: http://nhosoi.fedorapeople.org/0001-Use-thread-aware-library-for-complex-regex-searches.patchUnfortunately, the fedoraproject.org is closed now. I'm going to create the page http://directory.fedoraproject.org/wiki/Thread_Aware_Regex which contains the following notes as soon as the wiki is reopened.------------------------------------------------------------------------Directory Server used to use the regular expression pattern matching and replacing library which was not thread safe. Thus, the operation should have been protected by the mutex lock. Regular expression could be used by the search filters (syntax plugin), acl, schema file load, and SASL Mapping. If one of them took a long time, the rest should have been blocked. Replacing the library with the thread aware library solves the problem and improves the throughput.[http://www.pcre.org/ PCRE - Perl Compatible Regular Expressions] library is installed on RHELs/Fedoras, by default. We need just a subset of the APIs, thus we provide simplified slapi APIs wrapping the PCRE APIs.NAMEslapi_re_comp -- compiles a regular expression pattern. A thin wrapper of pcre_compile.SYNOPSIS Slapi_Regex *slapi_re_comp( char *pat, char **error ); PARAMS pat: Pattern to be compiled. error: The error string is set if the compile fails. RETURN VALUE a pointer to the regex handler which stores the compiled pattern. NULL if the compile fails. WARNING The regex handler should be released by slapi_re_free(). NAMEslapi_re_exec -- matches a compiled regular expression pattern against a given string. A thin wrapper of pcre_exec.SYNOPSISint slapi_re_exec( Slapi_Regex *re_handle, char *subject, time_t time_up );PARAMS re_handle: The regex handler returned from slapi_re_comp. subject: A string to be checked against the compiled pattern.time_up: If the current time is larger than the value, this function returns immediately. (-1) means no time limit.RETURN VALUE 0 if the string did not match. 1 if the string matched. other values if any error occurred. NAMEslapi_re_subs -- substitutes '&' or '\#' in the param src with the matched string.SYNOPSISint slapi_re_subs( Slapi_Regex *re_handle, char *subject, char *src, char **dst, unsigned long dstlen );PARAMS re_handle: The regex handler returned from slapi_re_comp. subject: A string checked against the compiled pattern. src: A given string which could contain the substitution symbols. dst: A pointer pointing to the memory which stores the output string. dstlen: Size of the memory dst. RETURN VALUE 1 if the substitution was successful. 0 if the substitution failed. NAMEslapi_re_free -- releases the regex handler which was returned from slapi_re_comp.SYNOPSIS void slapi_re_free(Slapi_Regex *re_handle); PARAMS re_handle: The regex handler to be released. RETURN VALUE none ------------------------------------------------------------------------
Thanks, --noriko ------------------------------------------------------------------------ -- Fedora-directory-devel mailing list Fedora-directory-devel@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/fedora-directory-devel
Attachment:
smime.p7s
Description: S/MIME Cryptographic Signature
-- Fedora-directory-devel mailing list Fedora-directory-devel@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/fedora-directory-devel