Adjusted to make lsmod and sh compilable as standalone apps.
Comment fixes
#include "internal.h"
#include <stdio.h>
-static void print_file(FILE * file)
-{
- int c;
-
- while ((c = getc(file)) != EOF)
- putc(c, stdout);
- fclose(file);
- fflush(stdout);
-}
-
extern int cat_main(int argc, char **argv)
{
- FILE *file;
-
if (argc == 1) {
print_file(stdin);
exit(TRUE);
usage(cat_usage);
while (--argc > 0) {
- file = fopen(*++argv, "r");
- if (file == NULL) {
+ if (print_file_by_name(*++argv) == FALSE) {
perror(*argv);
exit(FALSE);
}
- print_file(file);
}
return(TRUE);
}
#include "internal.h"
#include <stdio.h>
-static void print_file(FILE * file)
-{
- int c;
-
- while ((c = getc(file)) != EOF)
- putc(c, stdout);
- fclose(file);
- fflush(stdout);
-}
-
extern int cat_main(int argc, char **argv)
{
- FILE *file;
-
if (argc == 1) {
print_file(stdin);
exit(TRUE);
usage(cat_usage);
while (--argc > 0) {
- file = fopen(*++argv, "r");
- if (file == NULL) {
+ if (print_file_by_name(*++argv) == FALSE) {
perror(*argv);
exit(FALSE);
}
- print_file(file);
}
return(TRUE);
}
extern pid_t* findPidByName( char* pidName);
extern int find_real_root_device_name(char* name);
extern char *get_line_from_file(FILE *file);
+extern void print_file(FILE *file);
+extern int print_file_by_name(char *filename);
extern char process_escape_sequence(char **ptr);
extern char *get_last_path_component(char *path);
extern void xregcomp(regex_t *preg, const char *regex, int cflags);
extern int lsmod_main(int argc, char **argv)
{
#if defined BB_FEATURE_USE_DEVPS_PATCH
- char *cmd[] = { "cat", "/dev/modules", "\0" };
+ char *filename = "/dev/modules";
#else
#if ! defined BB_FEATURE_USE_PROCFS
#error Sorry, I depend on the /proc filesystem right now.
#endif
- char *cmd[] = { "cat", "/proc/modules", "\0" };
+ char *filename = "/proc/modules";
#endif
- return(cat_main(3, cmd));
+ return(print_file_by_name(filename));
}
extern int lsmod_main(int argc, char **argv)
{
#if defined BB_FEATURE_USE_DEVPS_PATCH
- char *cmd[] = { "cat", "/dev/modules", "\0" };
+ char *filename = "/dev/modules";
#else
#if ! defined BB_FEATURE_USE_PROCFS
#error Sorry, I depend on the /proc filesystem right now.
#endif
- char *cmd[] = { "cat", "/proc/modules", "\0" };
+ char *filename = "/proc/modules";
#endif
- return(cat_main(3, cmd));
+ return(print_file_by_name(filename));
}
return buf;
}
-#endif /* BB_TAR */
+#endif /* BB_TAR || BB_AR */
#if defined BB_TAR || defined BB_CP_MV || defined BB_AR
/*
return total;
}
-#endif /* BB_TAR || BB_CP_MV */
+#endif /* BB_TAR || BB_CP_MV || BB_AR */
-#if defined BB_TAR || defined BB_TAIL || defined BB_AR
+#if defined BB_TAR || defined BB_TAIL || defined BB_AR || defined BB_SH
/*
* Read all of the supplied buffer from a file.
* This does multiple reads as necessary.
return total;
}
-#endif /* BB_TAR || BB_TAIL */
+#endif /* BB_TAR || BB_TAIL || BB_AR || BB_SH */
#if defined (BB_CHMOD_CHOWN_CHGRP) \
return linebuf;
}
+#if defined BB_CAT || defined BB_LSMOD
+extern void print_file(FILE *file)
+{
+ int c;
+
+ while ((c = getc(file)) != EOF)
+ putc(c, stdout);
+ fclose(file);
+ fflush(stdout);
+}
+
+extern int print_file_by_name(char *filename)
+{
+ FILE *file;
+ file = fopen(filename, "r");
+ if (file == NULL) {
+ return FALSE;
+ }
+ print_file(file);
+ return TRUE;
+}
+#endif /* BB_CAT || BB_LSMOD */
+
#if defined BB_ECHO || defined BB_TR
char process_escape_sequence(char **ptr)
{