/[pgswish]/trunk/pgswish.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/pgswish.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 14 by dpavlin, Sat Feb 19 20:59:17 2005 UTC revision 18 by dpavlin, Sun Feb 20 22:58:25 2005 UTC
# Line 25  Line 25 
25  #include "fmgr.h"  #include "fmgr.h"
26  #include "funcapi.h"  #include "funcapi.h"
27  #include "utils/builtins.h"  #include "utils/builtins.h"
28    #include "utils/array.h"
29    #include "miscadmin.h"
30  #include <swish-e.h>  #include <swish-e.h>
31    
32  #define _textin(str) DirectFunctionCall1(textin, CStringGetDatum(str))  #define _textin(str) DirectFunctionCall1(textin, CStringGetDatum(str))
# Line 182  Datum pgswish(PG_FUNCTION_ARGS) { Line 184  Datum pgswish(PG_FUNCTION_ARGS) {
184                  values[3] = (char *) palloc(16 * sizeof(char));                  values[3] = (char *) palloc(16 * sizeof(char));
185                  snprintf(values[3], 16, "%d", 4);                  snprintf(values[3], 16, "%d", 4);
186  */  */
187                    
188                  /* build a tuple */                  /* build a tuple */
189                  tuple = BuildTupleFromCStrings(attinmeta, values);                  tuple = BuildTupleFromCStrings(attinmeta, values);
190    
# Line 196  Datum pgswish(PG_FUNCTION_ARGS) { Line 198  Datum pgswish(PG_FUNCTION_ARGS) {
198                  pfree(values[3]);                  pfree(values[3]);
199                  pfree(values);                  pfree(values);
200                                    
201                  elog(INFO, "row: %s|%s|%s|%s",values[0],values[1],values[2],values[3]);                  elog(DEBUG1, "row: %s|%s|%s|%s",values[0],values[1],values[2],values[3]);
202                    
203                  SRF_RETURN_NEXT(funcctx, result);                  SRF_RETURN_NEXT(funcctx, result);
204          } else {          } else {
# Line 211  Datum pgswish(PG_FUNCTION_ARGS) { Line 213  Datum pgswish(PG_FUNCTION_ARGS) {
213          }          }
214  }  }
215    
216  Datum swtextprop(PG_FUNCTION_ARGS) {  /* work in progress */
217          char    *prop;  PG_FUNCTION_INFO_V1(pgswish2);
218          char    *val;  Datum pgswish2(PG_FUNCTION_ARGS)
219    {
220            int             nrows = 3;
221            int16           typlen;
222            bool            typbyval;
223            char            typalign;
224            ReturnSetInfo   *rsinfo = (ReturnSetInfo *) fcinfo->resultinfo;
225            AttInMetadata   *attinmeta;
226            TupleDesc       tupdesc;
227            Tuplestorestate *tupstore = NULL;
228            HeapTuple       tuple;
229            MemoryContext   per_query_ctx;
230            MemoryContext   oldcontext;
231            Datum           dvalue;
232            char            **values;
233            int             ncols;
234            int             i, j;
235    
236            /* check to see if caller supports us returning a tuplestore */
237            if (!rsinfo || !(rsinfo->allowedModes & SFRM_Materialize))
238                    ereport(ERROR,
239                                    (errcode(ERRCODE_SYNTAX_ERROR),
240                                     errmsg("materialize mode required, but it is not " \
241                                                    "allowed in this context")));
242    
243            /* get the requested return tuple description */
244            tupdesc = rsinfo->expectedDesc;
245            ncols = tupdesc->natts;
246    
247            /*
248             * The requested tuple description better match up with the array
249             * we were given.
250             */
251            /* OK, use it */
252            attinmeta = TupleDescGetAttInMetadata(tupdesc);
253    
254            /* Now go to work */
255            rsinfo->returnMode = SFRM_Materialize;
256    
257            per_query_ctx = fcinfo->flinfo->fn_mcxt;
258            oldcontext = MemoryContextSwitchTo(per_query_ctx);
259    
260            /* initialize our tuplestore */
261            tupstore = tuplestore_begin_heap(true, false, SortMem);
262    
263            values = (char **) palloc(ncols * sizeof(char *));
264    
265            for (i = 0; i < nrows; i++)
266            {
267                    for (j = 0; j < ncols; j++)
268                    {
269                            values[j] = DatumGetCString( "foo" );
270                    }
271                    /* construct the tuple */
272                    tuple = BuildTupleFromCStrings(attinmeta, values);
273    
274          prop = _textout(PG_GETARG_TEXT_P(0));                  /* now store it */
275          elog(INFO, "pgswish: swextprop(%s)", prop);                  tuplestore_puttuple(tupstore, tuple);
276            }
277    
278          val = prop2int( sw_res, prop );          tuplestore_donestoring(tupstore);
279          error_or_abort( swish_handle );          rsinfo->setResult = tupstore;
280    
281          elog(INFO, "pgswish: swextprop(%s) = '%s'", prop, val );          /*
282             * SFRM_Materialize mode expects us to return a NULL Datum. The actual
283             * tuples are in our tuplestore and passed back through
284             * rsinfo->setResult. rsinfo->setDesc is set to the tuple description
285             * that we actually used to build our tuples with, so the caller can
286             * verify we did what it was expecting.
287             */
288            rsinfo->setDesc = tupdesc;
289            MemoryContextSwitchTo(oldcontext);
290    
291          PG_FREE_IF_COPY(prop, 0);          return (Datum) 0;
         PG_RETURN_TEXT_P( _textin(val) );  
292  }  }
293    
294    
295  /* make text var prom property */  /* make text var prom property */
296  char *prop2text(SW_RESULT sw_res, char *propname) {  char *prop2text(SW_RESULT sw_res, char *propname) {
297          char *val;          char *val;
298          char *prop;          char *prop;
299          int len;          int len;
300    
301          elog(DEBUG1, "prop2text(%s)", propname);          elog(DEBUG2, "prop2text(%s)", propname);
302    
303          prop = SwishResultPropertyStr( sw_res, propname );          prop = SwishResultPropertyStr( sw_res, propname );
304          error_or_abort( swish_handle );          error_or_abort( swish_handle );
305    
306          len = strlen(prop);          len = strlen(prop);
307          elog(INFO, "prop2text(%s) = '%s' %d bytes", propname, prop, len);          elog(DEBUG1, "prop2text(%s) = '%s' %d bytes", propname, prop, len);
308    
309          len++;          len++;
310          len *= sizeof(char);          len *= sizeof(char);
311    
312          elog(DEBUG1, "palloc(%d)", len);          elog(DEBUG2, "palloc(%d)", len);
313    
314          val = palloc(len);          val = palloc(len);
315    
316          memset(val, 0, len);          memset(val, 0, len);
317          strncpy(val, prop, len);          strncpy(val, prop, len);
318    
319          elog(DEBUG1, "val=%s", val);          elog(DEBUG2, "val=%s", val);
320    
321          return val;          return val;
322  }  }
# Line 262  char *prop2int(SW_RESULT sw_res, char *p Line 327  char *prop2int(SW_RESULT sw_res, char *p
327          unsigned long prop;          unsigned long prop;
328          int len;          int len;
329    
330          elog(DEBUG1, "prop2int(%s)", propname);          elog(DEBUG2, "prop2int(%s)", propname);
331    
332          prop = SwishResultPropertyULong( sw_res, propname );          prop = SwishResultPropertyULong( sw_res, propname );
333          error_or_abort( swish_handle );          error_or_abort( swish_handle );
334    
335          elog(INFO, "prop2int(%s) = %lu", propname, prop);          elog(DEBUG1, "prop2int(%s) = %lu", propname, prop);
336    
337          len = 128 * sizeof(char);          len = 128 * sizeof(char);
338          elog(DEBUG1, "palloc(%d)", len);          elog(DEBUG2, "palloc(%d)", len);
339    
340          val = palloc(len);          val = palloc(len);
341          memset(val, 0, len);          memset(val, 0, len);
342    
343          snprintf(val, len, "%lu", prop);          snprintf(val, len, "%lu", prop);
344    
345          elog(DEBUG1, "val=%s", val);          elog(DEBUG2, "val=%s", val);
346    
347          return val;          return val;
348  }  }

Legend:
Removed from v.14  
changed lines
  Added in v.18

  ViewVC Help
Powered by ViewVC 1.1.26