Changeset: 7e5a294af159 for MonetDB
URL: http://dev.monetdb.org/hg/MonetDB?cmd=changeset;node=7e5a294af159
Added Files:
        sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.sql
        sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.err
        sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.out
        sql/test/BugTracker-2014/Tests/order_by_incorrect_error.Bug-3630.sql
        
sql/test/BugTracker-2014/Tests/order_by_incorrect_error.Bug-3630.stable.err
        
sql/test/BugTracker-2014/Tests/order_by_incorrect_error.Bug-3630.stable.out
        sql/test/BugTracker-2014/Tests/stddev-empty.Bug-3628.sql
        sql/test/BugTracker-2014/Tests/stddev-empty.Bug-3628.stable.err
        sql/test/BugTracker-2014/Tests/stddev-empty.Bug-3628.stable.out
Modified Files:
        gdk/gdk_aggr.c
        monetdb5/modules/kernel/algebra.c
        sql/backends/monet5/sql_statement.c
        sql/server/rel_psm.c
        sql/server/rel_select.c
        sql/test/BugTracker-2014/Tests/All
        sql/test/Dependencies/Tests/Dependencies_bam.stable.out
Branch: default
Log Message:

Merge with Oct2014 branch.


diffs (truncated from 724 to 300 lines):

diff --git a/gdk/gdk_aggr.c b/gdk/gdk_aggr.c
--- a/gdk/gdk_aggr.c
+++ b/gdk/gdk_aggr.c
@@ -2634,7 +2634,7 @@ BATgroupquantile(BAT *b, BAT *g, BAT *e,
        } while (0)
 
 static dbl
-calcvariance(dbl *avgp, const void *values, BUN cnt, int tp, int issample)
+calcvariance(dbl *avgp, const void *values, BUN cnt, int tp, int issample, 
const char *func)
 {
        BUN n = 0, i;
        dbl mean = 0;
@@ -2674,6 +2674,8 @@ calcvariance(dbl *avgp, const void *valu
                AGGR_STDEV_SINGLE(dbl);
                break;
        default:
+               GDKerror("%s: type (%s) not supported.\n",
+                        func, ATOMname(tp));
                return dbl_nil;
        }
        if (n <= (BUN) issample) {
@@ -2690,7 +2692,8 @@ dbl
 BATcalcstdev_population(dbl *avgp, BAT *b)
 {
        dbl v = calcvariance(avgp, (const void *) Tloc(b, BUNfirst(b)),
-                            BATcount(b), b->ttype, 0);
+                            BATcount(b), b->ttype, 0,
+                            "BATcalcstdev_population");
        return v == dbl_nil ? dbl_nil : sqrt(v);
 }
 
@@ -2698,7 +2701,8 @@ dbl
 BATcalcstdev_sample(dbl *avgp, BAT *b)
 {
        dbl v = calcvariance(avgp, (const void *) Tloc(b, BUNfirst(b)),
-                            BATcount(b), b->ttype, 1);
+                            BATcount(b), b->ttype, 1,
+                            "BATcalcstdev_sample");
        return v == dbl_nil ? dbl_nil : sqrt(v);
 }
 
@@ -2706,14 +2710,16 @@ dbl
 BATcalcvariance_population(dbl *avgp, BAT *b)
 {
        return calcvariance(avgp, (const void *) Tloc(b, BUNfirst(b)),
-                           BATcount(b), b->ttype, 0);
+                           BATcount(b), b->ttype, 0,
+                           "BATcalcvariance_population");
 }
 
 dbl
 BATcalcvariance_sample(dbl *avgp, BAT *b)
 {
        return calcvariance(avgp, (const void *) Tloc(b, BUNfirst(b)),
-                           BATcount(b), b->ttype, 1);
+                           BATcount(b), b->ttype, 1,
+                           "BATcalcvariance_sample");
 }
 
 #define AGGR_STDEV(TYPE)                                               \
diff --git a/monetdb5/modules/kernel/algebra.c 
b/monetdb5/modules/kernel/algebra.c
--- a/monetdb5/modules/kernel/algebra.c
+++ b/monetdb5/modules/kernel/algebra.c
@@ -2177,7 +2177,7 @@ ALGstdev(dbl *res, const bat *bid)
                throw(MAL, "aggr.stdev", RUNTIME_OBJECT_MISSING);
        stdev = BATcalcstdev_sample(NULL, b);
        BBPreleaseref(b->batCacheid);
-       if (stdev == dbl_nil)
+       if (stdev == dbl_nil && GDKerrbuf && GDKerrbuf[0])
                throw(MAL, "aggr.stdev", SEMANTIC_TYPE_MISMATCH);
        *res = stdev;
        return MAL_SUCCEED;
@@ -2193,7 +2193,7 @@ ALGstdevp(dbl *res, const bat *bid)
                throw(MAL, "aggr.stdevp", RUNTIME_OBJECT_MISSING);
        stdev = BATcalcstdev_population(NULL, b);
        BBPreleaseref(b->batCacheid);
-       if (stdev == dbl_nil)
+       if (stdev == dbl_nil && GDKerrbuf && GDKerrbuf[0])
                throw(MAL, "aggr.stdevp", SEMANTIC_TYPE_MISMATCH);
        *res = stdev;
        return MAL_SUCCEED;
@@ -2212,7 +2212,7 @@ ALGvariance(dbl *res, const bat *bid)
                throw(MAL, "aggr.variance", RUNTIME_OBJECT_MISSING);
        variance = BATcalcvariance_sample(NULL, b);
        BBPreleaseref(b->batCacheid);
-       if (variance == dbl_nil)
+       if (variance == dbl_nil && GDKerrbuf && GDKerrbuf[0])
                throw(MAL, "aggr.variance", SEMANTIC_TYPE_MISMATCH);
        *res = variance;
        return MAL_SUCCEED;
@@ -2228,7 +2228,7 @@ ALGvariancep(dbl *res, const bat *bid)
                throw(MAL, "aggr.variancep", RUNTIME_OBJECT_MISSING);
        variance = BATcalcvariance_population(NULL, b);
        BBPreleaseref(b->batCacheid);
-       if (variance == dbl_nil)
+       if (variance == dbl_nil && GDKerrbuf && GDKerrbuf[0])
                throw(MAL, "aggr.variancep", SEMANTIC_TYPE_MISMATCH);
        *res = variance;
        return MAL_SUCCEED;
diff --git a/sql/backends/monet5/sql_statement.c 
b/sql/backends/monet5/sql_statement.c
--- a/sql/backends/monet5/sql_statement.c
+++ b/sql/backends/monet5/sql_statement.c
@@ -1655,7 +1655,11 @@ stmt_if(sql_allocator *sa, stmt *cond, s
        list_append(l, ifstmts);
        list_append(l, stmt_control_end(sa, cstmt));
        if (elsestmts) {
-               cond = stmt_unop(sa, cond, not);
+               sql_subfunc *or = sql_bind_func(sa, NULL, "or", bt, bt, F_FUNC);
+               sql_subfunc *isnull = sql_bind_func(sa, NULL, "isnull", bt, 
NULL, F_FUNC);
+               cond = stmt_binop(sa, 
+                               stmt_unop(sa, cond, not),
+                               stmt_unop(sa, cond, isnull), or);
                list_append(l, cstmt = stmt_cond(sa, cond, NULL, 0));
                list_append(l, elsestmts);
                list_append(l, stmt_control_end(sa, cstmt));
diff --git a/sql/server/rel_psm.c b/sql/server/rel_psm.c
--- a/sql/server/rel_psm.c
+++ b/sql/server/rel_psm.c
@@ -215,10 +215,11 @@ psm_if_then_else( mvc *sql, sql_subtype 
 {
        if (!elseif)
                return NULL;
-       if (elseif->next && elseif->type == type_symbol) { /* if or elseif */
+       assert(elseif->type == type_symbol); 
+       if (elseif->data.sym && elseif->data.sym->token == SQL_IF) {
                sql_exp *cond;
                list *ifstmts, *elsestmts;
-               dnode *n = elseif;
+               dnode *n = elseif->data.sym->data.lval->h;
                sql_rel *rel = NULL;
 
                cond = rel_logical_value_exp(sql, &rel, n->data.sym, sql_sel); 
diff --git a/sql/server/rel_select.c b/sql/server/rel_select.c
--- a/sql/server/rel_select.c
+++ b/sql/server/rel_select.c
@@ -3594,17 +3594,22 @@ rel_unop(mvc *sql, sql_rel **rel, symbol
        sql_subtype *t = NULL;
        int type = (ek.card == card_none)?F_PROC:F_FUNC;
 
-       if (!e) { /* possibly we cannot resolve the argument as the function 
maybe an aggregate */
+       if (sname)
+               s = mvc_bind_schema(sql, sname);
+
+       if (!s)
+               return NULL;
+       if (!e)
+               f = find_func(sql, s, fname, 1, F_AGGR);
+       if (!e && f) { /* possibly we cannot resolve the argument as the 
function maybe an aggregate */
                /* reset error */
                sql->session->status = 0;
                sql->errstr[0] = '\0';
                return rel_aggr(sql, rel, se, fs);
        }
-
-       if (sname)
-               s = mvc_bind_schema(sql, sname);
-       if (!s)
-               s = sql->session->schema;
+       if (!e)
+               return NULL;
+
        t = exp_subtype(e);
        f = bind_func(sql, s, fname, t, NULL, type);
        if (!f)
@@ -3836,22 +3841,27 @@ rel_binop(mvc *sql, sql_rel **rel, symbo
        sql_schema *s = sql->session->schema;
        exp_kind iek = {type_value, card_column, FALSE};
        int type = (ek.card == card_none)?F_PROC:F_FUNC;
+       sql_subfunc *sf = NULL;
+
+       if (sname)
+               s = mvc_bind_schema(sql, sname);
+       if (!s)
+               return NULL;
 
        l = rel_value_exp(sql, rel, dl->next->data.sym, f, iek);
        r = rel_value_exp(sql, rel, dl->next->next->data.sym, f, iek);
-       if (!l && !r) { /* possibly we cannot resolve the argument as the 
function maybe an aggregate */
+       if (!l && !r)
+               sf = find_func(sql, s, fname, 2, F_AGGR);
+       if (!l && !r && sf) { /* possibly we cannot resolve the argument as the 
function maybe an aggregate */
                /* reset error */
                sql->session->status = 0;
                sql->errstr[0] = '\0';
                return rel_aggr(sql, rel, se, f);
        }
 
-       if (sname)
-               s = mvc_bind_schema(sql, sname);
-
        if (type == F_FUNC) {
-               sql_subfunc *func = find_func(sql, s, fname, 2, F_AGGR);
-               if (func) {
+               sf = find_func(sql, s, fname, 2, F_AGGR);
+               if (sf) {
                        if (!l || !r) { /* reset error */
                                sql->session->status = 0;
                                sql->errstr[0] = '\0';
@@ -4640,12 +4650,12 @@ rel_order_by_column_exp(mvc *sql, sql_re
                if (r && or != r)
                        (*R)->l = r;
                /* add to internal project */
-               if (is_processed(r) && e) {
+               if (e && is_processed(r)) {
                        rel_project_add_exp(sql, r, e);
                        e = rel_lastexp(sql, r);
                }
                /* try with reverted aliases */
-               if (!e && sql->session->status != -ERR_AMBIGUOUS) {
+               if (!e && r && sql->session->status != -ERR_AMBIGUOUS) {
                        sql_rel *nr = rel_project(sql->sa, r, 
rel_projections_(sql, r));
 
                        /* reset error */
diff --git a/sql/test/BugTracker-2014/Tests/All 
b/sql/test/BugTracker-2014/Tests/All
--- a/sql/test/BugTracker-2014/Tests/All
+++ b/sql/test/BugTracker-2014/Tests/All
@@ -56,3 +56,7 @@ orderby_column_exp.Bug-3620
 typecast_error.Bug-3622
 case-sqrt.Bug-3627
 column-with-comma.Bug-3616
+stddev-empty.Bug-3628
+ifthenelse.Bug-3629
+order_by_incorrect_error.Bug-3630
+
diff --git a/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.sql 
b/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.sql
new file mode 100644
--- /dev/null
+++ b/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.sql
@@ -0,0 +1,13 @@
+START TRANSACTION;
+CREATE FUNCTION test(b1 BOOLEAN)
+RETURNS INTEGER
+BEGIN
+  IF b1 THEN RETURN 1;
+  ELSEIF NOT(b1) THEN RETURN 0;
+  ELSE RETURN NULL;
+  END IF;
+END;
+SELECT test(true), test(false), test(null);
+select test(true);
+select test(false);
+select test(null);
diff --git a/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.err 
b/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.err
new file mode 100644
--- /dev/null
+++ b/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.err
@@ -0,0 +1,37 @@
+stderr of test 'ifthenelse.Bug-3629` in directory 'sql/test/BugTracker-2014` 
itself:
+
+
+# 18:33:32 >  
+# 18:33:32 >  "mserver5" "--debug=10" "--set" "gdk_nr_threads=0" "--set" 
"mapi_open=true" "--set" "mapi_port=36196" "--set" 
"mapi_usock=/var/tmp/mtest-3090/.s.monetdb.36196" "--set" "monet_prompt=" 
"--forcemito" "--set" "mal_listing=2" 
"--dbpath=/home/niels/scratch/rc-clean/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2014"
 "--set" "mal_listing=0" "--set" "embedded_r=yes"
+# 18:33:32 >  
+
+# builtin opt  gdk_dbpath = 
/home/niels/scratch/rc-clean/Linux-x86_64/var/monetdb5/dbfarm/demo
+# builtin opt  gdk_debug = 0
+# builtin opt  gdk_vmtrim = no
+# builtin opt  monet_prompt = >
+# builtin opt  monet_daemon = no
+# builtin opt  mapi_port = 50000
+# builtin opt  mapi_open = false
+# builtin opt  mapi_autosense = false
+# builtin opt  sql_optimizer = default_pipe
+# builtin opt  sql_debug = 0
+# cmdline opt  gdk_nr_threads = 0
+# cmdline opt  mapi_open = true
+# cmdline opt  mapi_port = 36196
+# cmdline opt  mapi_usock = /var/tmp/mtest-3090/.s.monetdb.36196
+# cmdline opt  monet_prompt = 
+# cmdline opt  mal_listing = 2
+# cmdline opt  gdk_dbpath = 
/home/niels/scratch/rc-clean/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2014
+# cmdline opt  mal_listing = 0
+# cmdline opt  embedded_r = yes
+# cmdline opt  gdk_debug = 536870922
+
+# 18:33:32 >  
+# 18:33:32 >  "mclient" "-lsql" "-ftest" "-Eutf-8" "-i" "-e" 
"--host=/var/tmp/mtest-3090" "--port=36196"
+# 18:33:32 >  
+
+
+# 18:33:32 >  
+# 18:33:32 >  "Done."
+# 18:33:32 >  
+
diff --git a/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.out 
b/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.out
new file mode 100644
--- /dev/null
+++ b/sql/test/BugTracker-2014/Tests/ifthenelse.Bug-3629.stable.out
@@ -0,0 +1,65 @@
+stdout of test 'ifthenelse.Bug-3629` in directory 'sql/test/BugTracker-2014` 
itself:
+
+
+# 18:33:32 >  
+# 18:33:32 >  "mserver5" "--debug=10" "--set" "gdk_nr_threads=0" "--set" 
"mapi_open=true" "--set" "mapi_port=36196" "--set" 
"mapi_usock=/var/tmp/mtest-3090/.s.monetdb.36196" "--set" "monet_prompt=" 
"--forcemito" "--set" "mal_listing=2" 
"--dbpath=/home/niels/scratch/rc-clean/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2014"
 "--set" "mal_listing=0" "--set" "embedded_r=yes"
+# 18:33:32 >  
+
+# MonetDB 5 server v11.19.4
+# This is an unreleased version
+# Serving database 'mTests_sql_test_BugTracker-2014', using 4 threads
+# Compiled for x86_64-unknown-linux-gnu/64bit with 64bit OIDs dynamically 
linked
_______________________________________________
checkin-list mailing list
[email protected]
https://www.monetdb.org/mailman/listinfo/checkin-list

Reply via email to