The defaults in Rails with ActiveRecord is beautiful when you are just getting started and are created everything for the first time. But once you get into it and your database schema becomes a little more solidified, the things that would have been easy to do by relying on the conventions of Rails require a little bit more work.

In my case, I had a form where there was a database column named “num_guests”, representing the number of guests. When the field fails to pass validation, the error messages is something like

Num guests is not a number

Not quite the text that we want. It would be better if it said

Number of guests is not a number

After doing a little bit of digging, I found the human_attribute_name method. You can override this method in your model class to provide alternative names for fields. To change our error message, I did the following

class Reservation < ActiveRecord::Base
...
validates_presence_of :num_guests
...
HUMAN_ATTRIBUTES = {
:num_guests => “Number of guests”
}

def self.human_attribute_name(attr)
HUMAN_ATTRIBUTES[attr.to_sym] || super
end
end

(taken from http://www.theodorenguyen-cao.com/2009/04/06/custom-field-names-in-rails-error-messages/)

Written on April 22nd, 2009 & filed under SciTech

Firefox3 stores a lot of info in sqlite3 databases. Optimizing those databases can speed up load time and reduce the file sizes of these files as well.

On linux or os x, go to your profile directory (Library/Application Support/Firefox/Profiles/ or .firefox/profiles/ ) and execute the following:

for i in *.sqlite; do echo “VACUUM;” | sqlite3 $i ; done

This reduced my places.sqlite file to 10% of its previous size.

Written on April 13th, 2009 & filed under SciTech Tags:

From Yoga Journal

Written on April 10th, 2009 & filed under Posts from Afar, Sailing and Sailboats