4abef77311
X-SVN-Rev: 8135
262 lines
9.1 KiB
C
262 lines
9.1 KiB
C
/******************************************************************************
|
|
*
|
|
* Copyright (C) 2000-2001, International Business Machines
|
|
* Corporation and others. All Rights Reserved.
|
|
*
|
|
*******************************************************************************
|
|
* file name: pkgdata.c
|
|
* encoding: ANSI X3.4 (1968)
|
|
* tab size: 8 (not used)
|
|
* indentation:4
|
|
*
|
|
* created on: 2000may15
|
|
* created by: Steven \u24C7 Loomis
|
|
*
|
|
* This program packages the ICU data into different forms
|
|
* (DLL, common data, etc.)
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include "unicode/utypes.h"
|
|
#include "cmemory.h"
|
|
#include "cstring.h"
|
|
#include "filestrm.h"
|
|
#include "toolutil.h"
|
|
#include "unewdata.h"
|
|
#include "uoptions.h"
|
|
#include "pkgtypes.h"
|
|
#include "makefile.h"
|
|
|
|
static void
|
|
writeObjRules(UPKGOptions *o, FileStream *makefile, CharList **objects)
|
|
{
|
|
const char *p, *baseName;
|
|
char tmp[1024];
|
|
char stanza[1024];
|
|
char cfile[1024];
|
|
CharList *oTail = NULL;
|
|
CharList *infiles;
|
|
CharList *parents = NULL, *commands = NULL;
|
|
|
|
infiles = o->filePaths;
|
|
|
|
for(;infiles;infiles = infiles->next) {
|
|
baseName = findBasename(infiles->str);
|
|
p = uprv_strrchr(baseName, '.');
|
|
if( (p == NULL) || (*p == '\0' ) ) {
|
|
continue;
|
|
}
|
|
|
|
uprv_strncpy(tmp, baseName, p-baseName);
|
|
p++;
|
|
|
|
uprv_strcpy(tmp+(p-1-baseName), "_"); /* to append */
|
|
uprv_strcat(tmp, p);
|
|
uprv_strcat(tmp, OBJ_SUFFIX);
|
|
|
|
*objects = pkg_appendToList(*objects, &oTail, uprv_strdup(tmp));
|
|
|
|
/* write source list */
|
|
strcpy(cfile,tmp);
|
|
strcpy(cfile+strlen(cfile)-strlen(OBJ_SUFFIX), ".c" );
|
|
|
|
|
|
/* Make up parents.. */
|
|
parents = pkg_appendToList(parents, NULL, uprv_strdup(infiles->str));
|
|
|
|
/* make up commands.. */
|
|
sprintf(stanza, "$(INVOKE) $(GENCCODE) -n $(ENTRYPOINT) -d $(TEMP_DIR) $<");
|
|
|
|
commands = pkg_appendToList(commands, NULL, uprv_strdup(stanza));
|
|
|
|
sprintf(stanza, "$(COMPILE.c) -o $@ $(TEMP_DIR)/%s", cfile);
|
|
commands = pkg_appendToList(commands, NULL, uprv_strdup(stanza));
|
|
|
|
sprintf(stanza, "$(TEMP_DIR)/%s", tmp);
|
|
pkg_mak_writeStanza(makefile, o, stanza, parents, commands);
|
|
|
|
pkg_deleteList(parents);
|
|
pkg_deleteList(commands);
|
|
parents = NULL;
|
|
commands = NULL;
|
|
}
|
|
|
|
}
|
|
|
|
void pkg_mode_dll(UPKGOptions *o, FileStream *makefile, UErrorCode *status)
|
|
{
|
|
char tmp[1024];
|
|
CharList *tail = NULL;
|
|
CharList *objects = NULL;
|
|
|
|
if(U_FAILURE(*status)) {
|
|
return;
|
|
}
|
|
|
|
uprv_strcpy(tmp, LIB_PREFIX "$(NAME)" UDATA_SO_SUFFIX);
|
|
|
|
/* We should be the only item. So we don't care about the order. */
|
|
o->outFiles = pkg_appendToList(o->outFiles, &tail, uprv_strdup(tmp));
|
|
|
|
if(o->nooutput || o->verbose) {
|
|
fprintf(stdout, "# Output file: %s%s%s\n", o->targetDir, U_FILE_SEP_STRING, tmp);
|
|
}
|
|
|
|
if(o->nooutput) {
|
|
*status = U_ZERO_ERROR;
|
|
return;
|
|
}
|
|
|
|
/* begin writing makefile ========================= */
|
|
|
|
|
|
/*390port start*/
|
|
#ifdef OS390BATCH
|
|
if (uprv_strcmp(o->shortName, U_ICUDATA_NAME) == 0)
|
|
sprintf(tmp, "# File to make:\nBATCH_TARGET=\"//'${LOADMOD}(IXMI" U_ICU_VERSION_SHORT "DA)'\"\n\n");
|
|
else if (uprv_strcmp(o->shortName, "testdata") == 0)
|
|
sprintf(tmp, "# File to make:\nBATCH_TARGET=\"//'${LOADMOD}(IXMI" U_ICU_VERSION_SHORT "TE)'\"\n\n");
|
|
else if (uprv_strcmp(o->shortName, U_ICUDATA_NAME"_390") == 0)
|
|
sprintf(tmp, "# File to make:\nBATCH_TARGET=\"//'${LOADMOD}(IXMI" U_ICU_VERSION_SHORT "D1)'\"\n\n");
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
#endif
|
|
|
|
T_FileStream_writeLine(makefile, "# Version numbers:\nVERSIONED=");
|
|
if (o->version) {
|
|
sprintf(tmp, ".%s", o->version);
|
|
if (!uprv_strchr(o->version, '.')) {
|
|
uprv_strcat(tmp, ".0");
|
|
}
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
T_FileStream_writeLine(makefile, "\nDLL_LDFLAGS=$(LD_SONAME) $(RPATH_LDFLAGS) $(BIR_LDFLAGS)\nDLL_DEPS=$(BIR_DEPS)\n");
|
|
} else {
|
|
T_FileStream_writeLine(makefile, "\nDLL_LDFLAGS=$(BIR_LDFLAGS)\nDLL_DEPS=$(BIR_DEPS)\n");
|
|
}
|
|
T_FileStream_writeLine(makefile, "\n");
|
|
|
|
sprintf(tmp, "# File to make:\nTARGET=%s\n\n", o->outFiles->str);
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
if (o->version) {
|
|
char *p;
|
|
const char *v;
|
|
|
|
T_FileStream_writeLine(makefile, "SO_TARGET=$(TARGET)\n");
|
|
sprintf(tmp, "SO_TARGET_VERSION=%s\n", o->version);
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
uprv_strcpy(tmp, "SO_TARGET_VERSION_MAJOR=");
|
|
for (p = tmp + uprv_strlen(tmp), v = o->version; *v && *v != '.'; ++v) {
|
|
*p++ = *v;
|
|
}
|
|
*p++ = '\n';
|
|
*p++ = '\n';
|
|
*p++ = 0;
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
} else {
|
|
T_FileStream_writeLine(makefile, "FINAL_SO_TARGET=$(TARGET)\n");
|
|
}
|
|
|
|
uprv_strcpy(tmp, "all: $(TARGETDIR)/$(FINAL_SO_TARGET) $(BATCH_TARGET)");
|
|
if (o->version) {
|
|
uprv_strcat(tmp, " $(TARGETDIR)/$(MIDDLE_SO_TARGET) $(TARGETDIR)/$(SO_TARGET)");
|
|
}
|
|
uprv_strcat(tmp, "\n\n");
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
|
|
/* Write compile rules */
|
|
writeObjRules(o, makefile, &objects);
|
|
|
|
sprintf(tmp, "# List file for gencmn:\n"
|
|
"CMNLIST=%s%s$(NAME)_dll.lst\n\n",
|
|
o->tmpDir,
|
|
U_FILE_SEP_STRING);
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
|
|
if(o->hadStdin == FALSE) { /* shortcut */
|
|
T_FileStream_writeLine(makefile, "$(CMNLIST): $(LISTFILES)\n"
|
|
"\tcat $(LISTFILES) > $(CMNLIST)\n\n");
|
|
} else {
|
|
T_FileStream_writeLine(makefile, "$(CMNLIST): \n"
|
|
"\t@echo \"generating $@ (list of data files)\"\n"
|
|
"\t@-$(RMV) $@\n"
|
|
"\t@for file in $(DATAFILEPATHS); do \\\n"
|
|
"\t echo $$file >> $@; \\\n"
|
|
"\tdone;\n\n");
|
|
}
|
|
|
|
sprintf(tmp,"$(TEMP_DIR)/$(NAME)_dat.o : $(TEMP_DIR)/$(NAME)_dat.c\n"
|
|
"\t$(COMPILE.c) -o $@ $<\n\n");
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
|
|
T_FileStream_writeLine(makefile, "# 'TOCOBJ' contains C Table of Contents objects [if any]\n");
|
|
|
|
sprintf(tmp, "$(TEMP_DIR)/$(NAME)_dat.c: $(CMNLIST)\n"
|
|
"\t$(INVOKE) $(GENCMN) -e $(ENTRYPOINT) -n $(NAME) -S -d $(TEMP_DIR) 0 $(CMNLIST)\n\n");
|
|
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
sprintf(tmp, "TOCOBJ= $(NAME)_dat%s \n\n", OBJ_SUFFIX);
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
sprintf(tmp, "TOCSYM= %s_dat \n\n", o->entryName); /* entrypoint not always shortname! */
|
|
T_FileStream_writeLine(makefile, tmp);
|
|
|
|
T_FileStream_writeLine(makefile, "BASE_OBJECTS= $(TOCOBJ) ");
|
|
|
|
pkg_writeCharListWrap(makefile, objects, " ", " \\\n",0);
|
|
T_FileStream_writeLine(makefile, "\n\n");
|
|
T_FileStream_writeLine(makefile, "OBJECTS=$(BASE_OBJECTS:%=$(TEMP_DIR)/%)\n\n");
|
|
|
|
T_FileStream_writeLine(makefile,"$(TEMP_DIR)/%.o: $(TEMP_DIR)/%.c\n\t $(COMPILE.c) -o $@ $<\n\n");
|
|
|
|
T_FileStream_writeLine(makefile,"build-objs: $(SOURCES) $(OBJECTS)\n\n$(OBJECTS): $(SOURCES)\n\n");
|
|
|
|
#ifdef HPUX
|
|
T_FileStream_writeLine(makefile, "$(TARGETDIR)/$(FINAL_SO_TARGET): $(OBJECTS) $(HPUX_JUNK_OBJ) $(LISTFILES) $(DLL_DEPS)\n"
|
|
"\t$(SHLIB.cc) -o $@ $(OBJECTS) $(HPUX_JUNK_OBJ) $(DLL_LDFLAGS)\n"
|
|
"\t-ls -l $@\n\n");
|
|
|
|
T_FileStream_writeLine(makefile, "$(TEMP_DIR)/hpux_junk_obj.cpp:\n"
|
|
"\techo \"void to_emit_cxx_stuff_in_the_linker(){}\" >> $(TEMP_DIR)/hpux_junk_obj.cpp\n"
|
|
"\n"
|
|
"$(TEMP_DIR)/hpux_junk_obj.o: $(TEMP_DIR)/hpux_junk_obj.cpp\n"
|
|
"\t$(COMPILE.cc) -o $@ $<\n"
|
|
"\n");
|
|
#else
|
|
|
|
/*390port*/
|
|
#ifdef OS390BATCH
|
|
T_FileStream_writeLine(makefile, "$(BATCH_TARGET): $(OBJECTS) $(LISTFILES) $(DLL_DEPS)\n"
|
|
"\t$(SHLIB.c) -o $@ $(OBJECTS) $(DLL_LDFLAGS)\n"
|
|
"# \t-ls -l $@\n\n");
|
|
#endif
|
|
|
|
T_FileStream_writeLine(makefile, "$(TARGETDIR)/$(FINAL_SO_TARGET): $(OBJECTS) $(LISTFILES) $(DLL_DEPS)\n"
|
|
"\t$(SHLIB.c) -o $@ $(OBJECTS) $(DLL_LDFLAGS)\n"
|
|
"\t-ls -l $@\n\n");
|
|
#endif
|
|
|
|
T_FileStream_writeLine(makefile, "CLEANFILES= $(CMNLIST) $(OBJECTS) $(HPUX_JUNK_OBJ) $(TARGETDIR)/$(FINAL_SO_TARGET) $(TARGETDIR)/$(MIDDLE_SO_TARGET) $(TARGETDIR)/$(TARGET)\n\nclean:\n\t-$(RMV) $(CLEANFILES) $(MAKEFILE)");
|
|
T_FileStream_writeLine(makefile, "\n\n");
|
|
|
|
T_FileStream_writeLine(makefile, "install: $(TARGETDIR)/$(FINAL_SO_TARGET)\n"
|
|
"\t$(INSTALL-L) $(TARGETDIR)/$(FINAL_SO_TARGET) $(INSTALLTO)/$(FINAL_SO_TARGET)\n");
|
|
if (o->version) {
|
|
T_FileStream_writeLine(makefile, "\tcd $(INSTALLTO) && $(RM) $(MIDDLE_SO_TARGET) && ln -s $(FINAL_SO_TARGET) $(MIDDLE_SO_TARGET)\n\tcd $(INSTALLTO) && $(RM) $(SO_TARGET) && ln -s $(FINAL_SO_TARGET) $(SO_TARGET)\n");
|
|
}
|
|
T_FileStream_writeLine(makefile, "\n");
|
|
|
|
#ifdef U_SOLARIS
|
|
T_FileStream_writeLine(makefile, "$(NAME).map:\n\techo \"{global: $(TOCSYM); local: *; };\" > $@\n\n");
|
|
#endif
|
|
|
|
#ifdef AIX
|
|
T_FileStream_writeLine(makefile, "$(NAME).map:\n\techo \"$(TOCSYM)\" > $@\n\n");
|
|
#endif
|
|
|
|
|
|
*status = U_ZERO_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|