forked from Bananymous/banan-os
				
			cat: Use write() instead of puts to print file contents
This allows printing files that contain null bytes behave more like you would expect
This commit is contained in:
		
							parent
							
								
									57605c2b3e
								
							
						
					
					
						commit
						bc4d272c4f
					
				|  | @ -1,18 +1,18 @@ | |||
| #include <fcntl.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| bool cat_file(FILE* fp) | ||||
| bool cat_file(int fd) | ||||
| { | ||||
| 	char buffer[1025]; | ||||
| 	char buffer[1024]; | ||||
| 	size_t n_read; | ||||
| 	while ((n_read = fread(buffer, 1, sizeof(buffer) - 1, fp)) > 0) | ||||
| 	while (ssize_t n_read = read(fd, buffer, sizeof(buffer))) | ||||
| 	{ | ||||
| 		buffer[n_read] = '\0'; | ||||
| 		fputs(buffer, stdout); | ||||
| 	} | ||||
| 	if (ferror(fp)) | ||||
| 	{ | ||||
| 		perror("fread"); | ||||
| 		return false; | ||||
| 		if (n_read == -1) | ||||
| 		{ | ||||
| 			perror("read"); | ||||
| 			return false; | ||||
| 		} | ||||
| 		write(STDOUT_FILENO, buffer, n_read); | ||||
| 	} | ||||
| 	return true; | ||||
| } | ||||
|  | @ -25,21 +25,21 @@ int main(int argc, char** argv) | |||
| 	{ | ||||
| 		for (int i = 1; i < argc; i++) | ||||
| 		{ | ||||
| 			FILE* fp = fopen(argv[i], "r"); | ||||
| 			if (fp == nullptr) | ||||
| 			int fd = open(argv[i], O_RDONLY); | ||||
| 			if (fd == -1) | ||||
| 			{ | ||||
| 				perror(argv[i]); | ||||
| 				ret = 1; | ||||
| 				continue; | ||||
| 			} | ||||
| 			if (!cat_file(fp)) | ||||
| 			if (!cat_file(fd)) | ||||
| 				ret = 1; | ||||
| 			fclose(fp); | ||||
| 			close(fd); | ||||
| 		} | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		if (!cat_file(stdin)) | ||||
| 		if (!cat_file(STDIN_FILENO)) | ||||
| 			ret = 1; | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue