blob: 63d2ab1737389086e1616863bd22a51c0d637509 [file] [log] [blame]
Eric Andersenaad1a882001-03-16 22:47:14 +00001/* vi: set sw=4 ts=4: */
2/*
3 * Utility routines.
4 *
Eric Andersenbdfd0d72001-10-24 05:00:29 +00005 * Copyright (C) many different people. If you wrote this, please
6 * acknowledge your work.
Eric Andersenaad1a882001-03-16 22:47:14 +00007 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
Eric Andersenbdfd0d72001-10-24 05:00:29 +000013 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
Eric Andersenaad1a882001-03-16 22:47:14 +000015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
Eric Andersenbdfd0d72001-10-24 05:00:29 +000020 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
21 * USA
Eric Andersenaad1a882001-03-16 22:47:14 +000022 */
23
24#include <stdio.h>
25#include <sys/stat.h>
26#include "libbb.h"
27
Matt Kraaibf0a0102001-06-11 13:58:02 +000028/* Copy CHUNKSIZE bytes (or until EOF if CHUNKSIZE equals -1) from SRC_FILE
29 * to DST_FILE. */
Glenn L McGrathc9cac5b2001-04-12 13:47:12 +000030extern int copy_file_chunk(FILE *src_file, FILE *dst_file, unsigned long long chunksize)
Eric Andersenaad1a882001-03-16 22:47:14 +000031{
Matt Kraaibf0a0102001-06-11 13:58:02 +000032 size_t nread, nwritten, size;
33 char buffer[BUFSIZ];
Eric Andersenaad1a882001-03-16 22:47:14 +000034
Matt Kraaibf0a0102001-06-11 13:58:02 +000035 while (chunksize != 0) {
36 if (chunksize > BUFSIZ)
37 size = BUFSIZ;
38 else
39 size = chunksize;
40
41 nread = fread (buffer, 1, size, src_file);
42
43 if (nread != size && ferror (src_file)) {
44 perror_msg ("read");
45 return -1;
46 } else if (nread == 0) {
47 if (chunksize != -1) {
48 error_msg ("Unable to read all data");
49 return -1;
50 }
51
52 return 0;
53 }
54
55 nwritten = fwrite (buffer, 1, nread, dst_file);
56
57 if (nwritten != nread) {
58 if (ferror (dst_file))
59 perror_msg ("write");
60 else
61 error_msg ("Unable to write all data");
62 return -1;
63 }
64
65 if (chunksize != -1)
66 chunksize -= nwritten;
67 }
68
69 return 0;
70}