Changeset 6113 for trunk/tools/wrc/wrc.c


Ignore:
Timestamp:
Jun 26, 2001, 2:14:07 AM (24 years ago)
Author:
bird
Message:

Don't include unistd.h for VAC (inlcudes TCPIP stuff). Bad length assumption.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/tools/wrc/wrc.c

    r5523 r6113  
    44 * Copyrignt 1998 Bertho A. Stultiens (BS)
    55 *
    6  * 30-Apr-2000 BS       - Integrated a new preprocessor (-E and -N)
    7  * 20-Jun-1998 BS       - Added -L option to prevent case conversion
    8  *                        of embedded filenames.
    9  *
    10  * 08-Jun-1998 BS       - Added -A option to generate autoregister code
    11  *                        for winelib operation.
    12  *
    13  * 21-May-1998 BS       - Removed the CPP option. Its internal now.
    14  *                      - Added implementations for defines and includes
    15  *                        on the commandline.
    16  *
    17  * 30-Apr-1998 BS       - The options now contain nearly the entire alphabet.
    18  *                        Seems to be a sign for too much freedom. I implemeted
    19  *                        most of them as a user choice possibility for things
    20  *                        that I do not know what to put there by default.
    21  *                      - -l and -L options are now known as -t and -T.
    22  *
    23  * 23-Apr-1998 BS       - Finally gave up on backward compatibility on the
    24  *                        commandline (after a blessing from the newsgroup).
    25  *                        So, I changed the lot.
    26  *
    27  * 17-Apr-1998 BS       - Added many new command-line options but took care
    28  *                        that it would not break old scripts (sigh).
    29  *
    30  * 16-Apr-1998 BS       - There is not much left of the original source...
    31  *                        I had to rewrite most of it because the parser
    32  *                        changed completely with all the types etc..
     6 * 30-Apr-2000 BS   - Integrated a new preprocessor (-E and -N)
     7 * 20-Jun-1998 BS   - Added -L option to prevent case conversion
     8 *            of embedded filenames.
     9 *
     10 * 08-Jun-1998 BS   - Added -A option to generate autoregister code
     11 *            for winelib operation.
     12 *
     13 * 21-May-1998 BS   - Removed the CPP option. Its internal now.
     14 *          - Added implementations for defines and includes
     15 *            on the commandline.
     16 *
     17 * 30-Apr-1998 BS   - The options now contain nearly the entire alphabet.
     18 *            Seems to be a sign for too much freedom. I implemeted
     19 *            most of them as a user choice possibility for things
     20 *            that I do not know what to put there by default.
     21 *          - -l and -L options are now known as -t and -T.
     22 *
     23 * 23-Apr-1998 BS   - Finally gave up on backward compatibility on the
     24 *            commandline (after a blessing from the newsgroup).
     25 *            So, I changed the lot.
     26 *
     27 * 17-Apr-1998 BS   - Added many new command-line options but took care
     28 *            that it would not break old scripts (sigh).
     29 *
     30 * 16-Apr-1998 BS   - There is not much left of the original source...
     31 *            I had to rewrite most of it because the parser
     32 *            changed completely with all the types etc..
    3333 *
    3434 */
     
    3838#include <stdio.h>
    3939#include <stdlib.h>
     40#ifndef __IBMC__
    4041#include <unistd.h>
     42#endif
    4143#include <string.h>
    4244#include <assert.h>
     
    5557
    5658static char usage[] =
    57         "Usage: wrc [options...] [infile[.rc|.res]]\n"
    58         "   -a n        Alignment of resource (win16 only, default is 4)\n"
    59         "   -A          Auto register resources (only with gcc 2.7 and better)\n"
    60         "   -b          Create an assembly array from a binary .res file\n"
    61         "   -B x        Set output byte-order x={n[ative], l[ittle], b[ig]}\n"
    62         "               (win32 only; default is n[ative] which equals "
     59    "Usage: wrc [options...] [infile[.rc|.res]]\n"
     60    "   -a n        Alignment of resource (win16 only, default is 4)\n"
     61    "   -A          Auto register resources (only with gcc 2.7 and better)\n"
     62    "   -b          Create an assembly array from a binary .res file\n"
     63    "   -B x        Set output byte-order x={n[ative], l[ittle], b[ig]}\n"
     64    "               (win32 only; default is n[ative] which equals "
    6365#ifdef WORDS_BIGENDIAN
    64         "big"
     66    "big"
    6567#else
    66         "little"
     68    "little"
    6769#endif
    68         "-endian)\n"
    69         "   -c          Add 'const' prefix to C constants\n"
    70         "   -C cp       Set the resource's codepage to cp (default is 0)\n"
    71         "   -d n        Set debug level to 'n'\n"
    72         "   -D id[=val] Define preprocessor identifier id=val\n"
    73         "   -e          Disable recognition of win32 keywords in 16bit compile\n"
    74         "   -E          Preprocess only\n"
    75         "   -g          Add symbols to the global c namespace\n"
    76         "   -h          Also generate a .h file\n"
    77         "   -H file     Same as -h but written to file\n"
    78         "   -I path     Set include search dir to path (multiple -I allowed)\n"
    79         "   -l lan      Set default language to lan (default is neutral {0, 0})\n"
    80         "   -L          Leave case of embedded filenames as is\n"
    81         "   -m          Do not remap numerical resource IDs\n"
    82         "   -n          Do not generate .s file\n"
    83         "   -N          Do not preprocess input\n"
    84         "   -o file     Output to file (default is infile.[res|s|h]\n"
    85         "   -p prefix   Give a prefix for the generated names\n"
    86         "   -r          Create binary .res file (compile only)\n"
    87         "   -s          Add structure with win32/16 (PE/NE) resource directory\n"
    88         "   -t          Generate indirect loadable resource tables\n"
    89         "   -T          Generate only indirect loadable resources tables\n"
    90         "   -V          Print version end exit\n"
    91         "   -w 16|32    Select win16 or win32 output (default is win32)\n"
    92         "   -W          Enable pedantic warnings\n"
    93         "Input is taken from stdin if no sourcefile specified.\n"
    94         "Debug level 'n' is a bitmask with following meaning:\n"
    95         "    * 0x01 Tell which resource is parsed (verbose mode)\n"
    96         "    * 0x02 Dump internal structures\n"
    97         "    * 0x04 Create a parser trace (yydebug=1)\n"
    98         "    * 0x08 Preprocessor messages\n"
    99         "    * 0x10 Preprocessor lex messages\n"
    100         "    * 0x20 Preprocessor yacc trace\n"
    101         "The -o option only applies to the final destination file, which is\n"
    102         "in case of normal compile a .s file. You must use the '-H header.h'\n"
    103         "option to override the header-filename.\n"
    104         "If no input filename is given and the output name is not overridden\n"
    105         "with -o and/or -H, then the output is written to \"wrc.tab.[sh]\"\n"
    106         ;
     70    "-endian)\n"
     71    "   -c          Add 'const' prefix to C constants\n"
     72    "   -C cp       Set the resource's codepage to cp (default is 0)\n"
     73    "   -d n        Set debug level to 'n'\n"
     74    "   -D id[=val] Define preprocessor identifier id=val\n"
     75    "   -e          Disable recognition of win32 keywords in 16bit compile\n"
     76    "   -E          Preprocess only\n"
     77    "   -g          Add symbols to the global c namespace\n"
     78    "   -h          Also generate a .h file\n"
     79    "   -H file     Same as -h but written to file\n"
     80    "   -I path     Set include search dir to path (multiple -I allowed)\n"
     81    "   -l lan      Set default language to lan (default is neutral {0, 0})\n"
     82    "   -L          Leave case of embedded filenames as is\n"
     83    "   -m          Do not remap numerical resource IDs\n"
     84    "   -n          Do not generate .s file\n"
     85    "   -N          Do not preprocess input\n"
     86    "   -o file     Output to file (default is infile.[res|s|h]\n"
     87    "   -p prefix   Give a prefix for the generated names\n"
     88    "   -r          Create binary .res file (compile only)\n"
     89    "   -s          Add structure with win32/16 (PE/NE) resource directory\n"
     90    "   -t          Generate indirect loadable resource tables\n"
     91    "   -T          Generate only indirect loadable resources tables\n"
     92    "   -V          Print version end exit\n"
     93    "   -w 16|32    Select win16 or win32 output (default is win32)\n"
     94    "   -W          Enable pedantic warnings\n"
     95    "Input is taken from stdin if no sourcefile specified.\n"
     96    "Debug level 'n' is a bitmask with following meaning:\n"
     97    "    * 0x01 Tell which resource is parsed (verbose mode)\n"
     98    "    * 0x02 Dump internal structures\n"
     99    "    * 0x04 Create a parser trace (yydebug=1)\n"
     100    "    * 0x08 Preprocessor messages\n"
     101    "    * 0x10 Preprocessor lex messages\n"
     102    "    * 0x20 Preprocessor yacc trace\n"
     103    "The -o option only applies to the final destination file, which is\n"
     104    "in case of normal compile a .s file. You must use the '-H header.h'\n"
     105    "option to override the header-filename.\n"
     106    "If no input filename is given and the output name is not overridden\n"
     107    "with -o and/or -H, then the output is written to \"wrc.tab.[sh]\"\n"
     108    ;
    107109
    108110char version_string[] = "Wine Resource Compiler Version " WRC_FULLVERSION "\n"
    109                         "Copyright 1998-2000 Bertho A. Stultiens\n"
    110                         "          1994 Martin von Loewis\n";
     111            "Copyright 1998-2000 Bertho A. Stultiens\n"
     112            "          1994 Martin von Loewis\n";
    111113
    112114/*
     
    136138
    137139/*
    138  * debuglevel == DEBUGLEVEL_NONE        Don't bother
    139  * debuglevel & DEBUGLEVEL_CHAT         Say whats done
    140  * debuglevel & DEBUGLEVEL_DUMP         Dump internal structures
    141  * debuglevel & DEBUGLEVEL_TRACE        Create parser trace
    142  * debuglevel & DEBUGLEVEL_PPMSG        Preprocessor messages
    143  * debuglevel & DEBUGLEVEL_PPLEX        Preprocessor lex trace
    144  * debuglevel & DEBUGLEVEL_PPTRACE      Preprocessor yacc trace
     140 * debuglevel == DEBUGLEVEL_NONE    Don't bother
     141 * debuglevel & DEBUGLEVEL_CHAT     Say whats done
     142 * debuglevel & DEBUGLEVEL_DUMP     Dump internal structures
     143 * debuglevel & DEBUGLEVEL_TRACE    Create parser trace
     144 * debuglevel & DEBUGLEVEL_PPMSG    Preprocessor messages
     145 * debuglevel & DEBUGLEVEL_PPLEX    Preprocessor lex trace
     146 * debuglevel & DEBUGLEVEL_PPTRACE  Preprocessor yacc trace
    145147 */
    146148int debuglevel = DEBUGLEVEL_NONE;
     
    240242int remap = 1;
    241243
    242 char *output_name;              /* The name given by the -o option */
    243 char *input_name;               /* The name given on the command-line */
    244 char *header_name;              /* The name given by the -H option */
    245 char *temp_name;                /* Temporary file for preprocess pipe */
    246 
    247 int line_number = 1;            /* The current line */
    248 int char_number = 1;            /* The current char pos within the line */
    249 
    250 char *cmdline;                  /* The entire commandline */
    251 time_t now;                     /* The time of start of wrc */
    252 
    253 resource_t *resource_top;       /* The top of the parsed resources */
     244char *output_name;      /* The name given by the -o option */
     245char *input_name;       /* The name given on the command-line */
     246char *header_name;      /* The name given by the -H option */
     247char *temp_name;        /* Temporary file for preprocess pipe */
     248
     249int line_number = 1;        /* The current line */
     250int char_number = 1;        /* The current char pos within the line */
     251
     252char *cmdline;          /* The entire commandline */
     253time_t now;         /* The time of start of wrc */
     254
     255resource_t *resource_top;   /* The top of the parsed resources */
    254256
    255257#ifdef __EMX__
     
    264266int main(int argc,char *argv[])
    265267{
    266         extern char* optarg;
    267         extern int   optind;
    268         int optc;
    269         int lose = 0;
    270         int ret;
    271         int a;
    272         int i;
    273         int cmdlen;
    274 
    275         signal(SIGSEGV, segvhandler);
    276 
    277         now = time(NULL);
    278 
    279         /* First rebuild the commandline to put in destination */
    280         /* Could be done through env[], but not all OS-es support it */
    281         cmdlen = 4; /* for "wrc " */
    282         for(i = 1; i < argc; i++)
    283                 cmdlen += strlen(argv[i]) + 1;
    284         cmdline = (char *)xmalloc(cmdlen);
    285         strcpy(cmdline, "wrc ");
    286         for(i = 1; i < argc; i++)
    287         {
    288                 strcat(cmdline, argv[i]);
    289                 if(i < argc-1)
    290                         strcat(cmdline, " ");
    291         }
    292 
    293         while((optc = getopt(argc, argv, "a:AbB:cC:d:D:eEghH:I:l:LmnNo:p:rstTVw:W")) != EOF)
    294         {
    295                 switch(optc)
    296                 {
    297                 case 'a':
    298                         alignment = atoi(optarg);
    299                         break;
    300                 case 'A':
    301                         auto_register = 1;
    302                         break;
    303                 case 'b':
    304                         binary = 1;
    305                         break;
    306                 case 'B':
    307                         switch(optarg[0])
    308                         {
    309                         case 'n':
    310                         case 'N':
    311                                 byteorder = WRC_BO_NATIVE;
    312                                 break;
    313                         case 'l':
    314                         case 'L':
    315                                 byteorder = WRC_BO_LITTLE;
    316                                 break;
    317                         case 'b':
    318                         case 'B':
    319                                 byteorder = WRC_BO_BIG;
    320                                 break;
    321                         default:
    322                                 fprintf(stderr, "Byteordering must be n[ative], l[ittle] or b[ig]\n");
    323                                 lose++;
    324                         }
    325                         break;
    326                 case 'c':
    327                         constant = 1;
    328                         break;
    329                 case 'C':
    330                         codepage = strtol(optarg, NULL, 0);
    331                         break;
    332                 case 'd':
    333                         debuglevel = strtol(optarg, NULL, 0);
    334                         break;
    335                 case 'D':
    336                         add_cmdline_define(optarg);
    337                         break;
    338                 case 'e':
    339                         extensions = 0;
    340                         break;
    341                 case 'E':
    342                         preprocess_only = 1;
    343                         break;
    344                 case 'g':
    345                         global = 1;
    346                         break;
    347                 case 'H':
    348                         header_name = strdup(optarg);
    349                         /* Fall through */
    350                 case 'h':
    351                         create_header = 1;
    352                         break;
    353                 case 'I':
    354                         add_include_path(optarg);
    355                         break;
    356                 case 'l':
    357                         {
    358                                 int lan;
    359                                 lan = strtol(optarg, NULL, 0);
    360                                 currentlanguage = new_language(PRIMARYLANGID(lan), SUBLANGID(lan));
    361                         }
    362                         break;
    363                 case 'L':
    364                         leave_case = 1;
    365                         break;
    366                 case 'm':
    367                         remap = 0;
    368                         break;
    369                 case 'n':
    370                         create_s = 0;
    371                         break;
    372                 case 'N':
    373                         no_preprocess = 1;
    374                         break;
    375                 case 'o':
    376                         output_name = strdup(optarg);
    377                         break;
    378                 case 'p':
     268    extern char* optarg;
     269    extern int   optind;
     270    int optc;
     271    int lose = 0;
     272    int ret;
     273    int a;
     274    int i;
     275    int cmdlen;
     276
     277    signal(SIGSEGV, segvhandler);
     278
     279    now = time(NULL);
     280
     281    /* First rebuild the commandline to put in destination */
     282    /* Could be done through env[], but not all OS-es support it */
     283    //cmdlen = 4; /* for "wrc " */ //hi guys! can't you count?
     284    cmdlen = 5; /* for "wrc " */
     285    for(i = 1; i < argc; i++)
     286        cmdlen += strlen(argv[i]) + 1;
     287    cmdline = (char *)xmalloc(cmdlen);
     288    strcpy(cmdline, "wrc ");
     289    for(i = 1; i < argc; i++)
     290    {
     291        strcat(cmdline, argv[i]);
     292        if(i < argc-1)
     293            strcat(cmdline, " ");
     294    }
     295
     296    while((optc = getopt(argc, argv, "a:AbB:cC:d:D:eEghH:I:l:LmnNo:p:rstTVw:W")) != EOF)
     297    {
     298        switch(optc)
     299        {
     300        case 'a':
     301            alignment = atoi(optarg);
     302            break;
     303        case 'A':
     304            auto_register = 1;
     305            break;
     306        case 'b':
     307            binary = 1;
     308            break;
     309        case 'B':
     310            switch(optarg[0])
     311            {
     312            case 'n':
     313            case 'N':
     314                byteorder = WRC_BO_NATIVE;
     315                break;
     316            case 'l':
     317            case 'L':
     318                byteorder = WRC_BO_LITTLE;
     319                break;
     320            case 'b':
     321            case 'B':
     322                byteorder = WRC_BO_BIG;
     323                break;
     324            default:
     325                fprintf(stderr, "Byteordering must be n[ative], l[ittle] or b[ig]\n");
     326                lose++;
     327            }
     328            break;
     329        case 'c':
     330            constant = 1;
     331            break;
     332        case 'C':
     333            codepage = strtol(optarg, NULL, 0);
     334            break;
     335        case 'd':
     336            debuglevel = strtol(optarg, NULL, 0);
     337            break;
     338        case 'D':
     339            add_cmdline_define(optarg);
     340            break;
     341        case 'e':
     342            extensions = 0;
     343            break;
     344        case 'E':
     345            preprocess_only = 1;
     346            break;
     347        case 'g':
     348            global = 1;
     349            break;
     350        case 'H':
     351            header_name = strdup(optarg);
     352            /* Fall through */
     353        case 'h':
     354            create_header = 1;
     355            break;
     356        case 'I':
     357            add_include_path(optarg);
     358            break;
     359        case 'l':
     360            {
     361                int lan;
     362                lan = strtol(optarg, NULL, 0);
     363                currentlanguage = new_language(PRIMARYLANGID(lan), SUBLANGID(lan));
     364            }
     365            break;
     366        case 'L':
     367            leave_case = 1;
     368            break;
     369        case 'm':
     370            remap = 0;
     371            break;
     372        case 'n':
     373            create_s = 0;
     374            break;
     375        case 'N':
     376            no_preprocess = 1;
     377            break;
     378        case 'o':
     379            output_name = strdup(optarg);
     380            break;
     381        case 'p':
    379382#ifdef NEED_UNDERSCORE_PREFIX
    380                         prefix = (char *)xmalloc(strlen(optarg)+2);
    381                         prefix[0] = '_';
    382                         strcpy(prefix+1, optarg);
     383            prefix = (char *)xmalloc(strlen(optarg)+2);
     384            prefix[0] = '_';
     385            strcpy(prefix+1, optarg);
    383386#else
    384                         prefix = xstrdup(optarg);
     387            prefix = xstrdup(optarg);
    385388#endif
    386                         break;
    387                 case 'r':
    388                         create_res = 1;
    389                         break;
    390                 case 's':
    391                         create_dir = 1;
    392                         break;
    393                 case 'T':
    394                         indirect_only = 1;
    395                         /* Fall through */
    396                 case 't':
    397                         indirect = 1;
    398                         break;
    399                 case 'V':
    400                         printf(version_string);
    401                         exit(0);
    402                         break;
    403                 case 'w':
    404                         if(!strcmp(optarg, "16"))
    405                                 win32 = 0;
    406                         else if(!strcmp(optarg, "32"))
    407                                 win32 = 1;
    408                         else
    409                                 lose++;
    410                         break;
    411                 case 'W':
    412                         pedantic = 1;
    413                         break;
    414                 default:
    415                         lose++;
    416                         break;
    417                 }
    418         }
    419 
    420         if(lose)
    421         {
    422                 fprintf(stderr, usage);
    423                 return 1;
    424         }
    425 
    426         /* Check the command line options for invalid combinations */
    427         if(win32)
    428         {
    429                 if(!extensions)
    430                 {
    431                         warning("Option -e ignored with 32bit compile\n");
    432                         extensions = 1;
    433                 }
    434         }
    435 
    436         if(create_res)
    437         {
    438                 if(constant)
    439                 {
    440                         warning("Option -c ignored with compile to .res\n");
    441                         constant = 0;
    442                 }
    443 
    444                 if(create_header)
    445                 {
    446                         warning("Option -[h|H] ignored with compile to .res\n");
    447                         create_header = 0;
    448                 }
    449 
    450                 if(indirect)
    451                 {
    452                         warning("Option -l ignored with compile to .res\n");
    453                         indirect = 0;
    454                 }
    455 
    456                 if(indirect_only)
    457                 {
    458                         warning("Option -L ignored with compile to .res\n");
    459                         indirect_only = 0;
    460                 }
    461 
    462                 if(global)
    463                 {
    464                         warning("Option -g ignored with compile to .res\n");
    465                         global = 0;
    466                 }
    467 
    468                 if(create_dir)
    469                 {
    470                         error("Option -r and -s cannot be used together\n");
    471                 }
    472 
    473                 if(binary)
    474                 {
    475                         error("Option -r and -b cannot be used together\n");
    476                 }
    477         }
    478 
    479         if(byteorder != WRC_BO_NATIVE)
    480         {
    481                 if(binary)
    482                         error("Forced byteordering not supported for binary resources\n");
    483         }
    484 
    485         if(preprocess_only)
    486         {
    487                 if(constant)
    488                 {
    489                         warning("Option -c ignored with preprocess only\n");
    490                         constant = 0;
    491                 }
    492 
    493                 if(create_header)
    494                 {
    495                         warning("Option -[h|H] ignored with preprocess only\n");
    496                         create_header = 0;
    497                 }
    498 
    499                 if(indirect)
    500                 {
    501                         warning("Option -l ignored with preprocess only\n");
    502                         indirect = 0;
    503                 }
    504 
    505                 if(indirect_only)
    506                 {
    507                         error("Option -E and -L cannot be used together\n");
    508                 }
    509 
    510                 if(global)
    511                 {
    512                         warning("Option -g ignored with preprocess only\n");
    513                         global = 0;
    514                 }
    515 
    516                 if(create_dir)
    517                 {
    518                         warning("Option -s ignored with preprocess only\n");
    519                         create_dir = 0;
    520                 }
    521 
    522                 if(binary)
    523                 {
    524                         error("Option -E and -b cannot be used together\n");
    525                 }
    526 
    527                 if(no_preprocess)
    528                 {
    529                         error("Option -E and -N cannot be used together\n");
    530                 }
    531         }
     389            break;
     390        case 'r':
     391            create_res = 1;
     392            break;
     393        case 's':
     394            create_dir = 1;
     395            break;
     396        case 'T':
     397            indirect_only = 1;
     398            /* Fall through */
     399        case 't':
     400            indirect = 1;
     401            break;
     402        case 'V':
     403            printf(version_string);
     404            exit(0);
     405            break;
     406        case 'w':
     407            if(!strcmp(optarg, "16"))
     408                win32 = 0;
     409            else if(!strcmp(optarg, "32"))
     410                win32 = 1;
     411            else
     412                lose++;
     413            break;
     414        case 'W':
     415            pedantic = 1;
     416            break;
     417        default:
     418            lose++;
     419            break;
     420        }
     421    }
     422
     423    if(lose)
     424    {
     425        fprintf(stderr, usage);
     426        return 1;
     427    }
     428
     429    /* Check the command line options for invalid combinations */
     430    if(win32)
     431    {
     432        if(!extensions)
     433        {
     434            warning("Option -e ignored with 32bit compile\n");
     435            extensions = 1;
     436        }
     437    }
     438
     439    if(create_res)
     440    {
     441        if(constant)
     442        {
     443            warning("Option -c ignored with compile to .res\n");
     444            constant = 0;
     445        }
     446
     447        if(create_header)
     448        {
     449            warning("Option -[h|H] ignored with compile to .res\n");
     450            create_header = 0;
     451        }
     452
     453        if(indirect)
     454        {
     455            warning("Option -l ignored with compile to .res\n");
     456            indirect = 0;
     457        }
     458
     459        if(indirect_only)
     460        {
     461            warning("Option -L ignored with compile to .res\n");
     462            indirect_only = 0;
     463        }
     464
     465        if(global)
     466        {
     467            warning("Option -g ignored with compile to .res\n");
     468            global = 0;
     469        }
     470
     471        if(create_dir)
     472        {
     473            error("Option -r and -s cannot be used together\n");
     474        }
     475
     476        if(binary)
     477        {
     478            error("Option -r and -b cannot be used together\n");
     479        }
     480    }
     481
     482    if(byteorder != WRC_BO_NATIVE)
     483    {
     484        if(binary)
     485            error("Forced byteordering not supported for binary resources\n");
     486    }
     487
     488    if(preprocess_only)
     489    {
     490        if(constant)
     491        {
     492            warning("Option -c ignored with preprocess only\n");
     493            constant = 0;
     494        }
     495
     496        if(create_header)
     497        {
     498            warning("Option -[h|H] ignored with preprocess only\n");
     499            create_header = 0;
     500        }
     501
     502        if(indirect)
     503        {
     504            warning("Option -l ignored with preprocess only\n");
     505            indirect = 0;
     506        }
     507
     508        if(indirect_only)
     509        {
     510            error("Option -E and -L cannot be used together\n");
     511        }
     512
     513        if(global)
     514        {
     515            warning("Option -g ignored with preprocess only\n");
     516            global = 0;
     517        }
     518
     519        if(create_dir)
     520        {
     521            warning("Option -s ignored with preprocess only\n");
     522            create_dir = 0;
     523        }
     524
     525        if(binary)
     526        {
     527            error("Option -E and -b cannot be used together\n");
     528        }
     529
     530        if(no_preprocess)
     531        {
     532            error("Option -E and -N cannot be used together\n");
     533        }
     534    }
    532535
    533536#if !defined(HAVE_WINE_CONSTRUCTOR)
    534         if(auto_register)
    535         {
    536                 warning("Autoregister code non-operable (HAVE_WINE_CONSTRUCTOR not defined)");
    537                 auto_register = 0;
    538         }
     537    if(auto_register)
     538    {
     539        warning("Autoregister code non-operable (HAVE_WINE_CONSTRUCTOR not defined)");
     540        auto_register = 0;
     541    }
    539542#endif
    540543
    541         /* Set alignment power */
    542         a = alignment;
    543         for(alignment_pwr = 0; alignment_pwr < 10 && a > 1; alignment_pwr++)
    544         {
    545                 a >>= 1;
    546         }
    547         if(a != 1)
    548         {
    549                 error("Alignment must be between 1 and 1024");
    550         }
    551         if((1 << alignment_pwr) != alignment)
    552         {
    553                 error("Alignment must be a power of 2");
    554         }
    555 
    556         /* Kill io buffering when some kind of debuglevel is enabled */
    557         if(debuglevel)
    558         {
    559                 setbuf(stdout,0);
    560                 setbuf(stderr,0);
    561         }
    562 
    563         yydebug = debuglevel & DEBUGLEVEL_TRACE ? 1 : 0;
    564         yy_flex_debug = debuglevel & DEBUGLEVEL_TRACE ? 1 : 0;
    565         ppdebug = debuglevel & DEBUGLEVEL_PPTRACE ? 1 : 0;
    566         pp_flex_debug = debuglevel & DEBUGLEVEL_PPLEX ? 1 : 0;
    567 
    568         /* Set the default defined stuff */
    569         add_cmdline_define("__WRC__=" WRC_EXP_STRINGIZE(WRC_MAJOR_VERSION));
    570         add_cmdline_define("__WRC_MINOR__=" WRC_EXP_STRINGIZE(WRC_MINOR_VERSION));
    571         add_cmdline_define("__WRC_MICRO__=" WRC_EXP_STRINGIZE(WRC_MICRO_VERSION));
    572         add_cmdline_define("__WRC_PATCH__=" WRC_EXP_STRINGIZE(WRC_MICRO_VERSION));
    573 
    574         add_cmdline_define("RC_INVOKED=1");
    575 
    576         if(win32)
    577         {
    578                 add_cmdline_define("__WIN32__=1");
    579                 add_cmdline_define("__FLAT__=1");
    580         }
    581 
    582         add_special_define("__FILE__");
    583         add_special_define("__LINE__");
    584         add_special_define("__DATE__");
    585         add_special_define("__TIME__");
    586 
    587         /* Check if the user set a language, else set default */
    588         if(!currentlanguage)
    589                 currentlanguage = new_language(0, 0);
    590 
    591         /* Check for input file on command-line */
    592         if(optind < argc)
    593         {
    594                 input_name = argv[optind];
    595         }
    596 
    597         if(binary && !input_name)
    598         {
    599                 error("Binary mode requires .res file as input\n");
    600         }
    601 
    602         /* Generate appropriate outfile names */
    603         if(!output_name && !preprocess_only)
    604         {
    605                 output_name = dup_basename(input_name, binary ? ".res" : ".rc");
    606                 strcat(output_name, create_res ? ".res" : ".s");
    607         }
    608 
    609         if(!header_name && !create_res)
    610         {
    611                 header_name = dup_basename(input_name, binary ? ".res" : ".rc");
    612                 strcat(header_name, ".h");
    613         }
    614 
    615         /* Run the preprocessor on the input */
    616         if(!no_preprocess && !binary)
    617         {
    618                 char *real_name;
    619                 /*
    620                 * Preprocess the input to a temp-file, or stdout if
    621                 * no output was given.
    622                 */
    623 
    624                 chat("Starting preprocess");
    625 
    626                 if(preprocess_only && !output_name)
    627                 {
    628                         ppout = stdout;
    629                 }
    630                 else if(preprocess_only && output_name)
    631                 {
    632                         if(!(ppout = fopen(output_name, "wb")))
    633                                 error("Could not open %s for writing\n", output_name);
    634                 }
    635                 else
    636                 {
    637                         if(!(temp_name = tmpnam(NULL)))
    638                                 error("Could nor generate a temp-name\n");
    639                         temp_name = xstrdup(temp_name);
    640                         if(!(ppout = fopen(temp_name, "wb")))
    641                                 error("Could not create a temp-file\n");
    642 
    643                         atexit(rm_tempfile);
    644                 }
    645 
    646                 real_name = input_name; /* Because it gets overwritten */
    647 
    648                 if(!input_name)
    649                         ppin = stdin;
    650                 else
    651                 {
    652                         if(!(ppin = fopen(input_name, "rb")))
    653                                 error("Could not open %s\n", input_name);
    654                 }
    655 
    656                 fprintf(ppout, "# 1 \"%s\" 1\n", input_name ? input_name : "");
    657 
    658                 ret = ppparse();
    659 
    660                 input_name = real_name;
    661 
    662                 if(input_name)
    663                         fclose(ppin);
    664 
    665                 fclose(ppout);
    666 
    667                 input_name = temp_name;
    668 
    669                 if(ret)
    670                         exit(1);        /* Error during preprocess */
    671 
    672                 if(preprocess_only)
    673                         exit(0);
    674         }
    675 
    676         if(!binary)
    677         {
    678                 /* Go from .rc to .res or .s */
    679                 chat("Starting parse");
    680 
    681                 if(!(yyin = fopen(input_name, "rb")))
    682                         error("Could not open %s for input\n", input_name);
    683 
    684                 ret = yyparse();
    685 
    686                 if(input_name)
    687                         fclose(yyin);
    688 
    689                 if(ret)
    690                 {
    691                         /* Error during parse */
    692                         exit(1);
    693                 }
    694 
    695                 if(debuglevel & DEBUGLEVEL_DUMP)
    696                         dump_resources(resource_top);
    697 
    698                 /* Convert the internal lists to binary data */
    699                 resources2res(resource_top);
    700 
    701                 if(create_res)
    702                 {
    703                         chat("Writing .res-file");
    704                         write_resfile(output_name, resource_top);
    705                 }
    706                 else
    707                 {
    708                         if(create_s)
    709                         {
    710                                 chat("Writing .s-file");
    711                                 write_s_file(output_name, resource_top);
    712                         }
    713                         if(create_header)
    714                         {
    715                                 chat("Writing .h-file");
    716                                 write_h_file(header_name, resource_top);
    717                         }
    718                 }
    719 
    720         }
    721         else
    722         {
    723                 /* Go from .res to .s */
    724                 chat("Reading .res-file");
    725                 resource_top = read_resfile(input_name);
    726                 if(create_s)
    727                 {
    728                         chat("Writing .s-file");
    729                         write_s_file(output_name, resource_top);
    730                 }
    731                 if(create_header)
    732                 {
    733                         chat("Writing .h-file");
    734                         write_h_file(header_name, resource_top);
    735                 }
    736         }
    737 
    738         return 0;
     544    /* Set alignment power */
     545    a = alignment;
     546    for(alignment_pwr = 0; alignment_pwr < 10 && a > 1; alignment_pwr++)
     547    {
     548        a >>= 1;
     549    }
     550    if(a != 1)
     551    {
     552        error("Alignment must be between 1 and 1024");
     553    }
     554    if((1 << alignment_pwr) != alignment)
     555    {
     556        error("Alignment must be a power of 2");
     557    }
     558
     559    /* Kill io buffering when some kind of debuglevel is enabled */
     560    if(debuglevel)
     561    {
     562        setbuf(stdout,0);
     563        setbuf(stderr,0);
     564    }
     565
     566    yydebug = debuglevel & DEBUGLEVEL_TRACE ? 1 : 0;
     567    yy_flex_debug = debuglevel & DEBUGLEVEL_TRACE ? 1 : 0;
     568    ppdebug = debuglevel & DEBUGLEVEL_PPTRACE ? 1 : 0;
     569    pp_flex_debug = debuglevel & DEBUGLEVEL_PPLEX ? 1 : 0;
     570
     571    /* Set the default defined stuff */
     572    add_cmdline_define("__WRC__=" WRC_EXP_STRINGIZE(WRC_MAJOR_VERSION));
     573    add_cmdline_define("__WRC_MINOR__=" WRC_EXP_STRINGIZE(WRC_MINOR_VERSION));
     574    add_cmdline_define("__WRC_MICRO__=" WRC_EXP_STRINGIZE(WRC_MICRO_VERSION));
     575    add_cmdline_define("__WRC_PATCH__=" WRC_EXP_STRINGIZE(WRC_MICRO_VERSION));
     576
     577    add_cmdline_define("RC_INVOKED=1");
     578
     579    if(win32)
     580    {
     581        add_cmdline_define("__WIN32__=1");
     582        add_cmdline_define("__FLAT__=1");
     583    }
     584
     585    add_special_define("__FILE__");
     586    add_special_define("__LINE__");
     587    add_special_define("__DATE__");
     588    add_special_define("__TIME__");
     589
     590    /* Check if the user set a language, else set default */
     591    if(!currentlanguage)
     592        currentlanguage = new_language(0, 0);
     593
     594    /* Check for input file on command-line */
     595    if(optind < argc)
     596    {
     597        input_name = argv[optind];
     598    }
     599
     600    if(binary && !input_name)
     601    {
     602        error("Binary mode requires .res file as input\n");
     603    }
     604
     605    /* Generate appropriate outfile names */
     606    if(!output_name && !preprocess_only)
     607    {
     608        output_name = dup_basename(input_name, binary ? ".res" : ".rc");
     609        strcat(output_name, create_res ? ".res" : ".s");
     610    }
     611
     612    if(!header_name && !create_res)
     613    {
     614        header_name = dup_basename(input_name, binary ? ".res" : ".rc");
     615        strcat(header_name, ".h");
     616    }
     617
     618    /* Run the preprocessor on the input */
     619    if(!no_preprocess && !binary)
     620    {
     621        char *real_name;
     622        /*
     623        * Preprocess the input to a temp-file, or stdout if
     624        * no output was given.
     625        */
     626
     627        chat("Starting preprocess");
     628
     629        if(preprocess_only && !output_name)
     630        {
     631            ppout = stdout;
     632        }
     633        else if(preprocess_only && output_name)
     634        {
     635            if(!(ppout = fopen(output_name, "wb")))
     636                error("Could not open %s for writing\n", output_name);
     637        }
     638        else
     639        {
     640            if(!(temp_name = tmpnam(NULL)))
     641                error("Could nor generate a temp-name\n");
     642            temp_name = xstrdup(temp_name);
     643            if(!(ppout = fopen(temp_name, "wb")))
     644                error("Could not create a temp-file\n");
     645
     646            atexit(rm_tempfile);
     647        }
     648
     649        real_name = input_name; /* Because it gets overwritten */
     650
     651        if(!input_name)
     652            ppin = stdin;
     653        else
     654        {
     655            if(!(ppin = fopen(input_name, "rb")))
     656                error("Could not open %s\n", input_name);
     657        }
     658
     659        fprintf(ppout, "# 1 \"%s\" 1\n", input_name ? input_name : "");
     660
     661        ret = ppparse();
     662
     663        input_name = real_name;
     664
     665        if(input_name)
     666            fclose(ppin);
     667
     668        fclose(ppout);
     669
     670        input_name = temp_name;
     671
     672        if(ret)
     673            exit(1);    /* Error during preprocess */
     674
     675        if(preprocess_only)
     676            exit(0);
     677    }
     678
     679    if(!binary)
     680    {
     681        /* Go from .rc to .res or .s */
     682        chat("Starting parse");
     683
     684        if(!(yyin = fopen(input_name, "rb")))
     685            error("Could not open %s for input\n", input_name);
     686
     687        ret = yyparse();
     688
     689        if(input_name)
     690            fclose(yyin);
     691
     692        if(ret)
     693        {
     694            /* Error during parse */
     695            exit(1);
     696        }
     697
     698        if(debuglevel & DEBUGLEVEL_DUMP)
     699            dump_resources(resource_top);
     700
     701        /* Convert the internal lists to binary data */
     702        resources2res(resource_top);
     703
     704        if(create_res)
     705        {
     706            chat("Writing .res-file");
     707            write_resfile(output_name, resource_top);
     708        }
     709        else
     710        {
     711            if(create_s)
     712            {
     713                chat("Writing .s-file");
     714                write_s_file(output_name, resource_top);
     715            }
     716            if(create_header)
     717            {
     718                chat("Writing .h-file");
     719                write_h_file(header_name, resource_top);
     720            }
     721        }
     722
     723    }
     724    else
     725    {
     726        /* Go from .res to .s */
     727        chat("Reading .res-file");
     728        resource_top = read_resfile(input_name);
     729        if(create_s)
     730        {
     731            chat("Writing .s-file");
     732            write_s_file(output_name, resource_top);
     733        }
     734        if(create_header)
     735        {
     736            chat("Writing .h-file");
     737            write_h_file(header_name, resource_top);
     738        }
     739    }
     740
     741    return 0;
    739742}
    740743
     
    742745static void rm_tempfile(void)
    743746{
    744         if(temp_name)
    745                 unlink(temp_name);
     747    if(temp_name)
     748        unlink(temp_name);
    746749}
    747750
    748751static void segvhandler(int sig)
    749752{
    750         fprintf(stderr, "\n%s:%d: Oops, segment violation\n", input_name, line_number);
    751         fflush(stdout);
    752         fflush(stderr);
    753         abort();
     753    fprintf(stderr, "\n%s:%d: Oops, segment violation\n", input_name, line_number);
     754    fflush(stdout);
     755    fflush(stderr);
     756    abort();
    754757}
    755758
     759
     760
Note: See TracChangeset for help on using the changeset viewer.