diff options
| author | Eric Andersen <andersen@codepoet.org> | 2001-05-15 17:48:09 +0000 |
|---|---|---|
| committer | Eric Andersen <andersen@codepoet.org> | 2001-05-15 17:48:09 +0000 |
| commit | 55f9872616f0c42f3fb712cfb7f9d0bb52c8afcb (patch) | |
| tree | 4dc106a5142e993d2a5e9bad32f2fcd53555047c | |
| parent | c911a4389bbaa5ac85d725c8c05e452dfba8583d (diff) | |
| download | busybox-w32-55f9872616f0c42f3fb712cfb7f9d0bb52c8afcb.tar.gz busybox-w32-55f9872616f0c42f3fb712cfb7f9d0bb52c8afcb.tar.bz2 busybox-w32-55f9872616f0c42f3fb712cfb7f9d0bb52c8afcb.zip | |
This patch from Adam Heath <doogie@debian.org>, makes print_file
(used by cat, grep, sed, etc) quite a bit faster.
| -rw-r--r-- | Makefile | 2 | ||||
| -rw-r--r-- | include/libbb.h | 1 | ||||
| -rw-r--r-- | libbb/copyfd.c | 67 | ||||
| -rw-r--r-- | libbb/libbb.h | 1 | ||||
| -rw-r--r-- | libbb/print_file.c | 7 |
5 files changed, 72 insertions, 6 deletions
| @@ -249,7 +249,7 @@ process_escape_sequence.c read_package_field.c read_text_file_to_buffer.c \ | |||
| 249 | recursive_action.c safe_read.c safe_strncpy.c seek_ared_file.c syscalls.c \ | 249 | recursive_action.c safe_read.c safe_strncpy.c seek_ared_file.c syscalls.c \ |
| 250 | syslog_msg_with_name.c time_string.c trim.c untar.c unzip.c vdprintf.c \ | 250 | syslog_msg_with_name.c time_string.c trim.c untar.c unzip.c vdprintf.c \ |
| 251 | verror_msg.c vperror_msg.c wfopen.c xfuncs.c xgetcwd.c xreadlink.c\ | 251 | verror_msg.c vperror_msg.c wfopen.c xfuncs.c xgetcwd.c xreadlink.c\ |
| 252 | xregcomp.c interface.c remove_file.c last_char_is.c | 252 | xregcomp.c interface.c remove_file.c last_char_is.c copyfd.c |
| 253 | LIBBB_OBJS=$(patsubst %.c,$(LIBBB)/%.o, $(LIBBB_CSRC)) | 253 | LIBBB_OBJS=$(patsubst %.c,$(LIBBB)/%.o, $(LIBBB_CSRC)) |
| 254 | LIBBB_CFLAGS = -I$(LIBBB) | 254 | LIBBB_CFLAGS = -I$(LIBBB) |
| 255 | ifneq ($(strip $(BB_SRC_DIR)),) | 255 | ifneq ($(strip $(BB_SRC_DIR)),) |
diff --git a/include/libbb.h b/include/libbb.h index f34bee8f7..7ab06388a 100644 --- a/include/libbb.h +++ b/include/libbb.h | |||
| @@ -128,6 +128,7 @@ extern pid_t* find_pid_by_name( char* pidName); | |||
| 128 | extern char *find_real_root_device_name(const char* name); | 128 | extern char *find_real_root_device_name(const char* name); |
| 129 | extern char *get_line_from_file(FILE *file); | 129 | extern char *get_line_from_file(FILE *file); |
| 130 | extern void print_file(FILE *file); | 130 | extern void print_file(FILE *file); |
| 131 | extern size_t copyfd(int fd1, int fd2); | ||
| 131 | extern int print_file_by_name(char *filename); | 132 | extern int print_file_by_name(char *filename); |
| 132 | extern char process_escape_sequence(const char **ptr); | 133 | extern char process_escape_sequence(const char **ptr); |
| 133 | extern char *get_last_path_component(char *path); | 134 | extern char *get_last_path_component(char *path); |
diff --git a/libbb/copyfd.c b/libbb/copyfd.c new file mode 100644 index 000000000..253a8cf6e --- /dev/null +++ b/libbb/copyfd.c | |||
| @@ -0,0 +1,67 @@ | |||
| 1 | /* vi: set sw=4 ts=4: */ | ||
| 2 | /* | ||
| 3 | * Utility routines. | ||
| 4 | * | ||
| 5 | * Copyright (C) 1999-2001 Erik Andersen <andersee@debian.org> | ||
| 6 | * | ||
| 7 | * This program is free software; you can redistribute it and/or modify | ||
| 8 | * it under the terms of the GNU General Public License as published by | ||
| 9 | * the Free Software Foundation; either version 2 of the License, or | ||
| 10 | * (at your option) any later version. | ||
| 11 | * | ||
| 12 | * This program is distributed in the hope that it will be useful, | ||
| 13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 15 | * General Public License for more details. | ||
| 16 | * | ||
| 17 | * You should have received a copy of the GNU General Public License | ||
| 18 | * along with this program; if not, write to the Free Software | ||
| 19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 20 | */ | ||
| 21 | |||
| 22 | #include <unistd.h> | ||
| 23 | #include <string.h> | ||
| 24 | #include <errno.h> | ||
| 25 | #include "libbb.h" | ||
| 26 | |||
| 27 | |||
| 28 | extern size_t copyfd(int fd1, int fd2) | ||
| 29 | { | ||
| 30 | char buf[32768], *writebuf; | ||
| 31 | int status = TRUE; | ||
| 32 | size_t totalread = 0, bytesread, byteswritten; | ||
| 33 | |||
| 34 | while(status) { | ||
| 35 | bytesread = read(fd1, &buf, sizeof(buf)); | ||
| 36 | if(bytesread == -1) { | ||
| 37 | error_msg("read: %s", strerror(errno)); | ||
| 38 | status = FALSE; | ||
| 39 | break; | ||
| 40 | } | ||
| 41 | byteswritten = 0; | ||
| 42 | writebuf = buf; | ||
| 43 | while(bytesread) { | ||
| 44 | byteswritten = write( fd2, &writebuf, bytesread ); | ||
| 45 | if(byteswritten == -1) { | ||
| 46 | error_msg("write: %s", strerror(errno)); | ||
| 47 | status = FALSE; | ||
| 48 | break; | ||
| 49 | } | ||
| 50 | bytesread -= byteswritten; | ||
| 51 | writebuf += byteswritten; | ||
| 52 | } | ||
| 53 | } | ||
| 54 | if ( status == TRUE ) | ||
| 55 | return totalread; | ||
| 56 | else | ||
| 57 | return -1; | ||
| 58 | } | ||
| 59 | |||
| 60 | /* END CODE */ | ||
| 61 | /* | ||
| 62 | Local Variables: | ||
| 63 | c-file-style: "linux" | ||
| 64 | c-basic-offset: 4 | ||
| 65 | tab-width: 4 | ||
| 66 | End: | ||
| 67 | */ | ||
diff --git a/libbb/libbb.h b/libbb/libbb.h index f34bee8f7..7ab06388a 100644 --- a/libbb/libbb.h +++ b/libbb/libbb.h | |||
| @@ -128,6 +128,7 @@ extern pid_t* find_pid_by_name( char* pidName); | |||
| 128 | extern char *find_real_root_device_name(const char* name); | 128 | extern char *find_real_root_device_name(const char* name); |
| 129 | extern char *get_line_from_file(FILE *file); | 129 | extern char *get_line_from_file(FILE *file); |
| 130 | extern void print_file(FILE *file); | 130 | extern void print_file(FILE *file); |
| 131 | extern size_t copyfd(int fd1, int fd2); | ||
| 131 | extern int print_file_by_name(char *filename); | 132 | extern int print_file_by_name(char *filename); |
| 132 | extern char process_escape_sequence(const char **ptr); | 133 | extern char process_escape_sequence(const char **ptr); |
| 133 | extern char *get_last_path_component(char *path); | 134 | extern char *get_last_path_component(char *path); |
diff --git a/libbb/print_file.c b/libbb/print_file.c index b47723454..bfedc5eff 100644 --- a/libbb/print_file.c +++ b/libbb/print_file.c | |||
| @@ -26,12 +26,9 @@ | |||
| 26 | 26 | ||
| 27 | extern void print_file(FILE *file) | 27 | extern void print_file(FILE *file) |
| 28 | { | 28 | { |
| 29 | int c; | ||
| 30 | |||
| 31 | while ((c = getc(file)) != EOF) | ||
| 32 | putc(c, stdout); | ||
| 33 | fclose(file); | ||
| 34 | fflush(stdout); | 29 | fflush(stdout); |
| 30 | copyfd(fileno(file), fileno(stdout)); | ||
| 31 | fclose(file); | ||
| 35 | } | 32 | } |
| 36 | 33 | ||
| 37 | extern int print_file_by_name(char *filename) | 34 | extern int print_file_by_name(char *filename) |
