home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Fresh Fish 9
/
FreshFishVol9-CD2.bin
/
bbs
/
disk
/
mkisofs-1.00.7.lha
/
mkisofs
/
mkisofs.c
< prev
next >
Wrap
C/C++ Source or Header
|
1994-12-18
|
12KB
|
533 lines
/*
* Program mkisofs.c - generate iso9660 filesystem based upon directory
* tree on hard disk.
Written by Eric Youngdale (1993).
Copyright 1993 Yggdrasil Computing, Incorporated
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
#include "mkisofs.h"
#ifdef linux
#include <getopt.h>
#endif
#include "iso9660.h"
#include <ctype.h>
#include <time.h>
#include <stdlib.h>
#ifndef AMIGA
#include <sys/stat.h>
#endif
#ifndef VMS
#ifndef AMIGA
#include <unistd.h>
#endif
#endif
#ifdef AMIGA
#ifdef LATTICE
#include <proto/exec.h>
#include <proto/utility.h>
#endif
#if defined(__GNUC__) || defined(AZTEC_C)
#include <clib/exec_protos.h>
#include <clib/utility_protos.h>
#endif
#endif
struct Library *UtilityBase = NULL;
#include "exclude.h"
#include "trans.h"
struct directory * root = NULL;
static char version_string[] = "$VER: mkisofs-1.00-Amiga 1.7 (18.12.94)";
FILE * discimage;
unsigned int next_extent = 0;
unsigned int last_extent = 0;
unsigned int path_table_size = 0;
unsigned int path_table[4] = {0,};
unsigned int path_blocks = 0;
struct iso_directory_record root_record;
int use_RockRidge = 0;
int verbose = 0;
int all_files = 0;
int follow_links = 0;
int generate_tables = 0;
static int timezone_offset;
char * extension_record = NULL;
int extension_record_extent = 0;
static int extension_record_size = 0;
int cdtv_trademark_file = 0;
int convert_filenames = 1;
int inhibit_relocation = 0;
int sort_extents = 0;
int progress_indicator = 1;
int short_filenames = 1;
int map_filenames = 1;
int preallocate = 0;
char * preparer = NULL;
char * publisher = NULL;
char * system_identifier = NULL;
char * path_table_l = NULL;
char * path_table_m = NULL;
int goof = 0;
void usage(void){
fprintf(stderr,
"Usage:\n"
"mkisofs [-RvaTcres12AB] [-o outfile] [-V volid] [-p preparer]\n"
" [-P publisher] [-S systemid] [-D path -D path ...]\n"
" [-x path -x path ...] [--cdtv] path\n"
);
exit(1);
}
int get_iso9660_timezone_offset(void){
#ifdef AMIGA
return 0;
#else
struct tm gm;
struct tm * pt;
time_t ctime;
int local_min, gmt_min;
time(&ctime);
pt = gmtime(&ctime);
gm = *pt;
pt = localtime(&ctime);
if(gm.tm_year < pt->tm_year)
gm.tm_yday = -1;
if(gm.tm_year > pt->tm_year)
pt->tm_yday = -1;
gmt_min = gm.tm_min + 60*(gm.tm_hour + 24*gm.tm_yday);
local_min = pt->tm_min + 60*(pt->tm_hour + 24*pt->tm_yday);
return (gmt_min - local_min)/15;
#endif
}
/* Fill in date in the iso9660 format */
int FDECL2(iso9660_date,char *, result, time_t, ctime){
struct tm *local;
#ifdef AMIGA
local = gmtime(&ctime);
#else
local = localtime(&ctime);
#endif
result[0] = local->tm_year;
result[1] = local->tm_mon + 1;
result[2] = local->tm_mday;
result[3] = local->tm_hour;
result[4] = local->tm_min;
result[5] = local->tm_sec;
result[6] = timezone_offset;
return 0;
}
int FDECL4(iso9660_file_length,const char*, name, struct directory_entry *, sresult,
int, dirflag, struct transtbl*, tbl){
char buf[33];
char *result = buf;
const char * pnt;
const char *cp;
#if 0
int seen_dot = 0;
int priority = 32767;
int tildes = 0;
int ignore = 0;
int extra = 0;
int chars_after_dot = 0;
int chars_before_dot = 0;
#endif
if(strcmp(name,".") == 0){
sresult->isorec.iso_name = "";
return 1;
};
if(strcmp(name,"..") == 0){
sresult->isorec.iso_name = "\1";
return 1;
};
if (!convert_filenames) {
int i;
for (pnt=name, i=0; *pnt && i < 30; i++)
*result++ = *pnt++;
if (!dirflag) {
*result++ = ';';
*result++ = '1';
}
*result++ = 0;
sresult->isorec.iso_name = strdup_forever (buf);
return i+(dirflag?0:2);
}
if (generate_tables && tbl && (cp = translate (tbl, name))) {
static char tmp[40];
strcpy (tmp, cp);
if (!dirflag)
strcat (tmp, ";1");
sresult->isorec.iso_name = strdup_forever (tmp);
} else
sresult->isorec.iso_name =
strdup_forever (dirflag ? convert_dirname (name) :
convert_filename (name));
sresult->priority = 32767;
return (int) strlen (sresult->isorec.iso_name);
#if 0
pnt = name;
while(*pnt){
if(*pnt == '#') {priority = 1; pnt++; continue; };
if(*pnt == '~') {priority = 1; tildes++; pnt++; continue;};
if(ignore) {pnt++; continue;};
if(*pnt == '.') {
if (seen_dot) {ignore++; continue;}
*result++ = '.';
seen_dot++;
} else if (seen_dot) {
if(chars_after_dot < 3) {
chars_after_dot++;
*result++ = toupper(*pnt);
}
} else {
if(chars_before_dot < 8) {
chars_before_dot++;
*result++ = toupper(*pnt);
};
};
pnt++;
};
if(tildes == 2){
int prio1 = 0;
pnt = name;
while (*pnt && *pnt != '~') pnt++;
if (*pnt) pnt++;
while(*pnt && *pnt != '~'){
prio1 = 10*prio1 + *pnt - '0';
pnt++;
};
priority = prio1;
};
if (!dirflag){
if (!seen_dot) {
*result++ = '.';
extra++;
};
*result++ = ';';
*result++ = '1';
extra += 2;
};
*result++ = 0;
sresult->priority = priority;
sresult->isorec.iso_name = strdup_forever (buf);
return chars_before_dot + chars_after_dot + seen_dot + extra;
#endif
}
#ifdef AMIGA
static void Cleanup (void)
{
if (UtilityBase)
CloseLibrary (UtilityBase);
}
#endif
int FDECL2(main, int, argc, char **, argv){
char * outfile, *volid;
struct directory_entry de;
#ifndef AMIGA
unsigned int mem_start;
struct stat statbuf;
#endif
char * scan_tree;
int c;
char * trademark_filename;
if (argc < 2)
usage();
#ifdef AMIGA
UtilityBase = OpenLibrary ((UBYTE*) "utility.library", 0);
if (!UtilityBase) {
fprintf (stderr, "cannot open utility.library!\n");
exit (10);
}
atexit (Cleanup);
#endif
outfile = NULL;
volid = "CDROM";
while ((c = getopt(argc, argv, "acefo:p:rsvx:ABCD:P:RS:TV:-:12")) != EOF)
switch (c)
{
case '-':
if (strcmp (optarg, "cdtv") == 0) {
convert_filenames = 0;
cdtv_trademark_file = 1;
inhibit_relocation = 1;
system_identifier = "CDTV";
all_files++;
} else {
fprintf (stderr, "unknown option --%s\n", optarg);
exit (1);
}
break;
case 'c':
convert_filenames = 0;
break;
case 'C':
cdtv_trademark_file = 1;
break;
case 'D':
convert_filenames = 0;
include_conv (optarg);
break;
case 'r':
inhibit_relocation = 1;
break;
case 'e':
sort_extents = 1;
break;
case 's':
preallocate = 1;
break;
case 'p':
preparer = optarg;
if(strlen(preparer) > 128) {
fprintf(stderr,"Preparer string too long\n");
exit(1);
};
break;
case 'P':
publisher = optarg;
if(strlen(publisher) > 128) {
fprintf(stderr,"Publisher string too long\n");
exit(1);
};
break;
case 'S':
system_identifier = optarg;
if(strlen(system_identifier) > 32) {
fprintf(stderr,"System identifier string too long\n");
exit (1);
}
break;
case 'o':
outfile = optarg;
break;
case 'f':
follow_links++;
break;
case 'R':
use_RockRidge++;
break;
case 'V':
#ifdef AMIGA
if (strlen (optarg) > 30) {
fprintf (stderr, "volume name too long (max. 30 characters)\n");
exit (1);
}
#endif
volid = optarg;
break;
case 'v':
verbose++;
progress_indicator=0;
break;
case 'a':
all_files++;
break;
case 'T':
generate_tables++;
break;
case 'x':
exclude(optarg);
b