fixed the definition of STIX_SETBITS()
This commit is contained in:
		| @ -2693,8 +2693,8 @@ static int compile_method_primitive (stix_t* stix) | |||||||
| 		{ | 		{ | ||||||
| 			case STIX_IOTOK_NUMLIT: /* TODO: allow only an integer */ | 			case STIX_IOTOK_NUMLIT: /* TODO: allow only an integer */ | ||||||
| 	/*TODO: more checks the validity of the primitive number. support number with radix and so on support more extensive syntax. support primitive name, not number*/ | 	/*TODO: more checks the validity of the primitive number. support number with radix and so on support more extensive syntax. support primitive name, not number*/ | ||||||
| 				ptr = stix->c->tok.name.ptr; | 				ptr = TOKEN_NAME_PTR(stix); | ||||||
| 				end = ptr + stix->c->tok.name.len; | 				end = ptr + TOKEN_NAME_LEN(stix); | ||||||
| 				prim_no = 0; | 				prim_no = 0; | ||||||
| 				while (ptr < end && is_digitchar(*ptr))  | 				while (ptr < end && is_digitchar(*ptr))  | ||||||
| 				{ | 				{ | ||||||
| @ -3209,7 +3209,6 @@ static int compile_block_expression (stix_t* stix) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| static int add_to_byte_array_literal_buffer (stix_t* stix, stix_oob_t b) | static int add_to_byte_array_literal_buffer (stix_t* stix, stix_oob_t b) | ||||||
| { | { | ||||||
| 	if (stix->c->mth.balit_count >= stix->c->mth.balit_capa) | 	if (stix->c->mth.balit_count >= stix->c->mth.balit_capa) | ||||||
| @ -3324,8 +3323,8 @@ static int __read_array_literal (stix_t* stix, stix_oop_t* xlit) | |||||||
| 				break; | 				break; | ||||||
|  |  | ||||||
| 			case STIX_IOTOK_CHARLIT: | 			case STIX_IOTOK_CHARLIT: | ||||||
| 				STIX_ASSERT (stix->c->tok.name.len == 1); | 				STIX_ASSERT (TOKEN_NAME_LEN(stix) == 1); | ||||||
| 				lit = STIX_CHAR_TO_OOP(stix->c->tok.name.ptr[0]); | 				lit = STIX_CHAR_TO_OOP(TOKEN_NAME_PTR(stix)[0]); | ||||||
| 				break; | 				break; | ||||||
|  |  | ||||||
| 			case STIX_IOTOK_STRLIT: | 			case STIX_IOTOK_STRLIT: | ||||||
| @ -3585,8 +3584,8 @@ static int compile_expression_primary (stix_t* stix, const stix_oocs_t* ident, c | |||||||
| 				break; | 				break; | ||||||
|  |  | ||||||
| 			case STIX_IOTOK_CHARLIT: | 			case STIX_IOTOK_CHARLIT: | ||||||
| 				STIX_ASSERT (stix->c->tok.name.len == 1); | 				STIX_ASSERT (TOKEN_NAME_LEN(stix) == 1); | ||||||
| 				if (emit_push_character_literal(stix, stix->c->tok.name.ptr[0]) <= -1) return -1; | 				if (emit_push_character_literal(stix, TOKEN_NAME_PTR(stix)[0]) <= -1) return -1; | ||||||
| 				GET_TOKEN (stix); | 				GET_TOKEN (stix); | ||||||
| 				break; | 				break; | ||||||
|  |  | ||||||
| @ -5023,8 +5022,8 @@ static int __compile_pooldic_definition (stix_t* stix) | |||||||
| 				goto add_literal; | 				goto add_literal; | ||||||
|  |  | ||||||
| 			case STIX_IOTOK_CHARLIT: | 			case STIX_IOTOK_CHARLIT: | ||||||
| 				STIX_ASSERT (stix->c->tok.name.len == 1); | 				STIX_ASSERT (TOKEN_NAME_LEN(stix) == 1); | ||||||
| 				lit = STIX_CHAR_TO_OOP(stix->c->tok.name.ptr[0]); | 				lit = STIX_CHAR_TO_OOP(TOKEN_NAME_PTR(stix)[0]); | ||||||
| 				goto add_literal; | 				goto add_literal; | ||||||
|  |  | ||||||
| 			case STIX_IOTOK_STRLIT: | 			case STIX_IOTOK_STRLIT: | ||||||
|  | |||||||
| @ -276,5 +276,37 @@ int stix_prim_mod_con (stix_t* stix, stix_prim_mod_t* mod) | |||||||
| 	mod->query = query; | 	mod->query = query; | ||||||
| 	mod->unload = unload;  | 	mod->unload = unload;  | ||||||
| 	mod->ctx = STIX_NULL; | 	mod->ctx = STIX_NULL; | ||||||
|  |  | ||||||
|  | #if 0 | ||||||
|  |  | ||||||
|  | #include 'Stix.st'. | ||||||
|  | #import 'Console'. | ||||||
|  |  | ||||||
|  | 	c = stix_findclass (stix, "Console"); | ||||||
|  | 	if (!c) c = stix_makeclass (stix, "Console", "x y"); <- provides an API to create a simple class | ||||||
|  |  | ||||||
|  | 	stix_addmethod (stix, c, "open",         prim_open); | ||||||
|  | 	stix_addmethod (stix, c, "close:",       prim_close); | ||||||
|  | 	stix_addmethod (stix, c, "setCursorTo:", prim_setcursor); | ||||||
|  | 	stix_addmethod (stix, c, "clear", prim_clear ); | ||||||
|  | 	stix_addmethod (stix, c, "write", prim_write ); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* GRAMMER ENHANCEMENT */ | ||||||
|  | fun abc (a, b, c) <----- this style, register C style method | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun abc: a with: b c: c <----- smalltalk style  | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | abc->def (a, b, c)   <-------    use ->  as an c style method indicator | ||||||
|  | abc abc: a with: b c: c | ||||||
|  |  | ||||||
|  | #endif | ||||||
|  |  | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
|  | |||||||
| @ -434,7 +434,13 @@ struct stix_ntime_t | |||||||
| #define STIX_GETBITS(type,value,offset,length) \ | #define STIX_GETBITS(type,value,offset,length) \ | ||||||
| 	((((type)(value)) >> (offset)) & STIX_LBMASK(type,length)) | 	((((type)(value)) >> (offset)) & STIX_LBMASK(type,length)) | ||||||
|  |  | ||||||
|  | #define STIX_CLEARBITS(type,value,offset,length) \ | ||||||
|  | 	(((type)(value)) & ~(STIX_LBMASK(type,length) << (offset))) | ||||||
|  |  | ||||||
| #define STIX_SETBITS(type,value,offset,length,bits) \ | #define STIX_SETBITS(type,value,offset,length,bits) \ | ||||||
|  | 	(value = (STIX_CLEARBITS(type,value,offset,length) | (((bits) & STIX_LBMASK(type,length)) << (offset)))) | ||||||
|  |  | ||||||
|  | #define STIX_ORBITS(type,value,offset,length,bits) \ | ||||||
| 	(value = (((type)(value)) | (((bits) & STIX_LBMASK(type,length)) << (offset)))) | 	(value = (((type)(value)) | (((bits) & STIX_LBMASK(type,length)) << (offset)))) | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -560,6 +566,7 @@ struct stix_cmgr_t | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(__STDC_VERSION__) && (__STDC_VERSION__>=199901L) | #if defined(__STDC_VERSION__) && (__STDC_VERSION__>=199901L) | ||||||
|  | 	/* C99 has inline */ | ||||||
| #	define STIX_INLINE inline | #	define STIX_INLINE inline | ||||||
| #	define STIX_HAVE_INLINE | #	define STIX_HAVE_INLINE | ||||||
| #elif defined(__GNUC__) && defined(__GNUC_GNU_INLINE__) | #elif defined(__GNUC__) && defined(__GNUC_GNU_INLINE__) | ||||||
| @ -572,9 +579,6 @@ struct stix_cmgr_t | |||||||
| #	undef STIX_HAVE_INLINE | #	undef STIX_HAVE_INLINE | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * The STIX_TYPE_IS_SIGNED() macro determines if a type is signed. |  * The STIX_TYPE_IS_SIGNED() macro determines if a type is signed. | ||||||
|  * \code |  * \code | ||||||
|  | |||||||
| @ -63,7 +63,6 @@ | |||||||
|  */ |  */ | ||||||
| #define STIX_LIMIT_OBJ_SIZE | #define STIX_LIMIT_OBJ_SIZE | ||||||
|  |  | ||||||
|  |  | ||||||
| /* TODO: delete these header inclusion lines */ | /* TODO: delete these header inclusion lines */ | ||||||
| #include <string.h> | #include <string.h> | ||||||
| #include <assert.h> | #include <assert.h> | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user