X-Git-Url: http://cvs.zerfleddert.de/cgi-bin/gitweb.cgi/micropolis/blobdiff_plain/6a5fa4e03967ab980cdc7ef96a42400bc29b4414..efad9d6d0b164bd37c84a9581dbf6397c7ffb3fa:/src/sim/g_cam.c?ds=sidebyside diff --git a/src/sim/g_cam.c b/src/sim/g_cam.c index c2f1b12..139da46 100644 --- a/src/sim/g_cam.c +++ b/src/sim/g_cam.c @@ -1083,39 +1083,45 @@ cam_load_rule(Cam *cam, char *filename) FILE *fp; QUAD magic, neighborhood, rule_size; Byte *rule; + int test = 1; if ((fp = fopen(filename, "r")) == NULL) { fprintf(stderr, "cam: Can't open rule file \"%s\"\n", filename); return; } -/* XXX: Make this byte order independent!!! */ - -#if defined(MSDOS) || defined(OSF1) || defined(IS_INTEL) #define SWAPQUAD(x) ((x = ((x <<24) & 0xff000000) | \ ((x <<8) & 0x00ff0000) | \ ((x >>8) & 0x0000ff00) | \ ((x >>24) & 0x000000ff)), 0) -#else - -#define SWAPQUAD(x) 0 - -#endif - - if ((fread(&magic, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || - SWAPQUAD(magic) || - (magic != 0xcac0cac0) || - (fread(&neighborhood, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || - SWAPQUAD(neighborhood) || - (fread(&rule_size, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || - SWAPQUAD(rule_size) || - ((rule = (Byte *)malloc(rule_size)) == NULL) || - (fread(rule, 1, rule_size, fp) != rule_size)) { - fprintf(stderr, "cam: Bad rule file \"%s\"\n", filename); - fclose(fp); - return; +/* XXX: Make this byte order independent!!! */ + if ((*(unsigned char*) (&test))) { + if ((fread(&magic, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || + SWAPQUAD(magic) || + (magic != 0xcac0cac0) || + (fread(&neighborhood, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || + SWAPQUAD(neighborhood) || + (fread(&rule_size, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || + SWAPQUAD(rule_size) || + ((rule = (Byte *)malloc(rule_size)) == NULL) || + (fread(rule, 1, rule_size, fp) != rule_size)) { + fprintf(stderr, "cam: Bad rule file \"%s\"\n", filename); + fclose(fp); + return; + } + } else { + if ((fread(&magic, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || + (magic != 0xcac0cac0) || + (fread(&neighborhood, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || + (fread(&rule_size, 1, sizeof(QUAD), fp) != sizeof(QUAD)) || + ((rule = (Byte *)malloc(rule_size)) == NULL) || + (fread(rule, 1, rule_size, fp) != rule_size)) { + fprintf(stderr, "cam: Bad rule file \"%s\"\n", filename); + fclose(fp); + return; + } } fclose(fp);