/* ******************************************************************************* * * Copyright (C) 1999, International Business Machines * Corporation and others. All Rights Reserved. * ******************************************************************************* * file name: gennames.c * encoding: US-ASCII * tab size: 8 (not used) * indentation:4 * * created on: 1999nov01 * created by: Markus W. Scherer * * This program reads a binary file and creates a C source code file * with a byte array that contains the data of the binary file. * * 12/09/1999 weiv Added multiple file handling */ #ifdef WIN32 #include #include #endif #include #include #include "unicode/utypes.h" #include "unicode/putil.h" #include "cmemory.h" #include "cstring.h" #include "filestrm.h" #include "toolutil.h" #include "uoptions.h" static uint16_t column=0xffff; /* prototypes --------------------------------------------------------------- */ static void writeCCode(const char *filename, const char *destdir); static void writeObjectCode(const char *filename, const char *destdir); static void getOutFilename(const char *inFilename, const char *destdir, char *outFilename, char *entryName, const char *newSuffix); static void write8(FileStream *out, uint8_t byte); /* -------------------------------------------------------------------------- */ static UOption options[]={ /*0*/UOPTION_HELP_H, UOPTION_HELP_QUESTION_MARK, UOPTION_DESTDIR, UOPTION_DEF("object", 'o', UOPT_NO_ARG), UOPTION_DEF("name", 'n', UOPT_REQUIRES_ARG), /*5*/UOPTION_DEF( "entrypoint", 'e', UOPT_REQUIRES_ARG) }; char symPrefix[100]; extern int main(int argc, char* argv[]) { /* read command line options */ argc=u_parseArgs(argc, argv, sizeof(options)/sizeof(options[0]), options); #ifndef U_HAVE_BIND_INTERNAL_REFERENCES if( (options[4].doesOccur) && uprv_strcmp(options[4].value, U_ICUDATA_NAME)) /* be consistent with gencmn! */ { uprv_strcpy(symPrefix, options[4].value); uprv_strcat(symPrefix, "_"); } else { symPrefix[0] = 0; } #else symPrefix[0] = 0; #endif /* error handling, printing usage message */ if(argc<0) { fprintf(stderr, "error in command line argument \"%s\"\n", argv[-argc]); } if(argc<0 || options[0].doesOccur || options[1].doesOccur) { fprintf(stderr, "usage: %s [-options] filename1 filename2 ...\n" "\tread each binary input file and \n" "\tcreate a .c file with a byte array that contains the input file's data\n" "\toptions:\n" "\t\t-h or -? or --help this usage text\n" "\t\t-d or --destdir destination directory, followed by the path\n" "\t\t-o or --object write a .obj file instead of .c\n", argv[0]); } else { const char *message, *filename; void (*writeCode)(const char *filename, const char *destdir); if(options[3].doesOccur) { message="Generating object code for %s\n"; writeCode=&writeObjectCode; } else { message="Generating C code for %s\n"; writeCode=&writeCCode; } while(--argc) { filename=getLongPathname(argv[argc]); fprintf(stdout, message, filename); column=0xffff; writeCode(filename, options[2].value); } } return 0; } static void writeCCode(const char *filename, const char *destdir) { char buffer[4096], entry[40]; FileStream *in, *out; size_t i, length; in=T_FileStream_open(filename, "rb"); if(in==NULL) { fprintf(stderr, "genccode: unable to open input file %s\n", filename); exit(U_FILE_ACCESS_ERROR); } getOutFilename(filename, destdir, buffer, entry, ".c"); out=T_FileStream_open(buffer, "w"); if(out==NULL) { fprintf(stderr, "genccode: unable to open output file %s\n", buffer); exit(U_FILE_ACCESS_ERROR); } /* turn dashes in the entry name into underscores */ length=uprv_strlen(entry); for(i=0; i=100) { s[i++]=(char)('0'+byte/100); byte%=100; } if(i>0 || byte>=10) { s[i++]=(char)('0'+byte/10); byte%=10; } s[i++]=(char)('0'+byte); s[i]=0; /* write the value, possibly with comma and newline */ if(column==0xffff) { /* first byte */ column=1; } else if(column<16) { T_FileStream_writeLine(out, ","); ++column; } else { T_FileStream_writeLine(out, ",\n"); column=1; } T_FileStream_writeLine(out, s); }