sds icon indicating copy to clipboard operation
sds copied to clipboard

Unexpected behaviour

Open ghost opened this issue 2 years ago • 1 comments

Hi Salvatore,

I came across some unexpected behaviour while using the sdsMakeRoomFor() and sdsrange() functions. Please have a look below. PS: It might be my one misuse of the library, but curious to hear what you think.

$ echo "test" >> test_file.txt


#include <stdio.h>
#include "sds/sds.h"

#define BUFSIZE 4096

static void expected_behaviour(FILE* const f) {
  sds s = sdsnew("abc");
  s     = sdsMakeRoomFor(s, BUFSIZE);

  while (fgets(s, BUFSIZE, f)) {
    sdsrange(s, 0, 2);
    printf("%s", s); // prints: tes
  }
  printf("\n");
  sdsfree(s);
}

static void unexpected_behaviour(FILE* const f) {
  // Can sdsempty() be used here?
  sds s = sdsMakeRoomFor(sdsempty(), BUFSIZE);

  while (fgets(s, BUFSIZE, f)) {
    // Why isn't sdsrange() working as expected?
    sdsrange(s, 0, 2);
    printf("%s", s); // prints: test\n
  }
  printf("\n");
  sdsfree(s);
}
int main(void) {
  FILE* const f = fopen("test_file.txt", "r");  // assume valid file
  expected_behaviour(f);
  fseek(f, 0, SEEK_SET);
  unexpected_behaviour(f);
  fclose(f)
  return 0;
}

ghost avatar Oct 18 '22 17:10 ghost

After changing a sds string with none-sds-aware functions you should use sdsupatelen(s) to set the correct sdslen (calculated from strlen). Even better is not to use such functions on sds strings.

Your expected behavior function works only, because your init string has the same length as the final output string - the sdslen value is always 3, while the length reported by strlen is changing from 3 to 5 to 3.

Your unexpected behavior function starts and ends with a sdslen of 0 and thats why sdsrange does not strip anything.

You can observe this by adding strlen and sdslen output before and after string modifications.

jcorporation avatar Nov 15 '22 18:11 jcorporation