From e67a951720caa81caf0c507fc22085a74f92187f Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Fri, 24 Jun 2005 17:22:57 +0000 Subject: [PATCH] add a note about variable length array git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22278 91177308-0d34-0410-b5e6-96231b3b80d8 --- docs/LangRef.html | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/docs/LangRef.html b/docs/LangRef.html index 3fac48d5c31..73e7e2db1fa 100644 --- a/docs/LangRef.html +++ b/docs/LangRef.html @@ -717,6 +717,14 @@ be any type with a size.

+ +

Note that 'variable sized arrays' can be implemented in LLVM With a zero +length array. Normally accesses past the end of an array are undefined in +LLVM (e.g. it is illegal to access the 5th element of a 3 element array). +As a special case, however, zero length arrays are recognized to be variable +length. This allows implementation of 'pascal style arrays' with the LLVM +type "{ int, [0 x float]}", for example.

+ @@ -1989,7 +1997,15 @@ the LLVM code for the given testcase is equivalent to:

ret int* %t5 } + +

Note that it is undefined to access an array out of bounds: array and +pointer indexes must always be within the defined bounds of the array type. +The one exception for this rules is zero length arrays. These arrays are +defined to be accessible as variable length arrays, which requires access +beyond the zero'th element.

+
Example:
+
     ; yields [12 x ubyte]*:aptr
     %aptr = getelementptr {int, [12 x ubyte]}* %sptr, long 0, uint 1