Refactoring JavaFX Builds & Sources

Anthony Petrov anthony.petrov at oracle.com
Fri Oct 19 07:58:02 PDT 2012


On 10/19/2012 6:34 PM, Richard Bair wrote:
>> On 10/18/2012 11:16 PM, Richard Bair wrote:
>>> In addition to code generation, we also build a ton of native code (gstreamer, webkit, prism, fonts, glass, image loading). So that has to fit into the build system. Building native code is SLOW, so being able to avoid it for "normal" developers, and being able to avoid native builds when nothing changed in the native code, is important.
>> Building native code may be slow in general, but building e.g. Glass takes under a minute. Of course I agree that if code hasn't changed, it shouldn't be re-built.
>>
>> One more point: presently we can clone the repository and build just glass itself (which is very fast as I mentioned above). This is useful for quick testing, and also we have a Glass-only demo app that doesn't depend on FX, so we can work on Glass w/o even building the whole FX right now. Can we make the new build system support this kind of partial builds (at least for Glass)?
> 
> I don't know that compilation time is actually going to be a problem in practice. I already have the prototype build setup to build all of base, graphics (which is Scene Graph + Prism + Glass), and controls and it only takes a few seconds on my machine, which is saying something, because my machine has a very slow harddrive and chronically long build times. I also expect there will be build targets for only building specific native parts, so you could say something like:
> 
> gradle :graphics compile-glass-native
> 
> and it would only compile the glass natives. In that case, I think you still have the ability to just clone, compile the natives, and run rain.

Using partial build targets sounds interesting. Let's see how it will 
look in the end.

But for some reason I can't believe (I wish!) it takes just a few 
seconds for your builds. Are you only compiling java code, or does this 
also include the native libs in prism/glass as well? On what platform 
are you currently testing?

>> Another point: I see that the ultimate goal is to be able to build from an IDE, and this is fine. However, I think that building from command line should still be supported and not require any more than it requires now (which is basically just `cd to-my-repo && ant`).
> 
> Yes, I think that goes without saying. Gradle (and Maven) are fully controllable / usable from the command line.

Good to know this.

--
best regards,
Anthony


More information about the openjfx-dev mailing list