Skip to main content

What is a better, simpler and more modern way to build Java Web Applications compared to Maven?


I'm thinking of getting rid of Maven. It's alright for simple applications, but I'm running into problems that I can't solve, nobody else seems to be able to solve them, and even the Maven mailing list doesn't have a solution.



What are some modern build tools for Java that provide what Maven provides, but also are equipped to deal with the challenges of making modern web applications? For example, if I want to use a Javascript minification tool, such as the YUI compressor, it will easily and effortlessly let me compress/aggregate my css and javascript just before the War file is created.





  • Explanation : The problem with maven is that there is no way to do things inside of the war plugin. For example, I want to call the yui compressor just after it copies over the webapp's resources (css, images, javascripts, etc.). If I could do this, it would ensure that any uncompressed javascript files (that were excluded in the YUI compressor's minification/aggregation process) were part of the final war package. This is not possible



    The YUI compressor only works if you plan on compressing and/or aggregating all your files as opposed to a subset. There are javascript files like jscharts.js where you need to exclude them from the minification process because they otherwise mess up the actual source code. There is no way to deal with this use-case in Maven, even though the solution is simple.





Having the ability to use live javascript vs. compressed/aggregated javascript would also be a big boon.





  • Explanation : It's also hard to refactor your massive javascript includes with those in your html files. Let's say you have 100 javascript files, and you want the ability to use your live javascript files for development, but you want to use the compressed/aggregated ones for production. You still need to include all the javascript files in your html templates (freemarker for example) because you want to deal with the live ones during development. For production, you also have to maintain a separate list in the maven pom.xml as well, in order to aggregate them.



    Both of these lists of javascript files are basically identical, and it's an extra burden for the developer to ensure they include the same files and in the same order :( Maven isn't helping with such a common web-related problem for year 2011. The Rails 3.1 folks though get this for free. We can do better.





I still need the ability to have filters, just like in maven, to handle different production environments. For example, I often use property files to change values in the applicationContext.xml for Spring, or the servlet context.



I also need the ability to add resources to the classpath. I have these massive text files that provide me with the basic functionality of a dictionary, thesaurus, etc. I need to put these in my classpath.



It would be great if the build tool also used the Maven repositories.



Any other benefits, such as more simplicity and writing less configuration code would be a plus, but the features I listed above are paramount.



Thank you.


Source: Tips4allCCNA FINAL EXAM

Comments

  1. You ought to be able to do all of that in Gradle. Essentially, its a set of libraries and modules in Groovy that give you a lot of power for putting together your build. If you need to extend it, then you write your extension in Groovy. Its quite nice.

    ReplyDelete
  2. If you are into learning Scala then I highly recommend SBT. We use it to build all our Java code and have been perfectly happy with it. It does neat things such as parallel builds and unlike ANT/Maven its incremental compilation actually seams to work. Also it includes a nice REPL that allows you to interact directly with the build and your code.

    SBT is easy to extend as it's build files are written in code rather than XML. So plugins exists for everything your heart can desire, for example:


    YUI compressor
    CoffeeScript


    As for project dependencies, these can be both managed (downloaded automatically from Maven/Ivy) or unmanaged (i.e. resources (jar's, files, ...) you add yourself) - they can also be mixet and matched.

    SBT uses the standard Maven directory layout (although this can easily be changed), has great support for IDE's (fx. Eclipse and Idea) and it can also produce a pom file for you if you should so desire.

    There is a very good guide to get you started quickly with SBT here

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.