Re: BUG #17912: Invalid memory access when converting plpython' array containing empty array
От | Tom Lane |
---|---|
Тема | Re: BUG #17912: Invalid memory access when converting plpython' array containing empty array |
Дата | |
Msg-id | 1805878.1682788590@sss.pgh.pa.us обсуждение исходный текст |
Ответ на | Re: BUG #17912: Invalid memory access when converting plpython' array containing empty array (Alexander Lakhin <exclusion@gmail.com>) |
Ответы |
Re: BUG #17912: Invalid memory access when converting plpython' array containing empty array
|
Список | pgsql-bugs |
Alexander Lakhin <exclusion@gmail.com> writes: > Thanks for fixing this! > Now python's handling of arrays is much nicer and is aligned with the plperl's behaviour: Well, mostly. As you noticed, it's a bit weird about zero-length sub-lists, treating those as scalars. I had been intending to keep the existing behavior there, but now that I see that plperl does it the other way (that is, you end up with an overall empty output array) I think we ought to make plpython do likewise. > While playing with plperl, I found that it handles arrays not perfectly too: > CREATE OR REPLACE FUNCTION test_pl() RETURNS text[] AS $$return [1, []];$$ LANGUAGE plperl; > SELECT * FROM test_pl(); Ugh. I pushed a fix for that. On the whole, I like plperl's implementation of this better, that is it scans the data structure just once and uses an ArrayBuildState to accumulate the datums. So now I'm thinking about throwing out the code in PLySequence_ToArray[_recurse] altogether and borrowing plperl's logic. I think that would make it easier to deal with zero-length sublists correctly. Haven't written the patch yet though. > I suppose that waiting for v17 is preferable if the patch is considered as > bringing a new feature (it's not the case) or could require extra time to > stabilize. But I'm afraid that anomalies, that would require additional > fixes for the change stabilization, could be related to the existing > code, and thus that extra time will be invested in improving v16- too. I'm a little uncomfortable with changing the semantics of non-failing cases in the back branches. regards, tom lane
В списке pgsql-bugs по дате отправления: