diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-02-11 02:09:23 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-02-11 02:09:23 +0000 |
commit | 935275bb5952b59b65c6a038a4b825aea95562ae (patch) | |
tree | 4f6fe32cbd24811dcc0b38153d426adc845dde02 /ext/digest/digest.h | |
parent | b632ca436c5d06defc87df8b2a4774680e9cf6ef (diff) | |
download | ruby-935275bb5952b59b65c6a038a4b825aea95562ae.tar.gz |
digest: define Finish func from Final func
* ext/digest/digest.h (DEFINE_FINISH_FUNC_FROM_FINAL): macro for
finish functions, by inverting arguments order.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@49564 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/digest/digest.h')
-rw-r--r-- | ext/digest/digest.h | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/ext/digest/digest.h b/ext/digest/digest.h index 85848d5682..30359ad348 100644 --- a/ext/digest/digest.h +++ b/ext/digest/digest.h @@ -30,3 +30,22 @@ typedef struct { rb_digest_hash_update_func_t update_func; rb_digest_hash_finish_func_t finish_func; } rb_digest_metadata_t; + +#define DEFINE_UPDATE_FUNC_FOR_UINT(name) \ +void \ +rb_digest_##name##_update(void *ctx, unsigned char *ptr, size_t size) \ +{ \ + const unsigned int stride = 16384; \ + \ + for (; size > stride; size -= stride, ptr += stride) { \ + name##_Update(ctx, ptr, stride); \ + } \ + if (size > 0) name##_Update(ctx, ptr, size); \ +} + +#define DEFINE_FINISH_FUNC_FROM_FINAL(name) \ +int \ +rb_digest_##name##_finish(void *ctx, unsigned char *ptr) \ +{ \ + return name##_Final(ptr, ctx); \ +} |