]> git.saurik.com Git - apple/icu.git/blob - icuSources/extra/uconv/makedata.mak
ICU-64232.0.1.tar.gz
[apple/icu.git] / icuSources / extra / uconv / makedata.mak
1 # Copyright (C) 2016 and later: Unicode, Inc. and others.
2 # License & terms of use: http://www.unicode.org/copyright.html
3 #**********************************************************************
4 #* Copyright (C) 1999-2008, International Business Machines Corporation
5 #* and others. All Rights Reserved.
6 #**********************************************************************
7 # nmake file for creating data files on win32
8 # invoke with
9 # nmake /f makedata.mak icup=<path_to_icu_instalation> [Debug|Release]
10 #
11 # 12/10/1999 weiv Created
12
13 #If no config, we default to debug
14 !IF "$(CFG)" == ""
15 CFG=Debug
16 !MESSAGE No configuration specified. Defaulting to common - Win32 Debug.
17 !ENDIF
18
19 #Here we test if a valid configuration is given
20 !IF "$(CFG)" != "Release" && "$(CFG)" != "release" && "$(CFG)" != "Debug" && "$(CFG)" != "debug" && "$(CFG)" != "x86\Release" && "$(CFG)" != "x86\Debug" && "$(CFG)" != "x64\Release" && "$(CFG)" != "x64\Debug"
21 !MESSAGE Invalid configuration "$(CFG)" specified.
22 !MESSAGE You can specify a configuration when running NMAKE
23 !MESSAGE by defining the macro CFG on the command line. For example:
24 !MESSAGE
25 !MESSAGE NMAKE /f "makedata.mak" CFG="Debug"
26 !MESSAGE
27 !MESSAGE Possible choices for configuration are:
28 !MESSAGE
29 !MESSAGE "Release"
30 !MESSAGE "Debug"
31 !MESSAGE
32 !ERROR An invalid configuration is specified.
33 !ENDIF
34
35 #Let's see if user has given us a path to ICU
36 #This could be found according to the path to makefile, but for now it is this way
37 !IF "$(ICUP)"==""
38 !ERROR Can't find path!
39 !ENDIF
40 !MESSAGE ICU path is $(ICUP)
41
42 RESNAME=uconvmsg
43 RESDIR=resources
44 RESFILES=resfiles.mk
45 ICUDATA=$(ICUP)\data
46
47 DLL_OUTPUT=.\$(CFG)
48 # set the following to 'static' or 'dll' depending
49 PKGMODE=static
50
51 ICD=$(ICUDATA)^\
52 DATA_PATH=$(ICUP)\data^\
53
54 !IF "$(CFG)" == "x64\Release" || "$(CFG)" == "x64\Debug"
55 ICUTOOLS=$(ICUP)\bin64
56 PATH = $(ICUP)\bin64;$(PATH)
57 !ELSE
58 ICUTOOLS=$(ICUP)\bin
59 PATH = $(ICUP)\bin;$(PATH)
60 !ENDIF
61
62 # Make sure the necessary tools exist before continuing. (This is to prevent cryptic errors from NMAKE).
63 !IF !EXISTS($(ICUTOOLS)\pkgdata.exe)
64 !MESSAGE Unable to find "$(ICUTOOLS)\pkgdata.exe"
65 !ERROR The tool 'pkgdata.exe' does not exist! (Have you built all of ICU yet?).
66 !ENDIF
67 !IF !EXISTS($(ICUTOOLS)\genrb.exe)
68 !MESSAGE Unable to find "$(ICUTOOLS)\genrb.exe"
69 !ERROR The tool 'genrb.exe' does not exist! (Have you built all of ICU yet?).
70 !ENDIF
71
72 # Suffixes for data files
73 .SUFFIXES : .ucm .cnv .dll .dat .res .txt .c
74
75 # We're including a list of resource files.
76 FILESEPCHAR=
77
78 !IF EXISTS("$(RESFILES)")
79 !INCLUDE "$(RESFILES)"
80 !ELSE
81 !ERROR ERROR: cannot find "$(RESFILES)"
82 !ENDIF
83 RES_FILES = $(RESSRC:.txt=.res)
84 RB_FILES = resources\$(RES_FILES:.res =.res resources\)
85 RESOURCESDIR=
86
87 # This target should build all the data files
88 !IF "$(PKGMODE)" == "dll"
89 OUTPUT = "$(DLL_OUTPUT)\$(RESNAME).dll"
90 !ELSE
91 OUTPUT = "$(DLL_OUTPUT)\$(RESNAME).lib"
92 !ENDIF
93
94 ALL : $(OUTPUT)
95 @echo All targets are up to date (mode $(PKGMODE))
96
97
98 # invoke pkgdata - static
99 "$(DLL_OUTPUT)\$(RESNAME).lib" : $(RB_FILES) $(RESFILES)
100 @echo Building $(RESNAME).lib
101 @"$(ICUTOOLS)\pkgdata" -f -v -m static -c -p $(RESNAME) -d "$(DLL_OUTPUT)" -s "$(RESDIR)" <<pkgdatain.txt
102 $(RES_FILES:.res =.res
103 )
104 <<KEEP
105
106 # This is to remove all the data files
107 CLEAN :
108 -@erase "$(RB_FILES)"
109 -@erase "$(CFG)\*uconvmsg*.*"
110 -@"$(ICUTOOLS)\pkgdata" -f --clean -v -m static -c -p $(RESNAME) -d "$(DLL_OUTPUT)" -s "$(RESDIR)" pkgdatain.txt
111
112 # Inference rule for creating resource bundles
113 {$(RESDIR)}.txt{$(RESDIR)}.res:
114 @echo Making Resource Bundle files
115 "$(ICUTOOLS)\genrb" -s $(@D) -d $(@D) $(?F)
116
117 $(RESSRC) : {"$(ICUTOOLS)"}genrb.exe