X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftypes%2Fdecl_extvar.c;h=24ff39a0284cce4b550af4a14865b16a30aa951d;hb=d4bd55e7d9b1cf63cd6fdc96b70010a0c2aca963;hp=21323da0fbe07cf4136bd27771cdc767f74743cb;hpb=35060621f2fd5079502543d17942127c1a602f72;p=m6w6%2Fext-psi diff --git a/src/types/decl_extvar.c b/src/types/decl_extvar.c index 21323da..24ff39a 100644 --- a/src/types/decl_extvar.c +++ b/src/types/decl_extvar.c @@ -27,9 +27,7 @@ #include "php_psi.h" -#include #include - #include #include "data.h" @@ -71,27 +69,14 @@ bool psi_decl_extvar_validate(struct psi_data *data, } if (!evar->sym) { - size_t i = 0; - void *dl; - - while (!evar->sym && psi_plist_get(data->file.dlopened, i++, &dl)) { - evar->sym = dlsym(dl, evar->arg->var->name->val); - } + evar->sym = psi_dlsym(data->file.dlopened, evar->arg->var->name->val, + evar->redir ? evar->redir->val : NULL); } if (!evar->sym) { -#ifndef RTLD_NEXT -# define RTLD_NEXT ((void *) -1l) -#endif -#ifndef RTLD_DEFAULT -# define RTLD_DEFAULT ((void *) 0) -#endif - evar->sym = dlsym(RTLD_DEFAULT, evar->arg->var->name->val); - if (!evar->sym) { - data->error(data, evar->arg->var->token, PSI_WARNING, - "Failed to locate symbol '%s': %s", evar->arg->var->name->val, - dlerror() ?: "not found"); - return false; - } + data->error(data, evar->arg->var->token, PSI_WARNING, + "Failed to locate symbol '%s': %s", evar->arg->var->name->val, + dlerror() ?: "not found"); + return false; } evar->getter = psi_decl_extvar_getter(evar); @@ -106,11 +91,11 @@ bool psi_decl_extvar_validate(struct psi_data *data, return true; } -void psi_decl_extvar_dump(int fd, struct psi_decl_extvar *evar) +void psi_decl_extvar_dump(struct psi_dump *dump, struct psi_decl_extvar *evar) { - dprintf(fd, "extern "); - psi_decl_arg_dump(fd, evar->arg, 0); - dprintf(fd, ";\n"); + PSI_DUMP(dump, "extern "); + psi_decl_arg_dump(dump, evar->arg, 0); + PSI_DUMP(dump, ";\n"); } struct psi_decl *psi_decl_extvar_setter(struct psi_decl_extvar *evar) @@ -166,7 +151,12 @@ struct psi_decl *psi_decl_extvar_getter(struct psi_decl_extvar *evar) void psi_decl_extvar_get(struct psi_decl_extvar *evar, void *ptr) { - memcpy(ptr, evar->sym, evar->size); + if (evar->arg->var->array_size) { + /* arrays are passed as pointer */ + *(void **) ptr = evar->sym; + } else { + memcpy(ptr, evar->sym, evar->size); + } } @@ -182,4 +172,3 @@ bool psi_decl_extvar_is_blacklisted(const char *name) } return false; } -