csscompass-sasssass

Add timestamps to compiled sass/scss


Is it possible to automatically add a timestamp on the compiled CSS file using SASS? e.g.

/* CSS Compiled on: {date+time} */
...compiled css goes here...

I've checked the SASS and Compass docs but no mention of such a feature.


Solution

  • I don't know of any built-in SASS or Compass feature for this, but it's not too hard to add a custom Ruby function to do it. (See the section entitled "Adding Custom Functions" in the SASS reference here.)

    Your file with the Ruby function would look like this (let's call it "timestamp.rb"):

    module Sass::Script::Functions
        def timestamp()
            return Sass::Script::String.new(Time.now.to_s)
        end
    end
    

    And you'd reference the new timestamp function in your SASS file like this:

    /*!
     * CSS Compiled on: #{timestamp()}
     */
    

    You just need to make sure your "timestamp.rb" file is loaded when you compile the SASS, either by requiring it from a Compass config file, or by using the --require parameter with the SASS command line. When all is said and done, you should get output like the following:

    /*
     * CSS Compiled on: 2012-10-23 08:53:03 -0400
     */