From 935eccb23be9464091ea0f6be3873c6450ff040c Mon Sep 17 00:00:00 2001 From: dzwdz Date: Sun, 1 May 2022 18:35:18 +0200 Subject: init/cat: read files until EOF --- initrd/long.txt | 7 +++++++ src/init/shell.c | 19 +++++++++++++------ 2 files changed, 20 insertions(+), 6 deletions(-) create mode 100644 initrd/long.txt diff --git a/initrd/long.txt b/initrd/long.txt new file mode 100644 index 0000000..ed0b66a --- /dev/null +++ b/initrd/long.txt @@ -0,0 +1,7 @@ +this file is longer than 512 characters. each line is exactly 80 characters long +01234567890123456789012345678901234567890123456789012345678901234567890123456789 +0 10 20 30 40 50 60 70 80 +for this file to be over 512 bytes, it needs 512/81 = 7 lines. that's a fun fact + ,_____O> [duck sound] | that's as good of a duck as i can make. it's very good +~|____| | /-- this X is the 513th byte in this file. very coolio + | | ,. . ., , ., | X. here it is. what you've waited for. idk what to say diff --git a/src/init/shell.c b/src/init/shell.c index 6314721..7714c38 100644 --- a/src/init/shell.c +++ b/src/init/shell.c @@ -48,6 +48,7 @@ static void cmd_cat_ls(const char *args, bool ls) { int fd; static char buf[512]; int len; // first used for strlen(args), then length of buffer + size_t pos = 0; if (!args) args = "/"; len = strlen(args); @@ -69,17 +70,23 @@ static void cmd_cat_ls(const char *args, bool ls) { return; } - len = _syscall_read(fd, buf, sizeof buf, 0); - if (ls) - for (int i = 0; i < len; i++) - if (buf[i] == '\0') buf[i] = '\n'; + while (true) { + len = _syscall_read(fd, buf, sizeof buf, pos); + if (len <= 0) break; + pos += len; + + if (ls) { + for (int i = 0; i < len; i++) + if (buf[i] == '\0') buf[i] = '\n'; + } + _syscall_write(__stdout, buf, len, 0); + } - _syscall_write(__stdout, buf, len, 0); _syscall_close(fd); } static void cmd_hexdump(const char *args) { - static uint8_t buf[513]; + static uint8_t buf[512]; int fd, len; fd = _syscall_open(args, strlen(args)); -- cgit v1.2.3