projects
/
m6w6
/
ext-psi
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
|
github
raw
|
inline
| side by side
missing m4
[m6w6/ext-psi]
/
src
/
parser.h
diff --git
a/src/parser.h
b/src/parser.h
index 8c25e88b221ce26e9e9dcc036de1d09b56f6e2ec..19bea06429c90c35cebbf12f921f592d241da163 100644
(file)
--- a/
src/parser.h
+++ b/
src/parser.h
@@
-13,6
+13,8
@@
#define BSIZE 256
#define PSI_T_POINTER PSI_T_ASTERISK
#define BSIZE 256
#define PSI_T_POINTER PSI_T_ASTERISK
+#define PSI_T_LONG_DOUBLE (PSI_T_DOUBLE << 16)
+
typedef int token_t;
/* in php_psi.h */
typedef int token_t;
/* in php_psi.h */
@@
-82,7
+84,7
@@
static inline decl_type *init_decl_type_ex(token_t type, int argc, ...) {
pos = all;
ptr = realloc(ptr, 1 + (all += len));
} else {
pos = all;
ptr = realloc(ptr, 1 + (all += len));
} else {
- ptr = malloc(
ptr,
1 + (all = len));
+ ptr = malloc(1 + (all = len));
}
memcpy(ptr + pos, arg, len);
}
}
memcpy(ptr + pos, arg, len);
}
@@
-318,7
+320,7
@@
typedef struct decl_callinfo {
void *info;
size_t argc;
void **args;
void *info;
size_t argc;
void **args;
- void *rval;
+ void *
*
rval;
} decl_callinfo;
typedef struct decl {
} decl_callinfo;
typedef struct decl {
@@
-375,6
+377,10
@@
typedef struct decl_struct {
char *name;
decl_args *args;
size_t size;
char *name;
decl_args *args;
size_t size;
+ struct {
+ void *type;
+ void (*dtor)(void *type);
+ } engine;
} decl_struct;
static inline decl_struct *init_decl_struct(const char *name, decl_args *args) {
} decl_struct;
static inline decl_struct *init_decl_struct(const char *name, decl_args *args) {
@@
-391,6
+397,9
@@
static inline void free_decl_struct(decl_struct *s) {
if (s->args) {
free_decl_args(s->args);
}
if (s->args) {
free_decl_args(s->args);
}
+ if (s->engine.type && s->engine.dtor) {
+ s->engine.dtor(s->engine.type);
+ }
free(s->name);
free(s);
}
free(s->name);
free(s);
}
@@
-1204,7
+1213,7
@@
static inline impl_val *enref_impl_val(void *ptr, decl_var *var) {
var->name, var->pointer_level, var->arg->var->pointer_level,
var->array_size, var->arg->var->array_size);
#endif
var->name, var->pointer_level, var->arg->var->pointer_level,
var->array_size, var->arg->var->array_size);
#endif
- if (!var->pointer_level && real_decl_type(var->arg->type)->type != PSI_T_STRUCT) {
+ if (!var->pointer_level
){//
&& real_decl_type(var->arg->type)->type != PSI_T_STRUCT) {
return ptr;
}
return ptr;
}
@@
-1303,7
+1312,7
@@
static inline PSI_Token *PSI_TokenAlloc(PSI_Parser *P) {
token_len = P->cur - P->tok;
fname_len = strlen(P->psi.file.fn);
token_len = P->cur - P->tok;
fname_len = strlen(P->psi.file.fn);
- T = calloc(1, PSI_TokenAllocSize(token_len, fname_len);
+ T = calloc(1, PSI_TokenAllocSize(token_len, fname_len)
)
;
T->type = token_typ;
T->size = token_len;
T->text = &T->buf[0];
T->type = token_typ;
T->size = token_len;
T->text = &T->buf[0];
@@
-1343,7
+1352,7
@@
static inline PSI_Token *PSI_TokenCat(unsigned argc, ...) {
T = realloc(T, PSI_TokenAllocSize(T->size + arg->size, fname_len));
memmove(&T->buf[T->size + 1], T->file, fname_len + 1);
T = realloc(T, PSI_TokenAllocSize(T->size + arg->size, fname_len));
memmove(&T->buf[T->size + 1], T->file, fname_len + 1);
- memcpy(T->file - 1, arg->text, arg->size + 1)
+ memcpy(T->file - 1, arg->text, arg->size + 1)
;
T->file = &T->buf[T->size + 1];
} else {
T = PSI_TokenCopy(arg);
T->file = &T->buf[T->size + 1];
} else {
T = PSI_TokenCopy(arg);