X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=tests%2Fndbm%2Fndbm.psi;h=8258796ef8174f2ee53149d3cbb0f34adf930863;hp=139f446b2366bb673f6ededc9a357d19c107c745;hb=9d039c3e02435dafc558b8524d8e3728d2e5a704;hpb=2f5af21b263403997e154658635d6b6e6eaab453 diff --git a/tests/ndbm/ndbm.psi b/tests/ndbm/ndbm.psi index 139f446..8258796 100644 --- a/tests/ndbm/ndbm.psi +++ b/tests/ndbm/ndbm.psi @@ -1,37 +1,43 @@ +#include + +lib "gdbm_compat"; +#include + + function psi\dbm_open(string $file, int $open_flags, int $file_mode) : object { let file = pathval($file); let open_flags = intval($open_flags); let file_mode = intval($file_mode); - return to_object(dbm_open); + return dbm_open(file, open_flags, file_mode) as to_object(dbm_open); } -function psi\dbm_store(object $db, array $key, array $data, int $mode) : int { +function psi\dbm_store(object $db, string $key, string $data, int $mode) : int { let db = objval($db); let key = arrval($key, - strval($dptr), - intval($dsize) + dptr = strval($0), + dsize = strlen($0) ); let content = arrval($data, - strval($dptr), - intval($dsize) + dptr = strval($0), + dsize = strlen($0) ); let store_mode = intval($mode); - return to_int(dbm_store); + return dbm_store(db, key, content, store_mode) as to_int(dbm_store); } function psi\dbm_fetch(object $db, array $key) : array { let db = objval($db); let key = arrval($key, - strval($dptr), - intval($dsize) + dptr = strval($dptr), + dsize = intval($dsize) ); - return to_array(dbm_fetch, - to_string(dptr, dsize), - to_int(dsize) + return dbm_fetch(db, key) as to_array(dbm_fetch, + to_int(dsize), + to_string(dptr, dsize) ); } function psi\dbm_close(object $db) : void { let db = objval($db); - return void(dbm_close); + return dbm_close(db) as void(dbm_close); }