fix default parameter error

This commit is contained in:
dreamcmi 2022-11-18 22:12:23 +08:00
parent ed6f18dac5
commit ce05a5f03c
4 changed files with 102 additions and 26 deletions

View File

@ -19,6 +19,13 @@ enum {
void to_hex(uint8_t* s, int l, uint8_t* d); void to_hex(uint8_t* s, int l, uint8_t* d);
void _hashlib_Hash_md5(PikaObj* self, Arg* data) { void _hashlib_Hash_md5(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -30,10 +37,16 @@ void _hashlib_Hash_md5(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_MD5); obj_setInt(self, "mode", PIKA_HASHLIB_MD5);
return;
} }
void _hashlib_Hash_sha1(PikaObj* self, Arg* data) { void _hashlib_Hash_sha1(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -45,10 +58,15 @@ void _hashlib_Hash_sha1(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA1); obj_setInt(self, "mode", PIKA_HASHLIB_SHA1);
return;
} }
void _hashlib_Hash_sha224(PikaObj* self, Arg* data) { void _hashlib_Hash_sha224(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -60,10 +78,16 @@ void _hashlib_Hash_sha224(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA224); obj_setInt(self, "mode", PIKA_HASHLIB_SHA224);
return;
} }
void _hashlib_Hash_sha256(PikaObj* self, Arg* data) { void _hashlib_Hash_sha256(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -75,10 +99,16 @@ void _hashlib_Hash_sha256(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA256); obj_setInt(self, "mode", PIKA_HASHLIB_SHA256);
return;
} }
void _hashlib_Hash_sha384(PikaObj* self, Arg* data) { void _hashlib_Hash_sha384(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -90,10 +120,16 @@ void _hashlib_Hash_sha384(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA384); obj_setInt(self, "mode", PIKA_HASHLIB_SHA384);
return;
} }
void _hashlib_Hash_sha512(PikaObj* self, Arg* data) { void _hashlib_Hash_sha512(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -105,7 +141,6 @@ void _hashlib_Hash_sha512(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA512); obj_setInt(self, "mode", PIKA_HASHLIB_SHA512);
return;
} }
void _hashlib_Hash_new(PikaObj* self, char* mode) { void _hashlib_Hash_new(PikaObj* self, char* mode) {
@ -148,10 +183,13 @@ void _hashlib_Hash_new(PikaObj* self, char* mode) {
} else { } else {
obj_setErrorCode(self, -1); // not support mode obj_setErrorCode(self, -1); // not support mode
} }
return;
} }
void _hashlib_Hash_update(PikaObj* self, Arg* data) { void _hashlib_Hash_update(PikaObj* self, Arg* data) {
if (ARG_TYPE_BYTES != arg_getType(data)) {
obj_setErrorCode(self, -2); // io error
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);

View File

@ -7,37 +7,37 @@ def new(mode: str) -> _hashlib.Hash:
return hash return hash
def md5(data: bytes) -> _hashlib.Hash: def md5(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.md5(data) hash.md5(data)
return hash return hash
def sha1(data: bytes) -> _hashlib.Hash: def sha1(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha1(data) hash.sha1(data)
return hash return hash
def sha224(data: bytes) -> _hashlib.Hash: def sha224(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha224(data) hash.sha224(data)
return hash return hash
def sha256(data: bytes) -> _hashlib.Hash: def sha256(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha256(data) hash.sha256(data)
return hash return hash
def sha384(data: bytes) -> _hashlib.Hash: def sha384(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha384(data) hash.sha384(data)
return hash return hash
def sha512(data: bytes) -> _hashlib.Hash: def sha512(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha512(data) hash.sha512(data)
return hash return hash

View File

@ -7,37 +7,37 @@ def new(mode: str) -> _hashlib.Hash:
return hash return hash
def md5(data: bytes) -> _hashlib.Hash: def md5(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.md5(data) hash.md5(data)
return hash return hash
def sha1(data: bytes) -> _hashlib.Hash: def sha1(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha1(data) hash.sha1(data)
return hash return hash
def sha224(data: bytes) -> _hashlib.Hash: def sha224(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha224(data) hash.sha224(data)
return hash return hash
def sha256(data: bytes) -> _hashlib.Hash: def sha256(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha256(data) hash.sha256(data)
return hash return hash
def sha384(data: bytes) -> _hashlib.Hash: def sha384(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha384(data) hash.sha384(data)
return hash return hash
def sha512(data: bytes) -> _hashlib.Hash: def sha512(data = None) -> _hashlib.Hash:
hash = _hashlib.Hash() hash = _hashlib.Hash()
hash.sha512(data) hash.sha512(data)
return hash return hash

View File

@ -19,6 +19,13 @@ enum {
void to_hex(uint8_t* s, int l, uint8_t* d); void to_hex(uint8_t* s, int l, uint8_t* d);
void _hashlib_Hash_md5(PikaObj* self, Arg* data) { void _hashlib_Hash_md5(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -30,10 +37,16 @@ void _hashlib_Hash_md5(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_MD5); obj_setInt(self, "mode", PIKA_HASHLIB_MD5);
return;
} }
void _hashlib_Hash_sha1(PikaObj* self, Arg* data) { void _hashlib_Hash_sha1(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -45,10 +58,15 @@ void _hashlib_Hash_sha1(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA1); obj_setInt(self, "mode", PIKA_HASHLIB_SHA1);
return;
} }
void _hashlib_Hash_sha224(PikaObj* self, Arg* data) { void _hashlib_Hash_sha224(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -60,10 +78,16 @@ void _hashlib_Hash_sha224(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA224); obj_setInt(self, "mode", PIKA_HASHLIB_SHA224);
return;
} }
void _hashlib_Hash_sha256(PikaObj* self, Arg* data) { void _hashlib_Hash_sha256(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -75,10 +99,16 @@ void _hashlib_Hash_sha256(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA256); obj_setInt(self, "mode", PIKA_HASHLIB_SHA256);
return;
} }
void _hashlib_Hash_sha384(PikaObj* self, Arg* data) { void _hashlib_Hash_sha384(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -90,10 +120,16 @@ void _hashlib_Hash_sha384(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA384); obj_setInt(self, "mode", PIKA_HASHLIB_SHA384);
return;
} }
void _hashlib_Hash_sha512(PikaObj* self, Arg* data) { void _hashlib_Hash_sha512(PikaObj* self, Arg* data) {
ArgType t = arg_getType(data);
if (ARG_TYPE_NONE != t) {
if (ARG_TYPE_BYTES != t) {
obj_setErrorCode(self, -2); // io error
}
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);
@ -105,7 +141,6 @@ void _hashlib_Hash_sha512(PikaObj* self, Arg* data) {
} }
obj_setStruct(self, "context", context); obj_setStruct(self, "context", context);
obj_setInt(self, "mode", PIKA_HASHLIB_SHA512); obj_setInt(self, "mode", PIKA_HASHLIB_SHA512);
return;
} }
void _hashlib_Hash_new(PikaObj* self, char* mode) { void _hashlib_Hash_new(PikaObj* self, char* mode) {
@ -148,10 +183,13 @@ void _hashlib_Hash_new(PikaObj* self, char* mode) {
} else { } else {
obj_setErrorCode(self, -1); // not support mode obj_setErrorCode(self, -1); // not support mode
} }
return;
} }
void _hashlib_Hash_update(PikaObj* self, Arg* data) { void _hashlib_Hash_update(PikaObj* self, Arg* data) {
if (ARG_TYPE_BYTES != arg_getType(data)) {
obj_setErrorCode(self, -2); // io error
}
size_t size = arg_getBytesSize(data); size_t size = arg_getBytesSize(data);
uint8_t* data_h = arg_getBytes(data); uint8_t* data_h = arg_getBytes(data);