Sha256: ee917653ef3e1309596176c29807fc2d4222eb2eac4189b0a76f8bd2c7ea622d

Contents?: true

Size: 1.21 KB

Versions: 2

Compression:

Stored size: 1.21 KB

Contents

require 'active_record/migration'

module Ridgepole
  module MigrationExt
    def self.prepended(klass)
      klass.class_eval do
        cattr_accessor :time_recorder
        cattr_accessor :disable_logging
      end
    end

    def write(text = '')
      logger = Ridgepole::Logger.instance
      logger.info(text) unless self.disable_logging
      parse_text(text)
    end

    def parse_text(text)
      return unless self.time_recorder

      case text
      when /\A--\s+(.+)\Z/
        self.time_recorder.add_key($1)
      when /\A\s+->\s+(\d+\.\d+)s\Z/
        self.time_recorder.add_value($1.to_f)
      end
    end

    def self.record_time
      result = nil

      begin
        self.time_recorder = TimeRecorder.new
        yield
        result = self.time_recorder.result
      ensure
        self.time_recorder = nil
      end

      result
    end

    class TimeRecorder
      attr_reader :result

      def initialize
        @result = {}
      end

      def add_key(key)
        @key = key
      end

      def add_value(value)
        if @key
          @result[@key] = value
        end

        @key = nil
      end
    end
  end
end

module ActiveRecord
  class Migration
    prepend Ridgepole::MigrationExt
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
ridgepole-0.6.4.beta8 lib/ridgepole/migration_ext.rb
ridgepole-0.6.4.beta7 lib/ridgepole/migration_ext.rb