aboutsummaryrefslogtreecommitdiffstats
path: root/src/mds-kbdc
diff options
context:
space:
mode:
authorMattias Andrée <maandree@operamail.com>2014-09-28 00:49:15 +0200
committerMattias Andrée <maandree@operamail.com>2014-09-28 00:49:15 +0200
commit4c69a8a7b59e2607b5e198cd076739fbf45af0a5 (patch)
tree93afaca0b7b8bdea19c1f33f76be22338e88f32f /src/mds-kbdc
parentmds-kbdc: we cannot remove unneeded whitespace, but comments can still be removed, we want to be able to print out the code (diff)
downloadmds-4c69a8a7b59e2607b5e198cd076739fbf45af0a5.tar.gz
mds-4c69a8a7b59e2607b5e198cd076739fbf45af0a5.tar.bz2
mds-4c69a8a7b59e2607b5e198cd076739fbf45af0a5.tar.xz
m + make sure the code ends with a new line
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to '')
-rw-r--r--src/mds-kbdc.c17
1 files changed, 12 insertions, 5 deletions
diff --git a/src/mds-kbdc.c b/src/mds-kbdc.c
index 3dcb542..eae5348 100644
--- a/src/mds-kbdc.c
+++ b/src/mds-kbdc.c
@@ -69,9 +69,7 @@ static char* read_file(const char* restrict pathname, size_t* restrict size)
/* Make sure the buffer is not small. */
if (buf_size - buf_ptr < 2048)
{
- old = content;
- fail_if (xrealloc(content, buf_size <<= 1, char));
- old = NULL;
+ fail_if (xxrealloc(old, content, buf_size <<= 1, char));
}
/* Read a chunk of the file. */
got = read(fd, content + buf_ptr, (buf_size - buf_ptr) * sizeof(char));
@@ -82,7 +80,7 @@ static char* read_file(const char* restrict pathname, size_t* restrict size)
}
/* Shrink the buffer so it is not excessively large. */
- fail_if (xrealloc(content, buf_ptr, char));
+ fail_if (xxrealloc(old, content, buf_ptr, char));
/* Close file decriptor for the file. */
close(fd);
@@ -154,6 +152,7 @@ int main(int argc_, char** argv_)
const char* pathname = argv_[1];
char* restrict content = NULL;
char* restrict real_content = NULL;
+ char* restrict old = NULL;
size_t content_size;
size_t real_content_size;
@@ -164,17 +163,25 @@ int main(int argc_, char** argv_)
content = read_file(pathname, &content_size);
fail_if (content == NULL);
+ /* Make sure the content ends with a new line. */
+ if (!content_size || (content[content_size - 1] != '\n'))
+ {
+ fail_if (xxrealloc(old, content, content_size + 1, char));
+ content[content_size++] = '\n';
+ }
+
/* Simplify file. */
fail_if (xmalloc(real_content, content_size, char));
memcpy(real_content, content, content_size * sizeof(char));
real_content_size = content_size;
content_size = remove_comments(content, content_size);
- fail_if (xrealloc(content, content_size, char));
+ fail_if (xxrealloc(old, content, content_size, char));
return 0;
pfail:
xperror(*argv);
+ free(old);
free(content);
free(real_content);
return 1;