1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-28 00:30:12 +00:00

Implement variable sized element count for arrays.

git-svn-id: svn://svn.cc65.org/cc65/trunk@5266 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
uz 2011-08-23 16:15:41 +00:00
parent 1e0ab407cd
commit 25171465d3
2 changed files with 30 additions and 15 deletions

View File

@ -50,16 +50,24 @@ void GT_AddArray (StrBuf* Type, unsigned ArraySize)
* NOT add the element type!
*/
{
unsigned I;
unsigned SizeBytes;
/* Add the array token */
/* Remember the current position */
char* A = SB_GetBuf (Type) + SB_GetLen (Type);
/* Add a dummy array token */
SB_AppendChar (Type, GT_TYPE_ARRAY);
/* Add the size. */
for (I = 0; I < 4; ++I) {
SizeBytes = 0;
do {
SB_AppendChar (Type, ArraySize & 0xFF);
ArraySize >>= 8;
}
++SizeBytes;
} while (ArraySize);
/* Write the correct array token */
*A = GT_ARRAY (SizeBytes);
}
@ -69,11 +77,18 @@ unsigned GT_GetArraySize (StrBuf* Type)
* The index position will get moved past the array size.
*/
{
unsigned Size;
Size = (unsigned)SB_Get (Type);
Size |= (unsigned)SB_Get (Type) << 8;
Size |= (unsigned)SB_Get (Type) << 16;
Size |= (unsigned)SB_Get (Type) << 24;
/* Get the number of bytes for the element count */
unsigned SizeBytes = GT_GET_SIZE (SB_Get (Type));
/* Read the size */
unsigned Size = 0;
const char* Buf = SB_GetConstBuf (Type) + SB_GetLen (Type);
while (SizeBytes--) {
Size <<= 8;
Size |= Buf[SizeBytes];
}
/* Return it */
return Size;
}
@ -100,7 +115,7 @@ const char* GT_AsString (const StrBuf* Type, StrBuf* String)
}
/* Terminate the string so it can be used with string functions */
SB_Terminate (String);
SB_Terminate (String);
/* Return the contents of String */
return SB_GetConstBuf (String);

View File

@ -89,10 +89,7 @@
#define GT_IS_LITTLE_ENDIAN(x) (((x) & GT_BYTEORDER_MASK) == GT_LITTLE_ENDIAN)
#define GT_IS_BIG_ENDIAN(x) (((x) & GT_BYTEORDER_MASK) == GT_BIG_ENDIAN)
/* Type of the data. Since we want to have zero as a terminator, we must
* introduce one thing that cannot be zero for normal data. This is the
* type.
*/
/* Type of the data. */
#define GT_TYPE_INT 0x20U
#define GT_TYPE_PTR 0x40U
#define GT_TYPE_FLOAT 0x60U
@ -117,6 +114,7 @@
#define GT_DBYTE (GT_TYPE_PTR | GT_BIG_ENDIAN | GT_UNSIGNED | GT_SIZE_2)
#define GT_PTR (GT_TYPE_PTR | GT_LITTLE_ENDIAN | GT_UNSIGNED | GT_SIZE_2)
#define GT_FAR_PTR (GT_TYPE_PTR | GT_LITTLE_ENDIAN | GT_UNSIGNED | GT_SIZE_3)
#define GT_ARRAY(size) (GT_TYPE_ARRAY | ((size) - 1))
@ -133,7 +131,9 @@ void GT_AddArray (StrBuf* Type, unsigned ArraySize);
unsigned GT_GetArraySize (StrBuf* Type);
/* Retrieve the size of an array stored in Type at the current index position.
* The index position will get moved past the array size.
* Note: Index must point to the array token itself, since the size of the
* element count is encoded there. The index position will get moved past the
* array.
*/
const char* GT_AsString (const StrBuf* Type, StrBuf* String);