Commit 4544e968 authored by dimhotepus's avatar dimhotepus

Cache strlen outside of cycles (PVS-Studio)

parent de6149ef
...@@ -768,17 +768,18 @@ static void TestOneTruncate(const char *path, int64 limit, int64 keep, ...@@ -768,17 +768,18 @@ static void TestOneTruncate(const char *path, int64 limit, int64 keep,
CHECK_ERR(fd = open(path, O_RDWR | O_CREAT | O_TRUNC, 0600)); CHECK_ERR(fd = open(path, O_RDWR | O_CREAT | O_TRUNC, 0600));
const char *discardstr = "DISCARDME!", *keepstr = "KEEPME!"; const char *discardstr = "DISCARDME!", *keepstr = "KEEPME!";
const size_t discard_size = strlen(discardstr), keep_size = strlen(keepstr);
// Fill the file with the requested data; first discard data, then kept data // Fill the file with the requested data; first discard data, then kept data
int64 written = 0; int64 written = 0;
while (written < dsize) { while (written < dsize) {
int bytes = min<int64>(dsize - written, strlen(discardstr)); int bytes = min<int64>(dsize - written, discard_size);
CHECK_ERR(write(fd, discardstr, bytes)); CHECK_ERR(write(fd, discardstr, bytes));
written += bytes; written += bytes;
} }
written = 0; written = 0;
while (written < ksize) { while (written < ksize) {
int bytes = min<int64>(ksize - written, strlen(keepstr)); int bytes = min<int64>(ksize - written, keep_size);
CHECK_ERR(write(fd, keepstr, bytes)); CHECK_ERR(write(fd, keepstr, bytes));
written += bytes; written += bytes;
} }
...@@ -800,7 +801,7 @@ static void TestOneTruncate(const char *path, int64 limit, int64 keep, ...@@ -800,7 +801,7 @@ static void TestOneTruncate(const char *path, int64 limit, int64 keep,
const char *p = buf; const char *p = buf;
int64 checked = 0; int64 checked = 0;
while (checked < expect) { while (checked < expect) {
int bytes = min<int64>(expect - checked, strlen(keepstr)); int bytes = min<int64>(expect - checked, keep_size);
CHECK(!memcmp(p, keepstr, bytes)); CHECK(!memcmp(p, keepstr, bytes));
checked += bytes; checked += bytes;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment