From 2c914937c144a25ae02190f8f11cd08731461d4c Mon Sep 17 00:00:00 2001 From: Teodor Sigaev <teodor@sigaev.ru> Date: Fri, 18 Jul 2003 13:27:43 +0000 Subject: [PATCH] Fix subpath and subltree. Allow to return '' value. subpath(ltree,0,0) returns ''. --- contrib/ltree/expected/ltree.out | 12 ++++++------ contrib/ltree/ltree_op.c | 5 +++-- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/contrib/ltree/expected/ltree.out b/contrib/ltree/expected/ltree.out index d856f0dbabc..a87738bf35d 100644 --- a/contrib/ltree/expected/ltree.out +++ b/contrib/ltree/expected/ltree.out @@ -74,15 +74,15 @@ SELECT subpath('Top.Child1.Child2',0,-1); (1 row) SELECT subpath('Top.Child1.Child2',0,0); - subpath -------------------- - Top.Child1.Child2 + subpath +--------- + (1 row) SELECT subpath('Top.Child1.Child2',1,0); - subpath ---------------- - Child1.Child2 + subpath +--------- + (1 row) SELECT subpath('Top.Child1.Child2',0); diff --git a/contrib/ltree/ltree_op.c b/contrib/ltree/ltree_op.c index 28fcfb7f7e3..44721bf6d0e 100644 --- a/contrib/ltree/ltree_op.c +++ b/contrib/ltree/ltree_op.c @@ -196,12 +196,13 @@ inner_subltree(ltree * t, int4 startpos, int4 endpos) ltree *res; int i; - if (startpos < 0 || endpos < 0 || startpos >= t->numlevel || startpos >= endpos) + if (startpos < 0 || endpos < 0 || startpos >= t->numlevel || startpos > endpos) elog(ERROR, "Wrong positions"); if (endpos > t->numlevel) endpos = t->numlevel; + start = end = (char *) ptr; for (i = 0; i < endpos; i++) { if (i == startpos) @@ -258,7 +259,7 @@ subpath(PG_FUNCTION_ARGS) if (len < 0) end = t->numlevel + len; else if (len == 0) - end = 0xffff; + end = (fcinfo->nargs == 3) ? start : 0xffff; res = inner_subltree(t, start, end); -- GitLab