From 0627eff3602c0ce0e8358d48ddb3ffa73963e4d0 Mon Sep 17 00:00:00 2001 From: Tom Lane Date: Sat, 21 Feb 2015 16:29:45 -0500 Subject: [PATCH] Don't need to explain [1] kluge anymore in xfunc.sgml. --- doc/src/sgml/xfunc.sgml | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/doc/src/sgml/xfunc.sgml b/doc/src/sgml/xfunc.sgml index f40504c481..97a56562d3 100644 --- a/doc/src/sgml/xfunc.sgml +++ b/doc/src/sgml/xfunc.sgml @@ -1885,17 +1885,12 @@ typedef struct typedef struct { int32 length; - char data[1]; + char data[FLEXIBLE_ARRAY_MEMBER]; } text; - Obviously, the data field declared here is not long enough to hold - all possible strings. Since it's impossible to declare a variable-size - structure in C, we rely on the knowledge that the - C compiler won't range-check array subscripts. We - just allocate the necessary amount of space and then access the array as - if it were declared the right length. (This is a common trick, which - you can read about in many textbooks about C.) + The [FLEXIBLE_ARRAY_MEMBER] notation means that the actual + length of the data part is not specified by this declaration.