[Date Prev][Date Next]
[Chronological]
[Thread]
[Top]
Re: ldap_search_s
Interesting. I'm sure I have some code where I set my message pointer to
a NULL, and assume that if it is non-NULL, that I must free it. This was
easier than trying to keep track of where it failed. This tells me I have
a problem.
>
> I answered this question for myself. It is "NO."
>
> Tom
>
> On Mon, 3 Apr 2000 tkaczma@gryf.net wrote:
>
> >
> > Thanks, this makes more sense. Can I expect the pointer to have it's
> > original value after the search function is called if the search yields no
> > results?
> >
> > Tom
> >
> > On Sat, 1 Apr 2000, Randy Kunkee wrote:
> >
> > > >
> > > > Why does ldap_search_s take LDAPMessage ** as one of the arguments?
> > > >
> > > > >From what I see only one LDAPMessage is ever returned. It a bit confusing
> > > > as LDAPMessage implies that it is a linked list. Can someone explain to
> > > > me why a doble pointer is necessary?
> > > >
> > > > Thanks;
> > > > Tom
> > > >
> > > >
> > >
> > > The return value of ldap_search_s is LDAP_SUCCESS, or an error code.
> > > The LDAP client library allocates memory, needs to return a pointer
> > > to that message. Since the status of the search is being returned
> > > by the function, the pointer to result message structure must be
> > > returned some other way. Since what is being returned is an LDAPMessage *,
> > > a pointer to that kind of memory is an LDAPMessage **.
> > >
> > > By the way, you must free this when you are finished with it using
> > > ldap_msgfree.
> > >
> > > Example of usage would be:
> > >
> > > int resCode;
> > > LDAPMessage *ldapResultMessage; /* will point to the result */
> > > .
> > > .
> > > resCode = ldap_search_s(.... , &ldapResultMessage);
> > > if (resCode == LDAP_SUCCESS) {
> > > .
> > > .
> > > ldap_msgfree(ldapResultMessage);
> > > } else {
> > > /* print error */
> > > }
> > >
> > >
> > > Regards,
> > > Randy
> > >
> >
>
>