aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Andersen <andersen@codepoet.org>2001-05-15 17:48:09 +0000
committerEric Andersen <andersen@codepoet.org>2001-05-15 17:48:09 +0000
commit55f9872616f0c42f3fb712cfb7f9d0bb52c8afcb (patch)
tree4dc106a5142e993d2a5e9bad32f2fcd53555047c
parentc911a4389bbaa5ac85d725c8c05e452dfba8583d (diff)
downloadbusybox-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--Makefile2
-rw-r--r--include/libbb.h1
-rw-r--r--libbb/copyfd.c67
-rw-r--r--libbb/libbb.h1
-rw-r--r--libbb/print_file.c7
5 files changed, 72 insertions, 6 deletions
diff --git a/Makefile b/Makefile
index b35ffc72e..c52537a0c 100644
--- a/Makefile
+++ b/Makefile
@@ -249,7 +249,7 @@ process_escape_sequence.c read_package_field.c read_text_file_to_buffer.c \
249recursive_action.c safe_read.c safe_strncpy.c seek_ared_file.c syscalls.c \ 249recursive_action.c safe_read.c safe_strncpy.c seek_ared_file.c syscalls.c \
250syslog_msg_with_name.c time_string.c trim.c untar.c unzip.c vdprintf.c \ 250syslog_msg_with_name.c time_string.c trim.c untar.c unzip.c vdprintf.c \
251verror_msg.c vperror_msg.c wfopen.c xfuncs.c xgetcwd.c xreadlink.c\ 251verror_msg.c vperror_msg.c wfopen.c xfuncs.c xgetcwd.c xreadlink.c\
252xregcomp.c interface.c remove_file.c last_char_is.c 252xregcomp.c interface.c remove_file.c last_char_is.c copyfd.c
253LIBBB_OBJS=$(patsubst %.c,$(LIBBB)/%.o, $(LIBBB_CSRC)) 253LIBBB_OBJS=$(patsubst %.c,$(LIBBB)/%.o, $(LIBBB_CSRC))
254LIBBB_CFLAGS = -I$(LIBBB) 254LIBBB_CFLAGS = -I$(LIBBB)
255ifneq ($(strip $(BB_SRC_DIR)),) 255ifneq ($(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);
128extern char *find_real_root_device_name(const char* name); 128extern char *find_real_root_device_name(const char* name);
129extern char *get_line_from_file(FILE *file); 129extern char *get_line_from_file(FILE *file);
130extern void print_file(FILE *file); 130extern void print_file(FILE *file);
131extern size_t copyfd(int fd1, int fd2);
131extern int print_file_by_name(char *filename); 132extern int print_file_by_name(char *filename);
132extern char process_escape_sequence(const char **ptr); 133extern char process_escape_sequence(const char **ptr);
133extern char *get_last_path_component(char *path); 134extern 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
28extern 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/*
62Local Variables:
63c-file-style: "linux"
64c-basic-offset: 4
65tab-width: 4
66End:
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);
128extern char *find_real_root_device_name(const char* name); 128extern char *find_real_root_device_name(const char* name);
129extern char *get_line_from_file(FILE *file); 129extern char *get_line_from_file(FILE *file);
130extern void print_file(FILE *file); 130extern void print_file(FILE *file);
131extern size_t copyfd(int fd1, int fd2);
131extern int print_file_by_name(char *filename); 132extern int print_file_by_name(char *filename);
132extern char process_escape_sequence(const char **ptr); 133extern char process_escape_sequence(const char **ptr);
133extern char *get_last_path_component(char *path); 134extern 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
27extern void print_file(FILE *file) 27extern 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
37extern int print_file_by_name(char *filename) 34extern int print_file_by_name(char *filename)