diff options
author | Noriko Hosoi <nhosoi@redhat.com> | 2009-08-04 11:54:34 -0700 |
---|---|---|
committer | Noriko Hosoi <nhosoi@redhat.com> | 2009-08-04 11:54:34 -0700 |
commit | 0565e8c39894b059191cfaff2176f758141ffe3b (patch) | |
tree | c654289fb6104ee5c1ef10f1373da9b9897f0a41 /ldap/servers/slapd/backend.c | |
parent | cbed8a2780469cdbf298c30e7f10da01c4356d03 (diff) | |
download | ds-0565e8c39894b059191cfaff2176f758141ffe3b.tar.gz ds-0565e8c39894b059191cfaff2176f758141ffe3b.tar.xz ds-0565e8c39894b059191cfaff2176f758141ffe3b.zip |
513916 Server doesn't ignore paged control, if page size and server's estimate of total no of entries are same
The code processing search results were returning the PAGE END without
knowing there are more entries to return or not. To learn it, introduced
"read ahead" one entry when it comes to the PAGE END. If there are more
entries, the code undo the read ahead, which prompts for the next page
on the client side. If there is no more entries, it returns the status
SEARCH END instead of PAGE END.
In addition to the read ahead implementation to fix the bug 513916,
* supporting Simple Paged Results for chaining backend is added.
* fixed a bug in idl_new_fetch (idl_new.c) -- idlistscanlimit was not
checked when the cursor comes to the end of an index file.
Diffstat (limited to 'ldap/servers/slapd/backend.c')
-rw-r--r-- | ldap/servers/slapd/backend.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/ldap/servers/slapd/backend.c b/ldap/servers/slapd/backend.c index 740de29d..c8380c6a 100644 --- a/ldap/servers/slapd/backend.c +++ b/ldap/servers/slapd/backend.c @@ -396,6 +396,9 @@ slapi_be_getentrypoint(Slapi_Backend *be, int entrypoint, void **ret_fnptr, Slap case SLAPI_PLUGIN_DB_SEARCH_RESULTS_RELEASE_FN: *ret_fnptr = (void*)be->be_search_results_release; break; + case SLAPI_PLUGIN_DB_PREV_SEARCH_RESULTS_FN: + *ret_fnptr = be->be_prev_search_results; + break; case SLAPI_PLUGIN_DB_SIZE_FN: *ret_fnptr = (void*)be->be_dbsize; break; @@ -504,6 +507,9 @@ slapi_be_setentrypoint(Slapi_Backend *be, int entrypoint, void *ret_fnptr, Slapi case SLAPI_PLUGIN_DB_SEARCH_RESULTS_RELEASE_FN: be->be_search_results_release=(VFPP) ret_fnptr; break; + case SLAPI_PLUGIN_DB_PREV_SEARCH_RESULTS_FN: + be->be_prev_search_results = (VFP) ret_fnptr; + break; case SLAPI_PLUGIN_DB_SIZE_FN: be->be_dbsize=(IFP) ret_fnptr; break; |