Thank's a lot! That's really help. I failed to bear memory context switching
in mind.
I resolved this problem with following strings in *getRate*:

  result = SPI_palloc(sizeof(rate));
  memcpy(result, rate, sizeof(rate));


P.S. I think it's a good idea to add example to documentation. Anyway when I
had started to work with PostgreSQL I was very surprised at so clear and
structured documentation. :)


On Tue, Aug 4, 2009 at 1:44 AM, Martijn van Oosterhout <klep...@svana.org>wrote:

> On Mon, Aug 03, 2009 at 10:20:36AM -0400, Tom Lane wrote:
> > Martijn van Oosterhout <klep...@svana.org> writes:
> > > What you need to do is copy the Datum you wish to return into the upper
> > > memory context. I'm not seeing a helpful SPI utility function or
> > > obvious example here you help you, but I'm sure it's something with
> > > MemoryContextSwitchTo() and datumCopy().
> >
> > SPI_palloc is what to use to allocate the result in the right place.
>
> Ofcourse, and then a memcpy(). I was distracted by the fact there is an
> SPI_copy/returntuple(), but no SPI_returndatum(). It might actually be
> helpful to include in the documentation an example of returning from a
> function a result from SPI, since it's not entirely obvious.
>
> Have a nice day,
> --
> Martijn van Oosterhout   <klep...@svana.org>   http://svana.org/kleptog/
> > Please line up in a tree and maintain the heap invariant while
> > boarding. Thank you for flying nlogn airlines.
>
> -----BEGIN PGP SIGNATURE-----
> Version: GnuPG v1.4.9 (GNU/Linux)
>
> iD8DBQFKdvezIB7bNG8LQkwRAiwGAJ0dyrP+JROL9F/OhKvzLlR5O2h4tACdEIAE
> QvCDFfLfnzCpkti8PXcVp38=
> =ZXiG
> -----END PGP SIGNATURE-----
>
>


-- 
Best regards,
Ilya Urikh.

Reply via email to