Commit 6fad73ed authored by Michael Meskes's avatar Michael Meskes

Some bugfixes for numerical library.

parent a6f00f39
/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/execute.c,v 1.1 2003/03/16 10:42:53 meskes Exp $ */ /* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/execute.c,v 1.2 2003/03/18 10:46:39 meskes Exp $ */
/* /*
* The aim is to get a simpler inteface to the database routines. * The aim is to get a simpler inteface to the database routines.
...@@ -861,7 +861,7 @@ ECPGstore_input(const struct statement * stmt, const struct variable * var, ...@@ -861,7 +861,7 @@ ECPGstore_input(const struct statement * stmt, const struct variable * var,
} }
else else
{ {
*str = PGTYPESnumeric_ntoa((NumericVar *)(var->value)); str = PGTYPESnumeric_ntoa((NumericVar *)(var->value));
slen = strlen (str); slen = strlen (str);
if (!(mallocedval = ECPGalloc(slen + 1, stmt->lineno))) if (!(mallocedval = ECPGalloc(slen + 1, stmt->lineno)))
......
#include <pgtypes_numeric.h>
#ifndef dec_t
#define dec_t NumericVar
#endif /* dec_t */
#define PGTYPES_OVERFLOW 201 #define PGTYPES_OVERFLOW 201
#define PGTYPES_BAD_NUMERIC 202 #define PGTYPES_BAD_NUMERIC 202
#define PGTYPES_DIVIDE_ZERO 203 #define PGTYPES_DIVIDE_ZERO 203
#define PGTYPES_BAD_DATE 300
...@@ -40,6 +40,7 @@ pgtypes_alloc(long size) ...@@ -40,6 +40,7 @@ pgtypes_alloc(long size)
return (new); return (new);
} }
#if 0
/* ---------- /* ----------
* apply_typmod() - * apply_typmod() -
* *
...@@ -119,6 +120,7 @@ apply_typmod(NumericVar *var, long typmod) ...@@ -119,6 +120,7 @@ apply_typmod(NumericVar *var, long typmod)
var->dscale = scale; var->dscale = scale;
return (0); return (0);
} }
#endif
/* ---------- /* ----------
* alloc_var() - * alloc_var() -
...@@ -387,7 +389,9 @@ PGTYPESnumeric_aton(char *str, char **endptr) ...@@ -387,7 +389,9 @@ PGTYPESnumeric_aton(char *str, char **endptr)
{ {
NumericVar *value = (NumericVar *)pgtypes_alloc(sizeof(NumericVar)); NumericVar *value = (NumericVar *)pgtypes_alloc(sizeof(NumericVar));
int ret; int ret;
#if 0
long typmod = -1; long typmod = -1;
#endif
char *realptr; char *realptr;
char **ptr = (endptr != NULL) ? endptr : &realptr; char **ptr = (endptr != NULL) ? endptr : &realptr;
...@@ -398,10 +402,11 @@ PGTYPESnumeric_aton(char *str, char **endptr) ...@@ -398,10 +402,11 @@ PGTYPESnumeric_aton(char *str, char **endptr)
if (ret) if (ret)
return (NULL); return (NULL);
#if 0
ret = apply_typmod(value, typmod); ret = apply_typmod(value, typmod);
if (ret) if (ret)
return (NULL); return (NULL);
#endif
return(value); return(value);
} }
......
# $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/Makefile,v 1.90 2003/02/14 13:17:13 meskes Exp $ # $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/Makefile,v 1.91 2003/03/18 10:46:39 meskes Exp $
subdir = src/interfaces/ecpg/preproc subdir = src/interfaces/ecpg/preproc
top_builddir = ../../../.. top_builddir = ../../../..
...@@ -18,7 +18,7 @@ override CFLAGS += -Wno-error ...@@ -18,7 +18,7 @@ override CFLAGS += -Wno-error
endif endif
OBJS=preproc.o type.o ecpg.o ecpg_keywords.o output.o\ OBJS=preproc.o type.o ecpg.o ecpg_keywords.o output.o\
keywords.o c_keywords.o ../lib/typename.o descriptor.o variable.o keywords.o c_keywords.o ../ecpglib/typename.o descriptor.o variable.o
all: submake-libpgport ecpg all: submake-libpgport ecpg
......
/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/ecpg.c,v 1.62 2003/03/16 10:42:54 meskes Exp $ */ /* $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/ecpg.c,v 1.63 2003/03/18 10:46:39 meskes Exp $ */
/* New main for ecpg, the PostgreSQL embedded SQL precompiler. */ /* New main for ecpg, the PostgreSQL embedded SQL precompiler. */
/* (C) Michael Meskes <meskes@postgresql.org> Feb 5th, 1998 */ /* (C) Michael Meskes <meskes@postgresql.org> Feb 5th, 1998 */
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
#include "postgres_fe.h" #include "postgres_fe.h"
#include <unistd.h> #include <unistd.h>
#include <string.h>
#ifdef HAVE_GETOPT_H #ifdef HAVE_GETOPT_H
#include <getopt.h> #include <getopt.h>
#endif #endif
...@@ -69,10 +70,27 @@ static void ...@@ -69,10 +70,27 @@ static void
add_preprocessor_define(char *define) add_preprocessor_define(char *define)
{ {
struct _defines *pd = defines; struct _defines *pd = defines;
char *ptr, *define_copy = mm_strdup(define);
defines = mm_alloc(sizeof(struct _defines)); defines = mm_alloc(sizeof(struct _defines));
defines->old = strdup(define);
defines->new = strdup(""); /* look for = sign */
ptr = strchr(define_copy, '=');
if (ptr != NULL)
{
char *tmp;
/* symbol gets a value */
for (tmp=ptr-1; *tmp == ' '; tmp--);
tmp[1] = '\0';
defines->old = define_copy;
defines->new = ptr+1;
}
else
{
defines->old = define_copy;
defines->new = mm_strdup("");
}
defines->pertinent = true; defines->pertinent = true;
defines->next = pd; defines->next = pd;
} }
...@@ -137,7 +155,10 @@ main(int argc, char *const argv[]) ...@@ -137,7 +155,10 @@ main(int argc, char *const argv[])
break; break;
case 'C': case 'C':
if (strcmp(optarg, "INFORMIX") == 0) if (strcmp(optarg, "INFORMIX") == 0)
{
compat = ECPG_COMPAT_INFORMIX; compat = ECPG_COMPAT_INFORMIX;
add_preprocessor_define("dec_t=NumericVar");
}
else else
{ {
fprintf(stderr, "Try '%s --help' for more information.\n", argv[0]); fprintf(stderr, "Try '%s --help' for more information.\n", argv[0]);
...@@ -313,7 +334,7 @@ main(int argc, char *const argv[]) ...@@ -313,7 +334,7 @@ main(int argc, char *const argv[])
lex_init(); lex_init();
/* we need several includes */ /* we need several includes */
fprintf(yyout, "/* Processed by ecpg (%d.%d.%d) */\n/* These four include files are added by the preprocessor */\n#include <ecpgtype.h>\n#include <ecpglib.h>\n#include <ecpgerrno.h>\n#include <sqlca.h>\n#include <pgtypes_numeric.h>\n#line 1 \"%s\"\n", MAJOR_VERSION, MINOR_VERSION, PATCHLEVEL, input_filename); fprintf(yyout, "/* Processed by ecpg (%d.%d.%d) */\n/* These four include files are added by the preprocessor */\n#include <ecpgtype.h>\n#include <ecpglib.h>\n#include <ecpgerrno.h>\n#include <sqlca.h>\n#line 1 \"%s\"\n", MAJOR_VERSION, MINOR_VERSION, PATCHLEVEL, input_filename);
/* add some compatibility headers */ /* add some compatibility headers */
if (compat == ECPG_COMPAT_INFORMIX) if (compat == ECPG_COMPAT_INFORMIX)
......
#include <stdio.h> #include <stdio.h>
#include <pgtypes_numeric.h>
int int
main() main()
{ {
char *text="error\n"; char *text="error\n";
NumericVar *value1, *value2, *res; NumericVar *value1, *value2, *res;
exec sql begin declare section; exec sql begin declare section;
decimal(14,7) des = {0, 0, 0, 0, 0, NULL, NULL} ; decimal(14,7) des = {0, 0, 0, 0, 0, NULL, NULL} ;
exec sql end declare section; exec sql end declare section;
...@@ -23,8 +24,8 @@ main() ...@@ -23,8 +24,8 @@ main()
text = PGTYPESnumeric_ntoa(value1); text = PGTYPESnumeric_ntoa(value1);
printf("long = %s\n", text); printf("long = %s\n", text);
value1 = PGTYPESnumeric_aton("2369.7", -1); value1 = PGTYPESnumeric_aton("2369.7", NULL);
value2 = PGTYPESnumeric_aton("10.0", -1); value2 = PGTYPESnumeric_aton("10.0", NULL);
res = PGTYPESnew(); res = PGTYPESnew();
decadd(value1, value2, res); decadd(value1, value2, res);
text = PGTYPESnumeric_ntoa(res); text = PGTYPESnumeric_ntoa(res);
...@@ -37,7 +38,7 @@ main() ...@@ -37,7 +38,7 @@ main()
PGTYPESnumeric_copy(res, &des); PGTYPESnumeric_copy(res, &des);
exec sql insert into test (text, num) values ('test', :des); exec sql insert into test (text, num) values ('test', :des);
value2 = PGTYPESnumeric_aton("2369.7", -1); value2 = PGTYPESnumeric_aton("2369.7", NULL);
PGTYPESnumeric_mul(value1, value2, res); PGTYPESnumeric_mul(value1, value2, res);
exec sql select num into :des from test where text = 'test'; exec sql select num into :des from test where text = 'test';
...@@ -46,7 +47,7 @@ main() ...@@ -46,7 +47,7 @@ main()
text = PGTYPESnumeric_ntoa(res); text = PGTYPESnumeric_ntoa(res);
printf("mul = %s\n", text); printf("mul = %s\n", text);
value2 = PGTYPESnumeric_aton("10000", -1); value2 = PGTYPESnumeric_aton("10000", NULL);
PGTYPESnumeric_div(res, value2, res); PGTYPESnumeric_div(res, value2, res);
text = PGTYPESnumeric_ntoa(res); text = PGTYPESnumeric_ntoa(res);
PGTYPESnumeric_ntod(res, &d); PGTYPESnumeric_ntod(res, &d);
......
...@@ -53,7 +53,7 @@ exec sql endif; ...@@ -53,7 +53,7 @@ exec sql endif;
char *connection="pm"; char *connection="pm";
int how_many; int how_many;
exec sql end declare section; exec sql end declare section;
exec sql var name is string(AMOUNT); exec sql var name is string[AMOUNT];
char msg[128]; char msg[128];
FILE *dbgs; FILE *dbgs;
int i,j; int i,j;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment