Awesome
formic
Allows using String.format() on GWT simply by changing to Stringf.format().
Ever ported some Java code to run on GWT and found there's no counterpart for String.format()
?
Well, now there's this. If you change String.format()
calls to Stringf.format()
calls, formic
will delegate at minimal (possibly 0) cost to String.format()
when it is available natively, or
call a JS library, format4js, when running on GWT. Using
format4js means the hard work is done, so most of this library is a wrapper.
Install
tl;dr version for libGDX users
//dependency of core module
api 'com.github.tommyettinger:formic:0.1.5'
//dependency of html module
api 'com.github.tommyettinger:formic:0.1.5:sources'
And in your GdxDefinition.gwt.xml
<inherits name="formic" />
Longer instructions for other usage
Using this needs a little bit of setup before the application will run correctly.
You can add a dependency on formic using your build tool (probably Gradle, but Maven should work
too). Maven Central is now supported; see the
right sidebar here
for Gradle and Maven instructions. If you want a newer commit, you can also use
JitPack.io. Choosing release v0.1.5 should be good,
or you can instead pick a commit. JitPack shows instructions when you click "Get it" on a commit
or release, and you probably need to add JitPack as a repository as well as to add the given
dependency to your core project (if you have a project that is GWT-agnostic). Regardless of whether
you use Maven Central or JitPack.io, you should also add a dependency to your GWT project (or only
project, if you just have GWT as a target); this is the same as the dependency JitPack or Maven
Central lists but has :sources
appended after the version for Gradle, or
<classifier>sources</classifier>
for Maven. JitPack and Maven Central always show the
dependencies as using implementation
, but older Gradle needs compile
instead, or if you have a
core project with recent Gradle, api
may be correct instead. The last setup step is to add a GWT
inherit line to your .gwt.xml
file, such as GdxDefinition.gwt.xml
:
<inherits name="formic" />
Now you're ready to write code. I hope the setup wasn't too bad...
API
In your Java code, text.formic.Stringf
has one static method,
format(String, Object...)
that should act almost exactly like Java's
java.lang.String.format(String, Object...)
even on GWT. Some features aren't supported, namely
%h
, %H
(hashCode() results), %tN
, %TN
(nanosecond time), %tZ
, %TZ
(time zone), %tc
,
and %Tc
(full date and time string). Using Stringf.format() in non-GWT code will simply
delegate to String.format(); using it in GWT will use a super-sourced alternative implementation.
The super-sourcing relies on format4js (technically, a modified version that allows better
transfer from Java) and does almost no work of its own.
Credits
Most of the credit here goes to Hidenori Sugiyama, who made format4js. The implementation for hexadecimal floating-point syntax is the work of Dan Kogai. The team behind vue-gwt also deserves significant credit for both the utility code that made some parts of this feasible and the injection code that obviates the need for separate JavaScript and HTML configuration. All of these projects are MIT-licensed. Thanks also to early testers, like damios!
Version History
- 0.1.1
- Initial working release; Strings, integers and some floating-point formats work correctly.
- 0.1.2
- Improved handling of hex floats (
%A
or%a
syntax) from previously-unusable to now matching Java.
- Improved handling of hex floats (
- 0.1.3
- Now Formic converts any
long
orLong
values that it is given todouble
, because GWT doesn't allow using longs from JS, plus, it convertsjava.util.Date
objects to their JS equivalents, allowing date/time conversions to work with them. Java'sjava.util.Calendar
is not converted because GWT doesn't support it.
- Now Formic converts any
- 0.1.4
- Bugfix release: the GWT
inherits
has changed, and is nowformic
instead oftext.formic
. This improves compatibility with frequently-used project layouts, and allows builds to work more reliably.
- Bugfix release: the GWT
- 0.1.5
- Update dependencies on GWT-related libraries to stable (non-release-candidate) versions.
- Build improvements.
- Gradle 8.6
- jsinterop:base 1.0.1
- elemental2 1.2.1
- GWT 2.11.0 worked already.
- JitPack is able to build again.
- Future release goals
- Stress-test all the unusual features and check for equivalence with Java.