Skip to content

Commit

Permalink
Introduce const_sds for const-content sds (valkey-io#1553)
Browse files Browse the repository at this point in the history
`sds` is a typedef of `char *`.

`const sds` means `char * const`, i.e. a const-pointer to non-const
content.

More often, you would want `const char *`, i.e. a pointer to
const-content. Until now, it's not possible to express that. This PR
adds `const_sds` which is a pointer to const-content sds.

To get a const-pointer to const-content sds, you can use `const
const_sds`.

In this PR, some uses of `const sds` are replaced by `const_sds`. We can
use it more later.

Fixes valkey-io#1542

---------

Signed-off-by: Viktor Söderqvist <[email protected]>
Signed-off-by: proost <[email protected]>
  • Loading branch information
zuiderkwast authored and proost committed Jan 17, 2025
1 parent c33a7b1 commit cf8af09
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 21 deletions.
16 changes: 8 additions & 8 deletions src/sds.c
Original file line number Diff line number Diff line change
Expand Up @@ -187,19 +187,19 @@ sds sdsnew(const char *init) {
}

/* Duplicate an sds string. */
sds sdsdup(const sds s) {
sds sdsdup(const_sds s) {
return sdsnewlen(s, sdslen(s));
}

/*
* This method returns the minimum amount of bytes required to store the sds (header + data + NULL terminator).
*/
static inline size_t sdsminlen(const sds s) {
static inline size_t sdsminlen(const_sds s) {
return sdslen(s) + sdsHdrSize(s[-1]) + 1;
}

/* This method copies the sds `s` into `buf` which is the target character buffer. */
size_t sdscopytobuffer(unsigned char *buf, size_t buf_len, const sds s, uint8_t *hdr_size) {
size_t sdscopytobuffer(unsigned char *buf, size_t buf_len, const_sds s, uint8_t *hdr_size) {
size_t required_keylen = sdsminlen(s);
if (buf == NULL) {
return required_keylen;
Expand Down Expand Up @@ -432,7 +432,7 @@ sds sdsResize(sds s, size_t size, int would_regrow) {
* 3) The free buffer at the end if any.
* 4) The implicit null term.
*/
size_t sdsAllocSize(sds s) {
size_t sdsAllocSize(const_sds s) {
char type = s[-1] & SDS_TYPE_MASK;
/* SDS_TYPE_5 header doesn't contain the size of the allocation */
if (type == SDS_TYPE_5) {
Expand All @@ -444,7 +444,7 @@ size_t sdsAllocSize(sds s) {

/* Return the pointer of the actual SDS allocation (normally SDS strings
* are referenced by the start of the string buffer). */
void *sdsAllocPtr(sds s) {
void *sdsAllocPtr(const_sds s) {
return (void *)(s - sdsHdrSize(s[-1]));
}

Expand Down Expand Up @@ -559,7 +559,7 @@ sds sdscat(sds s, const char *t) {
*
* After the call, the modified sds string is no longer valid and all the
* references must be substituted with the new pointer returned by the call. */
sds sdscatsds(sds s, const sds t) {
sds sdscatsds(sds s, const_sds t) {
return sdscatlen(s, t, sdslen(t));
}

Expand Down Expand Up @@ -870,7 +870,7 @@ void sdstoupper(sds s) {
* If two strings share exactly the same prefix, but one of the two has
* additional characters, the longer string is considered to be greater than
* the smaller one. */
int sdscmp(const sds s1, const sds s2) {
int sdscmp(const_sds s1, const_sds s2) {
size_t l1, l2, minlen;
int cmp;

Expand Down Expand Up @@ -996,7 +996,7 @@ sds sdscatrepr(sds s, const char *p, size_t len) {
* that is compatible with sdssplitargs(). For this reason, also spaces will be
* treated as needing an escape.
*/
int sdsneedsrepr(const sds s) {
int sdsneedsrepr(const_sds s) {
size_t len = sdslen(s);
const char *p = s;

Expand Down
29 changes: 18 additions & 11 deletions src/sds.h
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,14 @@ extern const char *SDS_NOINIT;
#include <stdarg.h>
#include <stdint.h>

/* Constness:
*
* - 'const sds' means 'char * const'. It is a const-pointer to non-const content.
* - 'const_sds' means 'const char *'. It is a non-const pointer to const content.
* - 'const const_sds' means 'const char * const', const pointer and content. */

typedef char *sds;
typedef const char *const_sds;

/* Note: sdshdr5 is never used, we just access the flags byte directly.
* However is here to document the layout of type 5 SDS strings. */
Expand Down Expand Up @@ -83,7 +90,7 @@ struct __attribute__((__packed__)) sdshdr64 {
#define SDS_HDR(T, s) ((struct sdshdr##T *)((s) - (sizeof(struct sdshdr##T))))
#define SDS_TYPE_5_LEN(f) ((f) >> SDS_TYPE_BITS)

static inline size_t sdslen(const sds s) {
static inline size_t sdslen(const_sds s) {
unsigned char flags = s[-1];
switch (flags & SDS_TYPE_MASK) {
case SDS_TYPE_5: return SDS_TYPE_5_LEN(flags);
Expand All @@ -95,7 +102,7 @@ static inline size_t sdslen(const sds s) {
return 0;
}

static inline size_t sdsavail(const sds s) {
static inline size_t sdsavail(const_sds s) {
unsigned char flags = s[-1];
switch (flags & SDS_TYPE_MASK) {
case SDS_TYPE_5: {
Expand Down Expand Up @@ -151,7 +158,7 @@ static inline void sdsinclen(sds s, size_t inc) {
}

/* sdsalloc() = sdsavail() + sdslen() */
static inline size_t sdsalloc(const sds s) {
static inline size_t sdsalloc(const_sds s) {
unsigned char flags = s[-1];
switch (flags & SDS_TYPE_MASK) {
case SDS_TYPE_5: return SDS_TYPE_5_LEN(flags);
Expand Down Expand Up @@ -180,14 +187,14 @@ sds sdsnewlen(const void *init, size_t initlen);
sds sdstrynewlen(const void *init, size_t initlen);
sds sdsnew(const char *init);
sds sdsempty(void);
sds sdsdup(const sds s);
size_t sdscopytobuffer(unsigned char *buf, size_t buf_len, sds s, uint8_t *hdr_size);
sds sdsdup(const_sds s);
size_t sdscopytobuffer(unsigned char *buf, size_t buf_len, const_sds s, uint8_t *hdr_size);
void sdsfree(sds s);
void sdsfreeVoid(void *s);
sds sdsgrowzero(sds s, size_t len);
sds sdscatlen(sds s, const void *t, size_t len);
sds sdscat(sds s, const char *t);
sds sdscatsds(sds s, const sds t);
sds sdscatsds(sds s, const_sds t);
sds sdscpylen(sds s, const char *t, size_t len);
sds sdscpy(sds s, const char *t);

Expand All @@ -204,7 +211,7 @@ void sdssubstr(sds s, size_t start, size_t len);
void sdsrange(sds s, ssize_t start, ssize_t end);
void sdsupdatelen(sds s);
void sdsclear(sds s);
int sdscmp(const sds s1, const sds s2);
int sdscmp(const_sds s1, const_sds s2);
sds *sdssplitlen(const char *s, ssize_t len, const char *sep, int seplen, int *count);
void sdsfreesplitres(sds *tokens, int count);
void sdstolower(sds s);
Expand All @@ -215,14 +222,14 @@ sds *sdssplitargs(const char *line, int *argc);
sds sdsmapchars(sds s, const char *from, const char *to, size_t setlen);
sds sdsjoin(char **argv, int argc, char *sep);
sds sdsjoinsds(sds *argv, int argc, const char *sep, size_t seplen);
int sdsneedsrepr(const sds s);
int sdsneedsrepr(const_sds s);

/* Callback for sdstemplate. The function gets called by sdstemplate
* every time a variable needs to be expanded. The variable name is
* provided as variable, and the callback is expected to return a
* substitution value. Returning a NULL indicates an error.
*/
typedef sds (*sdstemplate_callback_t)(const sds variable, void *arg);
typedef sds (*sdstemplate_callback_t)(const_sds variable, void *arg);
sds sdstemplate(const char *template, sdstemplate_callback_t cb_func, void *cb_arg);

/* Low level functions exposed to the user API */
Expand All @@ -231,8 +238,8 @@ sds sdsMakeRoomForNonGreedy(sds s, size_t addlen);
void sdsIncrLen(sds s, ssize_t incr);
sds sdsRemoveFreeSpace(sds s, int would_regrow);
sds sdsResize(sds s, size_t size, int would_regrow);
size_t sdsAllocSize(sds s);
void *sdsAllocPtr(sds s);
size_t sdsAllocSize(const_sds s);
void *sdsAllocPtr(const_sds s);

/* Export the allocator used by SDS to the program using SDS.
* Sometimes the program SDS is linked to, may use a different set of
Expand Down
2 changes: 1 addition & 1 deletion src/server.c
Original file line number Diff line number Diff line change
Expand Up @@ -6698,7 +6698,7 @@ void serverOutOfMemoryHandler(size_t allocation_size) {
/* Callback for sdstemplate on proc-title-template. See valkey.conf for
* supported variables.
*/
static sds serverProcTitleGetVariable(const sds varname, void *arg) {
static sds serverProcTitleGetVariable(const_sds varname, void *arg) {
if (!strcmp(varname, "title")) {
return sdsnew(arg);
} else if (!strcmp(varname, "listen-addr")) {
Expand Down
2 changes: 1 addition & 1 deletion src/unit/test_sds.c
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
#include "../sds.h"
#include "../sdsalloc.h"

static sds sdsTestTemplateCallback(sds varname, void *arg) {
static sds sdsTestTemplateCallback(const_sds varname, void *arg) {
UNUSED(arg);
static const char *_var1 = "variable1";
static const char *_var2 = "variable2";
Expand Down

0 comments on commit cf8af09

Please sign in to comment.