1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#ifdef __STDC__
#include <stdlib.h>
#include <unistd.h>
#else
#include <malloc.h>
#endif
#include "ar.h"
static struct ar_hdr arbuf;
#ifdef __STDC__
void
ld86r(int argc, char ** argv)
#else
ld86r(argc, argv)
int argc; char ** argv;
#endif
{
char buf[128];
FILE * fd, * ifd;
struct stat st;
int ar, libarg=0, need_o = 0, got_o = 0;
for(ar=1; ar<argc; ar++) if( argv[ar][0] == '-' )
{
if( argv[ar][1] == 'r' ) need_o = 1;
if( argv[ar][1] == 'o' ) { got_o++; libarg = 0; }
}
else
{
if( libarg == 0 ) libarg = ar;
}
if( libarg == 0 || got_o > 1 || need_o > got_o )
fatalerror("-o option required for -r");
if( (fd =fopen(argv[libarg], "wb")) == 0 ) fatalerror("Cannot open archive");
if( fwrite(ARMAG, 1, SARMAG, fd) != SARMAG) fatalerror("Cannot write magic");
for(ar=1; ar<argc; ar++) if( ar != libarg && argv[ar][0] != '-' )
{
char * ptr;
if( stat(argv[ar], &st) < 0 ) fatalerror("Cannot stat object");
if((ptr=strchr(argv[ar], '/'))) ptr++; else ptr=argv[ar];
memset(&arbuf, ' ', sizeof(arbuf));
strcpy(buf, ptr); strcat(buf, "/ ");
strncpy(arbuf.ar_name, buf, sizeof(arbuf.ar_name));
sprintf(arbuf.ar_date, "%-12ld", (long)st.st_mtime);
sprintf(arbuf.ar_uid, "%-6d", (int)(st.st_uid%1000000L));
sprintf(arbuf.ar_gid, "%-6d", (int)(st.st_gid%1000000L));
sprintf(arbuf.ar_mode, "%-8lo", (long)st.st_mode);
sprintf(arbuf.ar_size, "%-10ld", (long)st.st_size);
memcpy(arbuf.ar_fmag, ARFMAG, sizeof(arbuf.ar_fmag));
if( fwrite(&arbuf, 1, sizeof(arbuf), fd) != sizeof(arbuf) )
fatalerror("Cannot write header");
ptr = malloc(st.st_size+2);
if( ptr == 0 ) fatalerror("Out of memory");
ptr[st.st_size] = ' ';
if( (ifd = fopen(argv[ar], "rb")) == 0 ) fatalerror("Cannot open input");
if( fread(ptr, 1, st.st_size, ifd) != st.st_size )
fatalerror("Cannot read input file");
fclose(ifd);
if( st.st_size&1 ) st.st_size++;
if( fwrite(ptr, 1, st.st_size, fd) != st.st_size )
fatalerror("Cannot write output file");
}
fclose(fd);
exit(0);
}
|