Sha256: 18c71525c65d3120c7e8dab2a809f239330d1dfc2ecebcbe36bb37f92c24ef9f

Contents?: true

Size: 1.88 KB

Versions: 22

Compression:

Stored size: 1.88 KB

Contents

# Copyright (c) 2013 AppNeta, Inc.
# All rights reserved.

if defined?(ActionView::Base) && TraceView::Config[:action_view][:enabled]

  ##
  # ActionView Instrumentation is version dependent.  ActionView 2.x is separate
  # and ActionView 3.0 is a special case.
  # Everything else goes here. (ActionView 3.1 - 4.0 as of this writing)
  #
  if (Rails::VERSION::MAJOR == 3 && Rails::VERSION::MINOR > 0) || Rails::VERSION::MAJOR == 4

    TraceView.logger.info '[traceview/loading] Instrumenting actionview' if TraceView::Config[:verbose]

    ActionView::PartialRenderer.class_eval do
      alias :render_partial_without_traceview :render_partial
      def render_partial
        entry_kvs = {}
        begin
          name = TraceView::Util.prettify(@options[:partial]) if @options.is_a?(Hash)
          entry_kvs[:FunctionName] = :render_partial
          entry_kvs[:Class]        = :PartialRenderer
          entry_kvs[:Module]       = :ActionView
          entry_kvs[:File]         = __FILE__
          entry_kvs[:LineNumber]   = __LINE__
        rescue
        end

        TraceView::API.profile(name, entry_kvs, TraceView::Config[:action_view][:collect_backtraces]) do
          render_partial_without_traceview
        end
      end

      alias :render_collection_without_traceview :render_collection
      def render_collection
        entry_kvs = {}
        begin
          name = TraceView::Util.prettify(@path)
          entry_kvs[:FunctionName] = :render_collection
          entry_kvs[:Class]        = :PartialRenderer
          entry_kvs[:Module]       = :ActionView
          entry_kvs[:File]         = __FILE__
          entry_kvs[:LineNumber]   = __LINE__
        rescue
        end

        TraceView::API.profile(name, entry_kvs, TraceView::Config[:action_view][:collect_backtraces]) do
          render_collection_without_traceview
        end
      end

    end
  end
end

# vim:set expandtab:tabstop=2

Version data entries

22 entries across 22 versions & 1 rubygems

Version Path
traceview-3.3.3-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.3.3 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.3.1-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.3.1 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.3.0-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.3.0 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.2.1-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.2.1 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.1.0-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.1.0 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.5-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.5 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.4-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.4 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.3-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.3 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.2-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.2 lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.1-java lib/traceview/frameworks/rails/inst/action_view.rb
traceview-3.0.1 lib/traceview/frameworks/rails/inst/action_view.rb