rack-mini-profiler 0.1.30 → 0.9.2

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of rack-mini-profiler might be problematic. Click here for more details.

Files changed (45) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +149 -0
  3. data/README.md +271 -0
  4. data/{Ruby/lib → lib}/html/includes.css +0 -0
  5. data/{Ruby/lib → lib}/html/includes.js +9 -8
  6. data/{Ruby/lib → lib}/html/includes.less +0 -0
  7. data/{Ruby/lib → lib}/html/includes.tmpl +1 -1
  8. data/{Ruby/lib → lib}/html/jquery.1.7.1.js +0 -0
  9. data/{Ruby/lib → lib}/html/jquery.tmpl.js +0 -0
  10. data/{Ruby/lib → lib}/html/list.css +2 -2
  11. data/{Ruby/lib → lib}/html/list.js +1 -1
  12. data/{Ruby/lib → lib}/html/list.tmpl +2 -2
  13. data/lib/html/profile_handler.js +1 -0
  14. data/{Ruby/lib → lib}/html/share.html +2 -2
  15. data/{Ruby/lib → lib}/mini_profiler/client_settings.rb +0 -0
  16. data/{Ruby/lib → lib}/mini_profiler/client_timer_struct.rb +0 -0
  17. data/{Ruby/lib → lib}/mini_profiler/config.rb +11 -4
  18. data/{Ruby/lib → lib}/mini_profiler/context.rb +1 -1
  19. data/{Ruby/lib → lib}/mini_profiler/custom_timer_struct.rb +0 -0
  20. data/lib/mini_profiler/gc_profiler.rb +181 -0
  21. data/{Ruby/lib → lib}/mini_profiler/page_timer_struct.rb +0 -0
  22. data/{Ruby/lib → lib}/mini_profiler/profiler.rb +108 -123
  23. data/{Ruby/lib → lib}/mini_profiler/profiling_methods.rb +0 -0
  24. data/{Ruby/lib → lib}/mini_profiler/request_timer_struct.rb +0 -0
  25. data/{Ruby/lib → lib}/mini_profiler/sql_timer_struct.rb +0 -0
  26. data/{Ruby/lib → lib}/mini_profiler/storage/abstract_store.rb +0 -0
  27. data/{Ruby/lib → lib}/mini_profiler/storage/file_store.rb +26 -4
  28. data/{Ruby/lib → lib}/mini_profiler/storage/memcache_store.rb +0 -0
  29. data/{Ruby/lib → lib}/mini_profiler/storage/memory_store.rb +25 -4
  30. data/{Ruby/lib → lib}/mini_profiler/storage/redis_store.rb +0 -0
  31. data/{Ruby/lib → lib}/mini_profiler/timer_struct.rb +0 -0
  32. data/lib/mini_profiler/version.rb +5 -0
  33. data/{Ruby/lib → lib}/mini_profiler_rails/railtie.rb +23 -6
  34. data/{Ruby/lib → lib}/patches/net_patches.rb +0 -0
  35. data/{Ruby/lib → lib}/patches/sql_patches.rb +15 -8
  36. data/{Ruby/lib → lib}/rack-mini-profiler.rb +0 -0
  37. data/rack-mini-profiler.gemspec +24 -16
  38. metadata +163 -53
  39. data/Ruby/CHANGELOG +0 -156
  40. data/Ruby/README.md +0 -172
  41. data/Ruby/lib/html/flamegraph.html +0 -351
  42. data/Ruby/lib/html/profile_handler.js +0 -1
  43. data/Ruby/lib/mini_profiler/flame_graph.rb +0 -54
  44. data/Ruby/lib/mini_profiler/gc_profiler.rb +0 -107
  45. data/Ruby/lib/mini_profiler/version.rb +0 -5
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 88d14211a1bd6e204377a0405f364fa9069029f0
4
- data.tar.gz: 0c96e6d8d1df58cdd879319063e203efa846bd9f
3
+ metadata.gz: 8b3ee0b3863448cab4aa77a7d21a6660cd864fdd
4
+ data.tar.gz: 84d03ff97e66376542b2ad7862abcb1e5fee280b
5
5
  SHA512:
6
- metadata.gz: f681b1fe0dedcbd7ec6dc43f31cc0eb6d7dd78c0c69ae0b6bd040df166450a833a7f987c7d0167f2e54b30c37323bc99f48440078ad59052b852567a4d6ff442
7
- data.tar.gz: dccb1eec80365ab26fd439d280ccc03fe3f0c9c72d193df117c1392b8f338abb4fbb72f676217c5ae5cd47bfb66a8249b4f7a6e244dcf1df7cd322bbff36c2d1
6
+ metadata.gz: e31c6eacf0d6fa8b01f1c11ef4be1f16a86e1f08843ef79ff8051c5029b78460aa9c23802b1cdc1be8e1b4d19dc19e6644c621740bec0c8578aed6a04bb52ede
7
+ data.tar.gz: cf86b40baacdd86a5e90f641a4ec9e2367ddfef55c3f1810aeed774fd55950b86c428ab9df7eabcd08f09a1dc093b142f270ac3bad4ff7acba4a4b87e1d52826
@@ -0,0 +1,149 @@
1
+ # CHANGELOG
2
+ ## 0.9.2 - 2014-06-26 (Sam Saffron)
3
+ - [CHANGE] staging and other environments behave like production (Cedric Felizard)
4
+ - [DOC] CHANGELOG reorg (Olivier Lacan)
5
+ - [FIXED] Double calls to Rack::MiniProfilerRails.initialize! now raise an exception (Julik Tarkhanov)
6
+ - [FIXED] Add no-store header (George Mendoza)
7
+
8
+ ## 0.9.1 - 2014-03-13 (Sam Saffron)
9
+ - [ADDED] Added back Ruby 1.8 support (thanks Malet)
10
+ - [IMPROVED] Amended Railstie so MiniProfiler can be launched with action view or action controller (Thanks Akira)
11
+ - [FIXED] Rails 3.0 support (thanks Zlatko)
12
+ - [FIXED] Possible XSS (admin only)
13
+ - [FIXED] Corrected Sql patching to avoid setting instance vars on nil which is frozen (thanks Andy, huoxito)
14
+
15
+ ## 0.9.0.pre - 2013-12-12 (Sam Saffron)
16
+ - Bumped up version to reflect the stability of the project
17
+ - [IMPROVED] Reports for pp=profile-gc
18
+ - [IMPROVED] pp=flamegraph&flamegraph_sample_rate=1 , allow you to specify sampling rates
19
+
20
+ ## 2013-09-17 (Ross Wilson)
21
+ - [IMPROVED] Instead of supressing all "/assets/" requests we now check the configured
22
+ config.assets.prefix path since developers can rename the path to serve Asset Pipeline
23
+ files from
24
+
25
+ ## 2013-09-03
26
+ - [IMPROVED] Flamegraph now has much increased fidelity
27
+ - [REMOVED] Ripped out flamegraph so it can be isolated into a gem
28
+ - [REMOVED] Ripped out pp=sample it just was never really used
29
+
30
+ ## 1.30 - 2013-08-30
31
+ - [ADDED] Rack::MiniProfiler.counter_method(klass,name) for injecting counters
32
+ - [FIXED] Counters were not shifting the table correctly
33
+
34
+ ## 1.29 - 2013-08-20
35
+ - [ADDED] Implemented exception tracing using TracePoint see pp=trace-exceptions
36
+ - [FIXED] SOLR patching had an incorrect monkey patch
37
+
38
+ ## 1.28 - 2012-07-18
39
+ - [FIXED] Diagnostics in abstract storage was raising not implemented killing
40
+ ?pp=env and others
41
+ - [FIXED] SOLR xml unescaped by mistake
42
+
43
+ ## 1.27 - 2013-06-26
44
+ - [ADDED] Rack::MiniProfiler.config.backtrace_threshold_ms
45
+ - [ADDED] jQuery 2.0 support
46
+ - [FIXED] Disabled global ajax handlers on MP requests @JP
47
+
48
+ ## 1.26 - 2013-04-11
49
+ - [IMPROVED] Allow Rack::MiniProfilerRails.initialize!(Rails.application), for post config intialization
50
+
51
+ ## 1.25 - 2013-04-08
52
+ - [FIXED] Missed flamegraph.html from build
53
+
54
+ ## 1.24 - 2013-04-08
55
+ - [ADDED] Flame Graph Support see: http://samsaffron.com/archive/2013/03/19/flame-graphs-in-ruby-miniprofiler
56
+ - [ADDED] New toggle_shortcut and start_hidden options
57
+ - [ADDED] Mongoid support
58
+ - [ADDED] Rack::MiniProfiler.counter counter_name {}
59
+ - [ADDED] Net:HTTP profiling
60
+ - [ADDED] Ruby 1.8.7 support ... grrr
61
+ - [IMPROVED] More robust gc profiling
62
+ - [IMPROVED] Script tag initialized via data-attributes
63
+ - [IMPROVED] Allow usage of existing jQuery if its already loaded
64
+ - [IMPROVED] Pre-authorize to run in all non development? and production? modes
65
+ - [FIXED] AngularJS support and MooTools
66
+ - [FIXED] File retention leak in file_store
67
+ - [FIXED] HTML5 implicit <body> tags
68
+ - [FIXED] pp=enable
69
+
70
+ ## 1.22 - 2012-09-20
71
+ - [FIXED] Permission issue in the gem
72
+
73
+ ## 17-September-2012
74
+ - [IMPROVED] Allow rack-mini-profiler to be sourced from github
75
+ - [IMPROVED] Extracted the pp=profile-gc-time out, the object space profiler needs to disable gc
76
+
77
+ ## 1.21 - 2012-09-17
78
+ - [ADDED] New MemchacedStore
79
+ - [ADDED] Rails 4 support
80
+
81
+ ## 2012-09-12 (Sam Saffron)
82
+ - [ADDED] pp=profile-gc: allows you to profile the GC in Ruby 1.9.3
83
+
84
+ ## 1.19 - 2012-09-10 (Sam Saffron)
85
+ - [FIXED] Compatibility issue with Ruby 1.8.7
86
+
87
+ ## 1.17 - 2012-09-09 (Sam Saffron)
88
+ - [FIXED] pp=sample was bust unless stacktrace was installed
89
+
90
+ ## 1.16 - 2012-09-05 (Sam Saffron)
91
+ - [IMPROVED] Implemented stacktrace properly
92
+ - [FIXED] Long standing problem specs (issue with memory store)
93
+ - [FIXED] Issue where profiler would be dumped when you got a 404 in production (and any time rails is bypassed)
94
+
95
+ ## 1.15.pre - 2012-09-04 (Sam Saffron)
96
+ - [FIXED] Annoying bug where client settings were not sticking
97
+ - [FIXED] Long standing issue with Rack::ConditionalGet stopping MiniProfiler from working properly
98
+
99
+ ## 1.13.pre - 2012-09-03 (Sam Saffron)
100
+ - [ADDED] Setting: config.backtrace_ignores = [] - an array of regexes that match on caller lines that get ignored
101
+ - [ADDED] Setting: config.backtrace_includes = [] - an array of regexes that get included in the trace by default
102
+ - [ADDED] pp=normal-backtrace to clear the "sticky" state
103
+ - [IMPROVED] Cleaned up the way client settings are stored
104
+ - [IMPROVED] Made pp=full-backtrace "sticky"
105
+ - [IMPROVED] Changed "pp=sample" to work with "caller" no need for stack trace gem
106
+ - [FIXED] pg gem prepared statements were not being logged correctly
107
+
108
+ ## 1.12.pre - 2012-08-20 (Sam Saffron)
109
+ - [IMPROVED] Cap X-MiniProfiler-Ids at 10, otherwise the header can get killed
110
+
111
+ ## 2012-08-10 (Sam Saffron)
112
+ - [ADDED] Basic prepared statement profiling for Postgres
113
+
114
+ ## 2012-08-07 (Sam Saffron)
115
+ - [ADDED] Option to disable profiler for the current session (pp=disable / pp=enable)
116
+ - [ADDED] yajl compatability contributed by Sven Riedel
117
+
118
+ ## 0.1.9 - 2012-07-30 (Sam Saffron)
119
+ - [IMPROVED] Made compliant with ancient versions of Rack (including Rack used by Rails2)
120
+ - [FIXED] Broken share link
121
+ - [FIXED] Crashes on startup (in MemoryStore and FileStore)
122
+ - [FIXED] Unicode issue
123
+
124
+ ## 0.1.7 - 2012-07-18 (Sam Saffron)
125
+ - [ADDED] First Paint time for Google Chrome
126
+ - [FIXED] Ensure non Rails installs have mini profiler
127
+
128
+ ## 2012-07-12 (Sam Saffron)
129
+ - [ADDED] Native PG and MySql2 interceptors, this gives way more accurate times
130
+ - [ADDED] some more client probing built in to rails
131
+ - [IMPROVED] Refactored context so its a proper class and not a hash
132
+ - [IMPROVED] More tests
133
+ - [FIXED] Incorrect profiling steps (was not indenting or measuring start time right
134
+
135
+ ## 0.1.3 - 2012-07-09 (Sam Saffron)
136
+ - [ADDED] New option to display full backtraces pp=full-backtrace
137
+ - [IMPROVED] Cleaned up mechanism for profiling in production, all you need to do now
138
+ is call Rack::MiniProfiler.authorize_request to get profiling working in
139
+ production
140
+ - [IMPROVED] Cleaned up railties, got rid of the post authorize callback
141
+
142
+ ## 2012-06-28 (Sam Saffron)
143
+ - [ADDED] Started change log
144
+ - [ADDED] added MemcacheStore
145
+ - [IMPROVED] Corrected profiler so it properly captures POST requests (was supressing non 200s)
146
+ - [IMPROVED] Amended Rack.MiniProfiler.config[:user_provider] to use ip addres for identity
147
+ - [IMPROVED] Supress all '/assets/' in the rails tie (makes debugging easier)
148
+ - [FIXED] Issue where unviewed missing ids never got cleared
149
+ - [FIXED] record_sql was mega buggy
@@ -0,0 +1,271 @@
1
+ # rack-mini-profiler
2
+
3
+ [![Code Climate](https://codeclimate.com/github/MiniProfiler/rack-mini-profiler.png)](https://codeclimate.com/github/MiniProfiler/rack-mini-profiler) [![Build Status](https://travis-ci.org/MiniProfiler/rack-mini-profiler.png)](https://travis-ci.org/MiniProfiler/rack-mini-profiler)
4
+
5
+ Middleware that displays speed badge for every html page. Designed to work both in production and in development.
6
+
7
+ #### Features
8
+
9
+ * database profiling. Currently supports Mysql2, Postgres, and Mongoid3 (with fallback support to ActiveRecord)
10
+
11
+ #### Learn more
12
+
13
+ * [Visit our community](http://community.miniprofiler.com)
14
+ * [Watch the RailsCast](http://railscasts.com/episodes/368-miniprofiler)
15
+ * [Read about Flame graphs in rack-mini-profiler](http://samsaffron.com/archive/2013/03/19/flame-graphs-in-ruby-miniprofiler)
16
+ * [Read the announcement posts from 2012](http://samsaffron.com/archive/2012/07/12/miniprofiler-ruby-edition)
17
+
18
+ ## rack-mini-profiler needs your help
19
+
20
+ We have decided to restructure our repository so there is a central UI repo and the various language implementation have their own.
21
+
22
+ **WE NEED HELP.**
23
+
24
+ - Setting up a build that reuses https://github.com/MiniProfiler/ui
25
+ - Migrating the internal data structures [per the spec](https://github.com/MiniProfiler/ui)
26
+ - Cleaning up the [horrendous class structure that is using strings as keys and crazy non-objects](https://github.com/MiniProfiler/rack-mini-profiler/blob/master/lib/mini_profiler/sql_timer_struct.rb#L36-L44)
27
+
28
+ If you feel like taking on any of this start an issue and update us on your progress.
29
+
30
+ ## Installation
31
+
32
+ Install/add to Gemfile
33
+
34
+ ```ruby
35
+ gem 'rack-mini-profiler'
36
+ ```
37
+
38
+ NOTE: Be sure to require rack_mini_profiler below the `pg` and `mysql` gems in your Gemfile. rack_mini_profiler will identify these gems if they are loaded to insert instrumentation. If included too early no SQL will show up.
39
+
40
+ #### Rails
41
+
42
+ All you have to do is include the Gem and you're good to go in development. See notes below for use in production.
43
+
44
+ #### Rails and manual initialization
45
+
46
+ In case you need to make sure rack_mini_profiler initialized after all other gems.
47
+ Or you want to execute some code before rack_mini_profiler required.
48
+
49
+ ```ruby
50
+ gem 'rack-mini-profiler', require: false
51
+ ```
52
+ Note the `require: false` part - if omitted, it will cause the Railtie for the mini-profiler to
53
+ be loaded outright, and an attempt to re-initialize it manually will raise an exception.
54
+
55
+ Then put initialize code in file like `config/initializers/rack_profiler.rb`
56
+
57
+ ```ruby
58
+ if Rails.env == 'development'
59
+ require 'rack-mini-profiler'
60
+
61
+ # initialization is skipped so trigger it
62
+ Rack::MiniProfilerRails.initialize!(Rails.application)
63
+ end
64
+ ```
65
+
66
+ #### Rack Builder
67
+
68
+ ```ruby
69
+ require 'rack-mini-profiler'
70
+ builder = Rack::Builder.new do
71
+ use Rack::MiniProfiler
72
+
73
+ map('/') { run get }
74
+ end
75
+ ```
76
+
77
+ #### Sinatra
78
+
79
+ ```ruby
80
+ require 'rack-mini-profiler'
81
+ class MyApp < Sinatra::Base
82
+ use Rack::MiniProfiler
83
+ end
84
+ ```
85
+
86
+ ### Flamegraphs
87
+
88
+ To generate [flamegraphs](http://samsaffron.com/archive/2013/03/19/flame-graphs-in-ruby-miniprofiler):
89
+
90
+ * add the **flamegraph** gem to your Gemfile
91
+ * visit a page in your app with `?pp=flamegraph`
92
+
93
+ Flamegraph generation is supported in MRI 2.0 and 2.1 only.
94
+
95
+
96
+ ## Access control in production
97
+
98
+ rack-mini-profiler is designed with production profiling in mind. To enable that just run `Rack::MiniProfiler.authorize_request` once you know a request is allowed to profile.
99
+
100
+ ```ruby
101
+ # A hook in your ApplicationController
102
+ def authorize
103
+ if current_user.is_admin?
104
+ Rack::MiniProfiler.authorize_request
105
+ end
106
+ end
107
+ ```
108
+
109
+ ## Configuration
110
+
111
+ Various aspects of rack-mini-profiler's behavior can be configured when your app boots.
112
+ For example in a Rails app, this should be done in an initializer:
113
+ **config/initializers/mini_profiler.rb**
114
+
115
+ ### Storage
116
+
117
+ rack-mini-profiler stores its results so they can be shared later and aren't lost at the end of the request.
118
+
119
+ There are 4 storage options: `MemoryStore`, `RedisStore`, `MemcacheStore`, and `FileStore`.
120
+
121
+ `FileStore` is the default in Rails environments and will write files to `tmp/miniprofiler/*`. `MemoryStore` is the default otherwise.
122
+
123
+ ```ruby
124
+ # set MemoryStore
125
+ Rack::MiniProfiler.config.storage = Rack::MiniProfiler::MemoryStore
126
+
127
+ # set RedisStore
128
+ if Rails.env.production?
129
+ uri = URI.parse(ENV["REDIS_SERVER_URL"])
130
+ Rack::MiniProfiler.config.storage_options = { :host => uri.host, :port => uri.port, :password => uri.password }
131
+ Rack::MiniProfiler.config.storage = Rack::MiniProfiler::RedisStore
132
+ end
133
+ ```
134
+
135
+ MemoryStore stores results in a processes heap - something that does not work well in a multi process environment.
136
+ FileStore stores results in the file system - something that may not work well in a multi machine environment.
137
+ RedisStore/MemcacheStore work in multi process and multi machine environments (RedisStore only saves results for up to 24 hours so it won't continue to fill up Redis).
138
+
139
+ Additionally you may implement an AbstractStore for your own provider.
140
+
141
+ ### User result segregation
142
+
143
+ MiniProfiler will attempt to keep all user results isolated, out-of-the-box the user provider uses the ip address:
144
+
145
+ ```ruby
146
+ Rack::MiniProfiler.config.user_provider = Proc.new{|env| Rack::Request.new(env).ip}
147
+ ```
148
+
149
+ You can override (something that is very important in a multi-machine production setup):
150
+
151
+ ```ruby
152
+ Rack::MiniProfiler.config.user_provider = Proc.new{ |env| CurrentUser.get(env) }
153
+ ```
154
+
155
+ The string this function returns should be unique for each user on the system (for anonymous you may need to fall back to ip address)
156
+
157
+ ### Configuration Options
158
+
159
+ You can set configuration options using the configuration accessor on `Rack::MiniProfiler`.
160
+ For example:
161
+
162
+ ```ruby
163
+ Rack::MiniProfiler.config.position = 'right'
164
+ Rack::MiniProfiler.config.start_hidden = true
165
+ ```
166
+ The available configuration options are:
167
+
168
+ * pre_authorize_cb - A lambda callback you can set to determine whether or not mini_profiler should be visible on a given request. Default in a Rails environment is only on in development mode. If in a Rack app, the default is always on.
169
+ * position - Can either be 'right' or 'left'. Default is 'left'.
170
+ * skip_schema_queries - Whether or not you want to log the queries about the schema of your tables. Default is 'false', 'true' in rails development.
171
+ * auto_inject (default true) - when false the miniprofiler script is not injected in the page
172
+ * backtrace_filter - a regex you can use to filter out unwanted lines from the backtraces
173
+ * toggle_shortcut (default Alt+P) - a jquery.hotkeys.js-style keyboard shortcut, used to toggle the mini_profiler's visibility. See http://code.google.com/p/js-hotkeys/ for more info.
174
+ * start_hidden (default false) - Whether or not you want the mini_profiler to be visible when loading a page
175
+ * backtrace_threshold_ms (default zero) - Minimum SQL query elapsed time before a backtrace is recorded. Backtrace recording can take a couple of milliseconds on rubies earlier than 2.0, impacting performance for very small queries.
176
+ * flamegraph_sample_rate (default 0.5ms) - How often fast_stack should get stack trace info to generate flamegraphs
177
+
178
+ ### Custom middleware ordering (required if using `Rack::Deflate` with Rails)
179
+
180
+ If you are using `Rack::Deflate` with rails and rack-mini-profiler in its default configuration,
181
+ `Rack::MiniProfiler` will be injected (as always) at position 0 in the middleware stack. This
182
+ will result in it attempting to inject html into the already-compressed response body. To fix this,
183
+ the middleware ordering must be overriden.
184
+
185
+ To do this, first add `, require: false` to the gemfile entry for rack-mini-profiler.
186
+ This will prevent the railtie from running. Then, customize the initialization
187
+ in the initializer like so:
188
+
189
+ ```ruby
190
+ require 'rack-mini-profiler'
191
+
192
+ Rack::MiniProfilerRails.initialize!(Rails.application)
193
+
194
+ Rails.application.middleware.delete(Rack::MiniProfiler)
195
+ Rails.application.middleware.insert_after(Rack::Deflater, Rack::MiniProfiler)
196
+ ```
197
+
198
+ Deleting the middleware and then reinserting it is a bit inelegant, but
199
+ a sufficient and costless solution. It is possible that rack-mini-profiler might
200
+ support this scenario more directly if it is found that
201
+ there is significant need for this confriguration or that
202
+ the above recipe causes problems.
203
+
204
+
205
+ ## Special query strings
206
+
207
+ If you include the query string `pp=help` at the end of your request you will see the various options available. You can use these options to extend or contract the amount of diagnostics rack-mini-profiler gathers.
208
+
209
+
210
+ ## Rails 2.X support
211
+
212
+ To get MiniProfiler working with Rails 2.3.X you need to do the initialization manually as well as monkey patch away an incompatibility between activesupport and json_pure.
213
+
214
+ Add the following code to your environment.rb (or just in a specific environment such as development.rb) for initialization and configuration of MiniProfiler.
215
+
216
+ ```ruby
217
+ # configure and initialize MiniProfiler
218
+ require 'rack-mini-profiler'
219
+ c = ::Rack::MiniProfiler.config
220
+ c.pre_authorize_cb = lambda { |env|
221
+ Rails.env.development? || Rails.env.production?
222
+ }
223
+ tmp = Rails.root.to_s + "/tmp/miniprofiler"
224
+ FileUtils.mkdir_p(tmp) unless File.exists?(tmp)
225
+ c.storage_options = {:path => tmp}
226
+ c.storage = ::Rack::MiniProfiler::FileStore
227
+ config.middleware.use(::Rack::MiniProfiler)
228
+ ::Rack::MiniProfiler.profile_method(ActionController::Base, :process) {|action| "Executing action: #{action}"}
229
+ ::Rack::MiniProfiler.profile_method(ActionView::Template, :render) {|x,y| "Rendering: #{path_without_format_and_extension}"}
230
+
231
+ # monkey patch away an activesupport and json_pure incompatability
232
+ # http://pivotallabs.com/users/alex/blog/articles/1332-monkey-patch-of-the-day-activesupport-vs-json-pure-vs-ruby-1-8
233
+ if JSON.const_defined?(:Pure)
234
+ class JSON::Pure::Generator::State
235
+ include ActiveSupport::CoreExtensions::Hash::Except
236
+ end
237
+ end
238
+ ```
239
+
240
+ ## Running the Specs
241
+
242
+ ```
243
+ $ rake build
244
+ $ rake spec
245
+ ```
246
+
247
+ Additionally you can also run `autotest` if you like.
248
+
249
+ ## Licence
250
+
251
+ The MIT License (MIT)
252
+
253
+ Copyright (c) 2013 Sam Saffron
254
+
255
+ Permission is hereby granted, free of charge, to any person obtaining a copy
256
+ of this software and associated documentation files (the "Software"), to deal
257
+ in the Software without restriction, including without limitation the rights
258
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
259
+ copies of the Software, and to permit persons to whom the Software is
260
+ furnished to do so, subject to the following conditions:
261
+
262
+ The above copyright notice and this permission notice shall be included in
263
+ all copies or substantial portions of the Software.
264
+
265
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
266
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
267
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
268
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
269
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
270
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
271
+ THE SOFTWARE.
File without changes
@@ -1,4 +1,4 @@
1
- "use strict";
1
+ "use strict";
2
2
  var MiniProfiler = (function () {
3
3
  var $;
4
4
 
@@ -659,6 +659,14 @@ var MiniProfiler = (function () {
659
659
  } else {
660
660
  doInit();
661
661
  }
662
+
663
+ // jquery.hotkeys.js
664
+ // https://github.com/jeresig/jquery.hotkeys/blob/master/jquery.hotkeys.js
665
+
666
+ (function(d){function h(g){if("string"===typeof g.data){var h=g.handler,j=g.data.toLowerCase().split(" ");g.handler=function(b){if(!(this!==b.target&&(/textarea|select/i.test(b.target.nodeName)||"text"===b.target.type))){var c="keypress"!==b.type&&d.hotkeys.specialKeys[b.which],e=String.fromCharCode(b.which).toLowerCase(),a="",f={};b.altKey&&"alt"!==c&&(a+="alt+");b.ctrlKey&&"ctrl"!==c&&(a+="ctrl+");b.metaKey&&(!b.ctrlKey&&"meta"!==c)&&(a+="meta+");b.shiftKey&&"shift"!==c&&(a+="shift+");c?f[a+c]=
667
+ !0:(f[a+e]=!0,f[a+d.hotkeys.shiftNums[e]]=!0,"shift+"===a&&(f[d.hotkeys.shiftNums[e]]=!0));c=0;for(e=j.length;c<e;c++)if(f[j[c]])return h.apply(this,arguments)}}}}d.hotkeys={version:"0.8",specialKeys:{8:"backspace",9:"tab",13:"return",16:"shift",17:"ctrl",18:"alt",19:"pause",20:"capslock",27:"esc",32:"space",33:"pageup",34:"pagedown",35:"end",36:"home",37:"left",38:"up",39:"right",40:"down",45:"insert",46:"del",96:"0",97:"1",98:"2",99:"3",100:"4",101:"5",102:"6",103:"7",104:"8",105:"9",106:"*",107:"+",
668
+ 109:"-",110:".",111:"/",112:"f1",113:"f2",114:"f3",115:"f4",116:"f5",117:"f6",118:"f7",119:"f8",120:"f9",121:"f10",122:"f11",123:"f12",144:"numlock",145:"scroll",191:"/",224:"meta"},shiftNums:{"`":"~",1:"!",2:"@",3:"#",4:"$",5:"%",6:"^",7:"&",8:"*",9:"(","0":")","-":"_","=":"+",";":": ","'":'"',",":"<",".":">","/":"?","\\":"|"}};d.each(["keydown","keyup","keypress"],function(){d.event.special[this]={add:h}})})(MiniProfiler.jQuery);
669
+
662
670
  };
663
671
 
664
672
  var major, minor;
@@ -901,13 +909,6 @@ var MiniProfiler = (function () {
901
909
 
902
910
  MiniProfiler.init();
903
911
 
904
- // jquery.hotkeys.js
905
- // https://github.com/jeresig/jquery.hotkeys/blob/master/jquery.hotkeys.js
906
-
907
- (function(d){function h(g){if("string"===typeof g.data){var h=g.handler,j=g.data.toLowerCase().split(" ");g.handler=function(b){if(!(this!==b.target&&(/textarea|select/i.test(b.target.nodeName)||"text"===b.target.type))){var c="keypress"!==b.type&&d.hotkeys.specialKeys[b.which],e=String.fromCharCode(b.which).toLowerCase(),a="",f={};b.altKey&&"alt"!==c&&(a+="alt+");b.ctrlKey&&"ctrl"!==c&&(a+="ctrl+");b.metaKey&&(!b.ctrlKey&&"meta"!==c)&&(a+="meta+");b.shiftKey&&"shift"!==c&&(a+="shift+");c?f[a+c]=
908
- !0:(f[a+e]=!0,f[a+d.hotkeys.shiftNums[e]]=!0,"shift+"===a&&(f[d.hotkeys.shiftNums[e]]=!0));c=0;for(e=j.length;c<e;c++)if(f[j[c]])return h.apply(this,arguments)}}}}d.hotkeys={version:"0.8",specialKeys:{8:"backspace",9:"tab",13:"return",16:"shift",17:"ctrl",18:"alt",19:"pause",20:"capslock",27:"esc",32:"space",33:"pageup",34:"pagedown",35:"end",36:"home",37:"left",38:"up",39:"right",40:"down",45:"insert",46:"del",96:"0",97:"1",98:"2",99:"3",100:"4",101:"5",102:"6",103:"7",104:"8",105:"9",106:"*",107:"+",
909
- 109:"-",110:".",111:"/",112:"f1",113:"f2",114:"f3",115:"f4",116:"f5",117:"f6",118:"f7",119:"f8",120:"f9",121:"f10",122:"f11",123:"f12",144:"numlock",145:"scroll",191:"/",224:"meta"},shiftNums:{"`":"~",1:"!",2:"@",3:"#",4:"$",5:"%",6:"^",7:"&",8:"*",9:"(","0":")","-":"_","=":"+",";":": ","'":'"',",":"<",".":">","/":"?","\\":"|"}};d.each(["keydown","keyup","keypress"],function(){d.event.special[this]={add:h}})})(jQuery);
910
-
911
912
  if (typeof prettyPrint === "undefined") {
912
913
 
913
914
  // prettify.js