Commit 2c914937 authored by Teodor Sigaev's avatar Teodor Sigaev

Fix subpath and subltree. Allow to return '' value.

subpath(ltree,0,0) returns ''.
parent fd4c7754
......@@ -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);
......
......@@ -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);
......
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