Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
Openfire
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
Openfire
Commits
0106ecfc
Commit
0106ecfc
authored
Sep 28, 2015
by
Guus der Kinderen
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #294 from guusdk/OF-947
OF-947: Overlay should be able to modify i18n
parents
0566166e
c3541fcc
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
56 additions
and
38 deletions
+56
-38
build.xml
build/build.xml
+49
-20
jugbbant-1.7.jar
build/lib/ant/jugbbant-1.7.jar
+0
-0
overlay.html
documentation/docs/overlay.html
+7
-18
No files found.
build/build.xml
View file @
0106ecfc
...
...
@@ -69,7 +69,7 @@
<property
name=
"overlay.web.dir"
value=
"${overlay.dir}/webapp"
/>
<property
name=
"overlay.lib.dir"
value=
"${overlay.dir}/lib"
/>
<property
name=
"overlay.conf.dir"
value=
"${overlay.dir}/conf"
/>
<property
name=
"overlay.
properties.file"
value=
"overlay.properties
"
/>
<property
name=
"overlay.
i18n.dir"
value=
"${overlay.dir}/i18n
"
/>
<property
name=
"overlay.compile.dir"
value=
"${work.dir}/overlay/classes"
/>
<property
name=
"javadoc.src.dir"
value=
"${src.dir}/javadoc"
/>
...
...
@@ -137,6 +137,9 @@
<taskdef
name=
"xmltask"
classname=
"com.oopsconsultancy.xmltask.ant.XmlTask"
>
<classpath
refid=
"ant.dependencies"
/>
</taskdef>
<taskdef
name=
"propertymerge"
classname=
"org.jugbb.ant.propertymerge.PropertyMergeTask"
>
<classpath
refid=
"ant.dependencies"
/>
</taskdef>
<typedef
name=
"srcinc"
classname=
"com.jivesoftware.tools.selector.IncludeSourceSelector"
>
<classpath
refid=
"ant.dependencies"
/>
</typedef>
...
...
@@ -150,7 +153,7 @@
<available
type=
"dir"
file=
"${overlay.web.dir}"
property=
"overlay.web.dir.found"
/>
<available
type=
"dir"
file=
"${overlay.lib.dir}"
property=
"overlay.lib.dir.found"
/>
<available
type=
"dir"
file=
"${overlay.conf.dir}"
property=
"overlay.conf.dir.found"
/>
<available
type=
"
file"
file=
"${overlay.properties.file}"
property=
"overlay.properties.file
.found"
/>
<available
type=
"
dir"
file=
"${overlay.i18n.dir}"
property=
"overlay.i18n.dir
.found"
/>
<!-- When overlay is used the content of "lib.merge.dir" needs to be combined with the content of "overlay.lib.dir"
Here, "libs.to.merge" is created which will always refer to the correct combination. "libs.to.merge" should be
...
...
@@ -326,21 +329,50 @@
<!-- i18n ================================================================================== -->
<!-- Note, this is a "private" target - no need to call it externally -->
<target
name=
"-i18n"
>
<!-- Auto generates a default base i18n file -->
<mkdir
dir=
"${target.i18n.dir}"
/>
<copy
file=
"${src.i18n.dir}/${i18n.basename}_${i18n.default.locale}.properties"
<if>
<equals
arg1=
"${overlay.i18n.dir.found}"
arg2=
"true"
/>
<then>
<!-- Overlay files exist for i18n: append/override the files that ship with Openfire. -->
<foreach
target=
"-i18n-overlay"
param=
"i18n-propertyfile"
>
<path>
<fileset
dir=
"${src.i18n.dir}"
>
<include
name=
"${i18n.basename}*.properties"
/>
</fileset>
</path>
</foreach>
</then>
<else>
<!-- No overlay for i18n: simply copy all files. -->
<copy
todir=
"${target.i18n.dir}"
>
<fileset
dir=
"${src.i18n.dir}"
includes=
"*.properties"
/>
</copy>
</else>
</if>
<!-- Auto generates a default base i18n file -->
<copy
file=
"${target.i18n.dir}/${i18n.basename}_${i18n.default.locale}.properties"
tofile=
"${target.i18n.dir}/${i18n.basename}.properties"
/>
<!-- if title override file exists, overwrite all i18n files -->
</target>
<!-- Note, this is a "private" target - no need to call it externally -->
<target
name=
"-i18n-overlay"
>
<basename
property=
"filename"
file=
"${i18n-propertyfile}"
/>
<if>
<
equals
arg1=
"${overlay.properties.file.found}"
arg2=
"true
"
/>
<
available
file=
"${overlay.i18n.dir}/${filename}
"
/>
<then>
<property
file=
"${overlay.properties.file}"
/>
<replace
dir=
"${target.i18n.dir}"
>
<replacefilter
token=
"title = Wildfire"
value=
"title=${title}"
/>
<replacefilter
token=
"short.title = Wildfire"
value=
"short.title=${short.title}"
/>
</replace
>
<property
merge
inputpropertyfile=
"${src.i18n.dir}/${filename}"
mergepropertyfile=
"${overlay.i18n.dir}/${filename}"
outputpropertyfile=
"${target.i18n.dir}/${filename}"
ignoreMissingMergeFile=
"true"
/
>
</then>
<else>
<copy
file=
"${src.i18n.dir}/${filename}"
tofile=
"${target.i18n.dir}/${filename}"
/>
</else>
</if>
</target>
...
...
@@ -387,7 +419,6 @@
<!-- Make main Openfire jar -->
<jar
jarfile=
"${jar.dest.dir}/${jar.name}"
index=
"true"
duplicate=
"preserve"
>
<fileset
dir=
"${compile.dir}"
includes=
"**/*.class"
excludes=
"org/jivesoftware/openfire/starter/ServerStarter*.class,org/jivesoftware/openfire/launcher/*.class"
/>
<fileset
dir=
"${src.i18n.dir}"
includes=
"*.properties"
/>
<fileset
dir=
"${target.i18n.dir}"
includes=
"*.properties"
/>
<fileset
dir=
"${resources.dir}/jar"
includes=
"**"
/>
<archives>
...
...
@@ -886,7 +917,6 @@
<!-- Copy the i18n files to the resources dir. This way they won't be in the jar only -->
<copy
todir=
"${release.src.out.dir}/resources/i18n"
>
<fileset
dir=
"${target.i18n.dir}"
includes=
"*.properties"
/>
<fileset
dir=
"${src.i18n.dir}"
includes=
"*.properties"
/>
</copy>
<!-- Copy build -->
<copy
todir=
"${release.src.out.dir}/build"
>
...
...
@@ -972,7 +1002,6 @@
<!-- Copy the i18n files to the resources dir. This way they won't be in the jar only -->
<copy
todir=
"${release.out.dir}/resources/i18n"
>
<fileset
dir=
"${target.i18n.dir}"
includes=
"*.properties"
/>
<fileset
dir=
"${src.i18n.dir}"
includes=
"*.properties"
/>
</copy>
<!-- Package the release -->
...
...
build/lib/ant/jugbbant-1.7.jar
0 → 100644
View file @
0106ecfc
File added
documentation/docs/overlay.html
View file @
0106ecfc
...
...
@@ -29,12 +29,12 @@
<h2><a
name=
"mysql"
>
File Structure
</a></h2>
<p>
To cusomize files, create the following file structure in your
<tt>
openfireHome
</tt>
<p>
To cus
t
omize files, create the following file structure in your
<tt>
openfireHome
</tt>
directory (where all the source files are on your filesystem).
</p>
<pre>
custom/
| -
overlay.properties
<
- Properties file to replace text in i18n files (optional)
| -
i18n/
<
- Directory to place translation files to be overridden
| - conf/
<
- Directory to place configuration files to be overridden
| - lib/
<
- Directory to place any private or 3rd prty jar files
| - source/
<
- Directory to place java source files to be overridden
...
...
@@ -74,24 +74,13 @@
functionality to bundle these changes in a separate jar file.
</p>
<h2>
Overlay Properties File
</h2>
<p>
The i18n files have been modified to be as generic as possible (not to mention this project
by name). In cases where that could not be avioded, two keys are responsible. We have
made it possible to modify these keys by means of an optional properties file,
<tt>
overlay.properties
</tt>
which you place in your
<tt>
custom/
</tt>
folder. If you want to override these
default properties just create this file. The build will continue to work if you haven't
created the file.
</p>
<p>
The overlay.properties file will currently replace the following keys in the i18n files.
Note: this properties file should follow the java.util.Properties text file format.
The texts that are used in the administration panel (as well as some other texts) are taken from various
translation files under the
<tt>
src/i18n
</tt>
directory. To customize such a file, a file by the same name
can be added in the
<tt>
custom/i18n
</tt>
directory. The build process will merge both files, which you to
add your own properties, as well as override existing properties, without the need to copy all properties
that aren't of interest to you.
</p>
<ul>
<li><em>
title
</em>
- Title key (usually in the title bar of an HTML page)
</li>
<li><em>
short.title
</em>
- Short title, also used frequently
</li>
</ul>
<h2>
Build
</h2>
<p>
Simply build the application as normal. You may need to run the ant
<tt>
clean
</tt>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment