| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- #include "pocketpy/common/strname.h"
- #include "pocketpy/common/smallmap.h"
- #include "pocketpy/common/utils.h"
- #include "pocketpy/common/vector.h"
- #include "pocketpy/pocketpy.h"
- #include <stdio.h>
- // TODO: use a more efficient data structure
- static c11_smallmap_s2n _interned;
- static c11_vector /*T=char* */ _r_interned;
- void py_Name__initialize() {
- c11_smallmap_s2n__ctor(&_interned);
- for(int i = 0; i < _r_interned.count; i++) {
- free(c11__at(char*, &_r_interned, i));
- }
- c11_vector__ctor(&_r_interned, sizeof(c11_sv));
- #define MAGIC_METHOD(x) assert(x == py_name(#x));
- #include "pocketpy/xmacros/magics.h"
- #undef MAGIC_METHOD
- }
- void py_Name__finalize() {
- // free all char*
- for(int i = 0; i < _r_interned.count; i++) {
- free(c11__getitem(char*, &_r_interned, i));
- }
- c11_smallmap_s2n__dtor(&_interned);
- c11_vector__dtor(&_r_interned);
- }
- py_Name py_name(const char* name) { return py_namev((c11_sv){name, strlen(name)}); }
- py_Name py_namev(c11_sv name) {
- // TODO: PK_GLOBAL_SCOPE_LOCK()
- uint16_t index = c11_smallmap_s2n__get(&_interned, name, 0);
- if(index != 0) return index;
- // generate new index
- if(_interned.count > 65530) c11__abort("py_Name index overflow");
- // NOTE: we must allocate the string in the heap so iterators are not invalidated
- char* p = malloc(name.size + 1);
- memcpy(p, name.data, name.size);
- p[name.size] = '\0';
- c11_vector__push(char*, &_r_interned, p);
- index = _r_interned.count; // 1-based
- // save to _interned
- c11_smallmap_s2n__set(&_interned, (c11_sv){p, name.size}, index);
- assert(_interned.count == _r_interned.count);
- return index;
- }
- const char* py_name2str(py_Name index) {
- assert(index > 0 && index <= _interned.count);
- return c11__getitem(char*, &_r_interned, index - 1);
- }
- c11_sv py_name2sv(py_Name index) {
- assert(index > 0 && index <= _interned.count);
- const char* p = py_name2str(index);
- return (c11_sv){p, strlen(p)};
- }
|