Skip to main content

Moving on to Ivy.

Maven has its share of success, at the same time it has some shortcomings. Many felt the Idea was right, the implementation was not. There were a few rants too. Project Ivy was started on that note. Today, Everyone is talking about Ivy and How Ivy can fix your woes from maven.

So, I began to test drive Ivy. Ivy has got pretty good documentation. And the edge over maven is, that you dont have to adapt your project to it (like maven). You can make ivy adapt to your project. All you need to start is a jar to put in your ant lib folder. The examples list a mighty hard way of starting with ivy - So I modified a little bit to get it easy and install ivy automatically. Also this can be used as a template build.xml file for starting from scratch :)

<!-- Use namespace even before bootstrap -->
<project xmlns:ivy="antlib:org.apache.ivy.ant" default="build" name="SarathPOC">
 <property file="" />

 <path id="compile.path">
  <fileset dir="${lib.dir}/compile" />
 <path id="runtime.path">
  <path location="${build.dir}" />
  <fileset dir="${lib.dir}/compile" />
  <fileset dir="${lib.dir}/runtime" />

 <target name="-download-ivy" unless="">
  <!-- Download directly (and skip if it exists or if instructed) -->
  <get src="${ivy.install.version}/ivy-${ivy.install.version}.jar" dest="${ant.library.dir}\ivy.jar" usetimestamp="true" />

 <target name="compile" depends="-download-ivy" description="Compile Project, Download Ivy Dependencies">
  <ivy:retrieve pattern="${lib.dir}/[artifact]-[revision].[ext]" />

 <target name="clean">
  <delete includeemptydirs="true" failonerror="false">
   <fileset dir="${build.dir}" />
   <fileset dir="${lib.dir}" />

 <target name="build" depends="-download-ivy,clean,compile">
  <mkdir dir="${build.dir}" />
  <javac srcdir="${src.dir}" destdir="${build.dir}" classpathref="runtime.path" />
Thats is it, Ivy is installed. If you want to download manually, you can go to the main site. It includes examples.

From here, you could jump start, understand dependency resolution. I am looking at these two for today. However, There is more to Ivy - mainitaing your repositories, Resolvers and Chaining them etc. May be after I get hooked in?

Popular posts from this blog

Javascript: Convert Strings to Binary (and representing in a nerdy way!)

I follow those GoogleDevelopers Videos . Sometime back, in one of the presentations on GoogleIO, there was this interesting string of dots at the bottom of each page of the presentation . They looked like random big and small dots. A similar bunch of dots were also on the T-shirt of a presenter was wearing in another presentation . While it seemed something in the pattern, I could not find what it was. Finally, another presenter cleared the matter that those dots are just binary representation of "GOOGLEIO" (So much for advertizing Google IO, Impressive!). So I wanna do it. Takes me back to days of those DSP classes at school. Nerdy me had to churn some old brain cells. I remember those first programming language classes in Pascal and C when you were asked to do fibonacci series and converting a binary string to ascii codes. That *experience* came handy here: Check it out! Text to Binarize: For those who came to copy the javascript code to convert string to binary,

MySql Copying Table Structures.

Some times you need to copy only table structures across databases. This article describes two ways of doing it. If the whole database schema need to be exported, mysqldump is very effective. A --nodata flag will dump all tables' schema. Like this. mysqldump --nodata -p -u username databaseName But if you want to copy a specific table, individually, you could use "create table like" feature. You could create it even from a different database. However it must be on the same mysqld instance. Like this. create table newtable like oldtable; --Or from a table in other database create table mytable like otherdatabase.tablename;

Add jquery in Chrome console

Many a time, a page you are debugging doesnot have jquery. This simple js will add(or prompt you to overwrite) jquery to any page from chrome console. javascript:if(!window.jQuery||confirm('Overwrite\x20current\x20version?\x20v'+jQuery.fn.jquery))(function(d,s){s=d.createElement('script');s.src='';(d.head||d.documentElement).appendChild(s)})(document);