X-Git-Url: https://deadsoftware.ru/gitweb?p=flatwaifu.git;a=blobdiff_plain;f=src%2Ffiles.c;h=eb6d36e943bbbda1b55d1082d79d7b04c473aade;hp=220d72cd254e4e9957ef83d5ff325aad2c4b4a83;hb=e5c2eddc151a59db4e611a77901732d7c15fde90;hpb=8fb3d3f767b8e5d094e8bcbee350f4d16ab17c5a diff --git a/src/files.c b/src/files.c index 220d72c..eb6d36e 100644 --- a/src/files.c +++ b/src/files.c @@ -180,67 +180,120 @@ int myfilelength(FILE *h) extern void mysplitpath(const char* path, char* drv, char* dir, char* name, char* ext); +static int myread_int32 (FILE *f) { + int x; + myfread(&x, 4, 1, f); + return int2host(x); +} + // build wad directory -void F_initwads(void) { - int i,j,k,p; +void F_initwads (void) { + int i, j, k, p; FILE *h; char s[4]; - int n,o; + int n, o; wad_t w; logo("F_initwads: подключение WAD-файлов\n"); - for(i=0;i=MAX_WAD) ERR_failinit("Слишком много элементов WAD'а"); - memcpy(wad[p].n,w.n,8); - wad[p].o=w.o;wad[p].l=w.l;wad[p].f=0; - ++p; + for (i = 0; i < MAX_WAD; ++i) { + wad[i].n[0] = 0; + } + + logo(" подключается %s\n", wads[0]); + if ((wadh[0] = h = fopen(wads[0], "rb")) == NULL) { + ERR_failinit("Не могу открыть файл: %s", wads[0]); + } + + s[0] = '\0'; + myfread(s, 1, 4, h); + if (strncmp(s, "IWAD", 4) != 0 && strncmp(s, "PWAD", 4) != 0) { + ERR_failinit("Нет подписи IWAD или PWAD (1)"); } + + p = 0; // wad number + n = myread_int32(h); // num + o = myread_int32(h); // offset + fseek(h, o, SEEK_SET); + for (j = 0; j < n; ++j) { + w.o = myread_int32(h); // offset + w.l = myread_int32(h); // len + myfread(w.n, 1, 8, h); // name + if (p >= MAX_WAD) { + ERR_failinit("Слишком много элементов WAD'а"); + } + wad[p].o = w.o; + wad[p].l = w.l; + memcpy(wad[p].n, w.n, 8); + wad[p].f = 0; + ++p; + } + //fclose(h); - for(i=1;i=MAX_WAD) { - if(p>=MAX_WAD) ERR_failinit("Слишком много элементов WAD'а"); - memset(wad[p].n,0,8); - strncpy(wad[p].n,f_name,8); - wad[p].o=0L;wad[p].l=myfilelength(h);wad[p].f=i; - ++p; - } - continue; - } - *s=0;myfread(s,1,4,h); - if(strncmp(s,"IWAD",4)!=0 && strncmp(s,"PWAD",4)!=0) - ERR_failinit("Нет подписи IWAD или PWAD"); - myfread(&n,1,4,h);myfread(&o,1,4,h);fseek(h,o,SEEK_SET); - for(j=0;j=MAX_WAD) { - if(p>=MAX_WAD) ERR_failinit("Слишком много элементов WAD'а"); - memcpy(wad[p].n,w.n,8); - wad[p].o=w.o;wad[p].l=w.l;wad[p].f=i; - ++p; + + for (i = 1; i < MAX_WADS; ++i) { + if (wads[i][0] != 0) { + logo(" подключается %s\n", wads[i]); + if ((wadh[i] = h = fopen(wads[i], "rb")) == NULL) { + ERR_failinit("Не могу открыть файл2: %s", wads[i]); + } + mysplitpath(wads[i], f_drive, f_dir, f_name, f_ext); + if (strcasecmp(f_ext, ".lmp") == 0) { + for (k = 0; k < MAX_WAD; ++k) { + if (strncasecmp(wad[k].n, f_name, 8) == 0) { + wad[k].o = 0; + wad[k].l = myfilelength(h); + wad[k].f = i; + break; + } + if (k >= MAX_WAD) { + if (p >= MAX_WAD) { + ERR_failinit("Слишком много элементов WAD'а"); + } + memset(wad[p].n, 0, 8); + strncpy(wad[p].n, f_name, 8); + wad[p].o = 0; + wad[p].l = myfilelength(h); + wad[p].f = i; + ++p; + } + } + + s[0] = '\0'; + myfread(s, 1, 4, h); + if (strncmp(s, "IWAD", 4) != 0 && strncmp(s, "PWAD", 4) != 0) { + ERR_failinit("Нет подписи IWAD или PWAD (2)"); + } + n = myread_int32(h); // num + o = myread_int32(h); // offset + fseek(h, o, SEEK_SET); + for (j = 0; j < n; ++j) { + w.o = myread_int32(h); // offset + w.l = myread_int32(h); // len + myfread(w.n, 1, 8, h); // name + for (k = 0; k < MAX_WAD; ++k) { + if (strncasecmp(wad[k].n, w.n, 8) == 0) { + wad[k].o = w.o; + wad[k].l = w.l; + wad[k].f = i; + break; + } + if (k >= MAX_WAD) { + if (p >= MAX_WAD) { + ERR_failinit("Слишком много элементов WAD'а"); + } + memcpy(wad[p].n, w.n, 8); + wad[p].o = w.o; + wad[p].l = w.l; + wad[p].f = i; + ++p; + } + } + } } } - } - wad_num=p; - + } + + wad_num = p; } // allocate resources @@ -356,31 +409,37 @@ void F_randmus(char *s) { } // reads bytes from file until CR -void F_readstr(FILE* h,char *s,int m) { - int i; - static char c; - - for(i=0;;) { - c=13; - myfreadc(&c,1,1,h); - if(c==13) break; - if(i