README.txt
1*********************************************************************
2*** © 2019 and later: Unicode, Inc. and others. ***
3*** License & terms of use: http://www.unicode.org/copyright.html ***
4*********************************************************************
5
6What is this directory and why is it empty?
7-------------------------------------------
8
9This is the root of a local Maven repository which needs to be populated before
10code which uses the CLDR data API can be executed.
11
12To do this, you need to have a local copy of the CLDR project configured on your
13computer and be able able to build the API jar file and copy an existing utility
14jar file. In the examples below it is assumed that $CLDR_ROOT references this
15CLDR release.
16
17Setup
18-----
19
20This project relies on the Maven build tool for managing dependencies and uses
21Ant for configuration purposes, so both will need to be installed. On a Debian
22based system, this should be as simple as:
23
24$ sudo apt-get install maven ant
25
26
27Installing the CLDR API jar
28---------------------------
29
30From this directory:
31
32$ ./install-cldr-jars.sh "$CLDR_DIR"
33
34
35Manually installing the CLDR API jar
36------------------------------------
37
38Only follow these remaining steps if the installation script isn't suitable or
39doesn't work on your system.
40
41To regenerate the CLDR API jar you need to build the "jar" target manually
42using the Maven pom.xml file in the "tools" directory of the CLDR project:
43
44$ cd "$CLDR_ROOT/tools"
45$ mvn package -DskipTests=true
46
47This should result in the cldr-code.jar file being built into the cldr-code/target
48sub-directory, which can then be installed as a Maven dependency as described above.
49
50
51Updating local Maven repository
52-------------------------------
53
54To update the local Maven repository (e.g. to install the CLDR jar) then from
55this directory (lib/) you should run:
56
57$ mvn install:install-file \
58 -Dproject.parent.relativePath="" \
59 -DgroupId=org.unicode.cldr \
60 -DartifactId=cldr-api \
61 -Dversion=0.1-SNAPSHOT \
62 -Dpackaging=jar \
63 -DgeneratePom=true \
64 -DlocalRepositoryPath=. \
65 -Dfile="$CLDR_ROOT/tools/cldr-code/target/cldr-code.jar"
66
67And if you have updated one of these libraries then from this directory run:
68
69$ mvn dependency:purge-local-repository \
70 -Dproject.parent.relativePath="" \
71 -DmanualIncludes=org.unicode.cldr:cldr-api:jar
72
73After doing this, you should see something like the following list of files in
74this directory:
75
76README.txt <-- this file
77org/unicode/cldr/cldr-api/maven-metadata-local.xml
78org/unicode/cldr/cldr-api/0.1-SNAPSHOT/maven-metadata-local.xml
79org/unicode/cldr/cldr-api/0.1-SNAPSHOT/cldr-api-0.1-SNAPSHOT.pom
80org/unicode/cldr/cldr-api/0.1-SNAPSHOT/cldr-api-0.1-SNAPSHOT.jar
81
82Finally, if you choose to update the version number of the snapshot, then also
83update all the the pom.xml files which reference it (but this is unlikely to be
84necessary).
85
86Troubleshooting
87---------------
88
89While the Maven system should keep the CLDR JAR up to date, there is a chance
90that you may have an out of date JAR installed elsewhere. If you have any
91issues with the JAR not being the expected version (e.g. after making changes)
92then run the above "purge" step again, from this directory.
93
94This should re-resolve the current JAR snapshot from the repository in this
95directory. Having purged the Maven cache, next time you build a project, you
96should see something like:
97
98[exec] Downloading from <xxx>: <url>/org/unicode/cldr/cldr-api/0.1-SNAPSHOT/maven-metadata.xml
99[exec] [INFO] Building jar: <path-to-icu-root>/tools/cldr/cldr-to-icu/target/cldr-to-icu-1.0-SNAPSHOT-jar-with-dependencies.jar
100
101This shows that it has had to re-fetch the JAR file.
102