This commit is contained in:
blueloveTH 2023-04-08 22:41:10 +08:00
parent 5e13149a4d
commit 2e46449117
3 changed files with 60 additions and 31 deletions

View File

@ -277,8 +277,6 @@ __NEXT_STEP:;
} DISPATCH(); } DISPATCH();
case OP_DICT_ADD: { case OP_DICT_ADD: {
PyObject* kv = frame->popx(); PyObject* kv = frame->popx();
// we do copy here to avoid accidental gc in `kv`
// TODO: optimize to avoid copy
Tuple& t = CAST(Tuple& ,kv); Tuple& t = CAST(Tuple& ,kv);
fast_call(__setitem__, Args{frame->top_1(), t[0], t[1]}); fast_call(__setitem__, Args{frame->top_1(), t[0], t[1]});
} DISPATCH(); } DISPATCH();

View File

@ -2,6 +2,7 @@
#include "common.h" #include "common.h"
#include "error.h" #include "error.h"
#include "new_str.h"
#include "str.h" #include "str.h"
namespace pkpy{ namespace pkpy{
@ -170,13 +171,9 @@ struct Lexer {
int eat_name() { int eat_name() {
curr_char--; curr_char--;
while(true){ while(true){
uint8_t c = peekchar(); unsigned char c = peekchar();
int u8bytes = 0; int u8bytes = utf8len(c);
if((c & 0b10000000) == 0b00000000) u8bytes = 1; if(u8bytes == 0) return 1;
else if((c & 0b11100000) == 0b11000000) u8bytes = 2;
else if((c & 0b11110000) == 0b11100000) u8bytes = 3;
else if((c & 0b11111000) == 0b11110000) u8bytes = 4;
else return 1;
if(u8bytes == 1){ if(u8bytes == 1){
if(isalpha(c) || c=='_' || isdigit(c)) { if(isalpha(c) || c=='_' || isdigit(c)) {
curr_char++; curr_char++;

View File

@ -2,33 +2,52 @@
#include "common.h" #include "common.h"
#include "memory.h" #include "memory.h"
#include <string_view>
namespace pkpy{ namespace pkpy{
struct String{ inline int utf8len(unsigned char c){
char* data; if((c & 0b10000000) == 0) return 1;
int size; if((c & 0b11100000) == 0b11000000) return 2;
if((c & 0b11110000) == 0b11100000) return 3;
String(): data((char*)pool64.alloc(0)), size(0) {} if((c & 0b11111000) == 0b11110000) return 4;
String(int size): data((char*)pool64.alloc(size)), size(size) {} if((c & 0b11111100) == 0b11111000) return 5;
String(const char* str) { if((c & 0b11111110) == 0b11111100) return 6;
size = strlen(str); return 0;
data = (char*)pool64.alloc(size);
memcpy(data, str, size);
} }
String(const String& other): data((char*)pool64.alloc(other.size)), size(other.size) { struct String{
int size;
bool is_ascii;
char* data;
String(): size(0), is_ascii(true), data((char*)pool64.alloc(0)) {}
String(int size, bool is_ascii): size(size), is_ascii(is_ascii) {
data = (char*)pool64.alloc(size);
}
String(const char* str): size(strlen(str)), is_ascii(true) {
data = (char*)pool64.alloc(size);
for(int i=0; i<size; i++){
data[i] = str[i];
if(!isascii(str[i])) is_ascii = false;
}
}
String(const String& other): size(other.size), is_ascii(other.is_ascii) {
data = (char*)pool64.alloc(size);
memcpy(data, other.data, size); memcpy(data, other.data, size);
} }
String(String&& other): data(other.data), size(other.size) { String(String&& other): size(other.size), is_ascii(other.is_ascii), data(other.data) {
other.data = nullptr; other.data = nullptr;
other.size = 0;
} }
String& operator=(const String& other){ String& operator=(const String& other){
if(data!=nullptr) pool64.dealloc(data); if(data!=nullptr) pool64.dealloc(data);
size = other.size; size = other.size;
is_ascii = other.is_ascii;
data = (char*)pool64.alloc(size); data = (char*)pool64.alloc(size);
memcpy(data, other.data, size); memcpy(data, other.data, size);
return *this; return *this;
@ -37,6 +56,7 @@ struct String{
String& operator=(String&& other){ String& operator=(String&& other){
if(data!=nullptr) pool64.dealloc(data); if(data!=nullptr) pool64.dealloc(data);
size = other.size; size = other.size;
is_ascii = other.is_ascii;
data = other.data; data = other.data;
other.data = nullptr; other.data = nullptr;
return *this; return *this;
@ -55,7 +75,7 @@ struct String{
} }
String operator+(const String& other) const { String operator+(const String& other) const {
String ret(size + other.size); String ret(size + other.size, is_ascii && other.is_ascii);
memcpy(ret.data, data, size); memcpy(ret.data, data, size);
memcpy(ret.data + size, other.data, other.size); memcpy(ret.data + size, other.data, other.size);
return ret; return ret;
@ -101,15 +121,11 @@ struct String{
} }
String substr(int start, int len) const { String substr(int start, int len) const {
String ret(len); String ret(len, is_ascii);
memcpy(ret.data, data + start, len); memcpy(ret.data, data + start, len);
return ret; return ret;
} }
String substr(int start) const {
return substr(start, size - start);
}
char* dup_c_str() const { char* dup_c_str() const {
char* p = (char*)malloc(size + 1); char* p = (char*)malloc(size + 1);
memcpy(p, data, size); memcpy(p, data, size);
@ -133,11 +149,29 @@ struct String{
})); }));
return String(copy.c_str()); return String(copy.c_str());
} }
/*************unicode*************/
int _u8_index(int i) const{
if(is_ascii) return i;
int j = 0;
while(i > 0){
j += utf8len(data[j]);
i--;
}
return j;
}
String u8_getitem(int i) const {
i = _u8_index(i);
return substr(i, utf8len(data[i]));
}
String u8_slice(int start, int end) const{
start = _u8_index(start);
end = _u8_index(end);
return substr(start, end - start);
}
}; };
struct UnicodeString: String{
};
} // namespace pkpy } // namespace pkpy