Re: [PATCH] Add crc32(text) & crc32(bytea)
| От | Nathan Bossart |
|---|---|
| Тема | Re: [PATCH] Add crc32(text) & crc32(bytea) |
| Дата | |
| Msg-id | Zqu2JJ0uW-n-pljs@nathan обсуждение исходный текст |
| Ответ на | Re: [PATCH] Add crc32(text) & crc32(bytea) (Aleksander Alekseev <aleksander@timescale.com>) |
| Ответы |
Re: [PATCH] Add crc32(text) & crc32(bytea)
|
| Список | pgsql-hackers |
+/*
+ * Calculate CRC32 of the given data.
+ */
+static inline pg_crc32
+crc32_sz(const char *buf, int size)
+{
+ pg_crc32 crc;
+ const char *p = buf;
+
+ INIT_TRADITIONAL_CRC32(crc);
+ while (size > 0)
+ {
+ char c = (char) (*p);
+
+ COMP_TRADITIONAL_CRC32(crc, &c, 1);
+ size--;
+ p++;
+ }
+ FIN_TRADITIONAL_CRC32(crc);
+ return crc;
+}
I'm curious why we need to do this instead of only using the macros:
INIT_TRADITIONAL_CRC32(crc);
COMP_TRADITIONAL_CRC32(crc, VARDATA_ANY(in), len);
FIN_TRADITIONAL_CRC32(crc);
+ * IDENTIFICATION
+ * src/backend/utils/adt/hashfuncs.c
Perhaps these would fit into src/backend/utils/hash/pg_crc.c?
--
nathan
В списке pgsql-hackers по дате отправления: