unexpected behavior of before_validation

Today I found these comments in active record's callbacks.rb file:

  # If the returning value of a before_validation callback can be
evaluated to false, the process will be aborted and Base#save will
return false.
  # If Base#save! is called it will raise a RecordNotSave error.
  # Nothing will be appended to the errors object.

This caused me a lot of frustration earlier when I was trying to get a
model with the following code to save:

  before_validation :ensure_boolean_value_for_finalized

  private
  def ensure_boolean_value_for_finalized
    self.finalized = false unless self.finalized
  end

I'm wondering why before_validation will abort the process of saving.
My conception of before_validation was that its purpose was only to
prepare the model object for validation, and that its purpose was
*not* to do pre-validation validation.

It's not a huge deal - I'm just wondering what the logic behind
before_validation's behavior is.

Daniel
http://www.hallwaytesting.com