mkar.c 2.3 KB

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