How I work with Lift.
Something I enjoy very much is teaching, specially when Lift is involved. Mainly because I learn a lot by teaching others, and secondly because I have learned a lot thanks to those who spent the time to either teach me directly, or indirectly through blog posts, articles, etc.
Since I joined Elemica about 9 months ago, I have spent a good amount of time sharing what I know about Lift, Scala and web security with my team members. And today I'd like to talk about my work setup. I'll cover some simple tips about SBT and Intellij.
IDE and Build tool.
My IDE of choice is IntelliJ IDEA with the Scala plugin. You will find that people use all kinds of IDEs, I tried a few, and I'm sticking with IDEA.
For building my Lift applications, I use SBT 0.12 (I just noticed that there is a newer version, 0.13).
And to have SBT and IntelliJ play nicely together, I use the SBT IDEA plugin
I find reading the Lift source code very helpful, so I always keep a clone of the framework repository on my laptop, and I add this project to Intellij, so I can switch from my current project to the framework project, and have full access to navigation/search/etc.
git clone git://github.com/lift/framework.git cd framework ./liftsh gen-idea //assuming you added the IDEA-sbt plugin to your global file in ~/.sbt/plugins/build.sbt
You can now open the framework project in Intellij, and it will let you navigate the source, etc.
I always have a few terminal tabs open (an average of 8), one tab runs sbt, and another is open so I can work with git.
On SBT, the 3 most used commands I use are:
1. ~compile 2. ;container:stop;container:start 3. ~test-only com.my.company.snippet.MyClassSpecs
When I'm starting with a new snippet, I want to make sure it compiles, and I'm not so interested in anything else. This is when I just have sbt running
~compile. You can say that there is no need for this, as Intellij will mark your invalid code as red, but I started with IntelliJ when you used to get a lot of code marked as red, but it worked just fine under sbt. Now this isn't as common, but I still prefer
Once the basic code is in place and I think it does what I want it to, I go and start jetty with
;container:stop;container:start, now, you may wonder why I have
container:stop in there, well, most of the time the snippet doesn't do what I expected, so I have to restart jetty, by using
;container:stop;container:start in the first place, I can simply press the arrow up on my keyboard followed by enter and after a second or two I'm back with the new code on the browser.
Some people like using jRebel, to avoid having to restart the server, you can give it a try and hopefully it will work for you.
I remember my first year or so with Lift, I would restart jetty so many times to get simple snippets to work, was frustrating, but over time, you get to a point where you don't need that many iterations to get the desired result, so by now I don't see the need for jRebel in my setup.
While I use Google Chrome for all my web browsing, I use Firefox (with the Firebug plugin) for testing my Lift applications.
Why? Because I find it quicker to press
command + tab (mac) to go from the browser with the Lift application to Chrome with some google search/documentation/etc, to IntelliJ, to the terminal. So I have one, maybe two tabs in Firefox, and then about 5-10 tabs in Chrome.
The second reason is that I find Firebug a lot easier to use than the Chrome developer tools.
This only applies to those who use a laptop to work, and no external monitor. The only application that is fully maximized is the terminal, and the tab that is active most of the time is the one running sbt, then the browsers/IntelliJ/etc are almost maximized, but the lower area is pulled up just enough so that I can see if sbt gave me a compiler error, or a test failure. This saves me the need to switch screens as I try different things on my snippet code.
There is a lot more that goes on in a normal day with Scala and Lift, but this is enough for this post, I hope you find some of it useful, but at the end of the day, you need to find what works best for you, this is just my opinionated setup.