Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Wow Code, Such Read!

Wow Code, Such Read!

Abstract:
An exploration of improving at the skill of reading source code.

This talk was presented at the New Relic afterparty for RailsConf 2016 in Kansas City, MO.
Blog post: http://kwugirl.blogspot.com/2016/05/wow-code-such-read.html

Katherine Wu

May 04, 2016
Tweet

More Decks by Katherine Wu

Other Decks in Technology

Transcript

  1. @kwugirl This document and the information herein (including any information

    that may be incorporated by reference) is provided for informational purposes only and should not be construed as an offer, commitment, promise or obligation on behalf of New Relic, Inc. (“New Relic”) to sell securities or deliver any product, material, code, functionality, or other feature. Any information provided hereby is proprietary to New Relic and may not be replicated or disclosed without New Relic’s express written permission. Such information may contain forward-looking statements within the meaning of federal securities laws. Any statement that is not a historical fact or refers to expectations, projections, future plans, objectives, estimates, goals, or other characterizations of future events is a forward-looking statement. These forward-looking statements can often be identified as such because the context of the statement will include words such as “believes,” “anticipates,” “expects” or words of similar import. Actual results may differ materially from those expressed in these forward-looking statements, which speak only as of the date hereof, and are subject to change at any time without notice. Existing and prospective investors, customers and other third parties transacting business with New Relic are cautioned not to place undue reliance on this forward-looking information. The achievement or success of the matters covered by such forward-looking statements are based on New Relic’s current assumptions, expectations, and beliefs and are subject to substantial risks, uncertainties, assumptions, and changes in circumstances that may cause the actual results, performance, or achievements to differ materially from those expressed or implied in any forward-looking statement. Further information on factors that could affect such forward-looking statements is included in the filings we make with the SEC from time to time. Copies of these documents may be obtained by visiting New Relic’s Investor Relations website at ir.newrelic.com or the SEC’s website at www.sec.gov. New Relic assumes no obligation and does not intend to update these forward-looking statements, except as required by law. New Relic makes no warranties, expressed or implied, in this document or otherwise, with respect to the information provided.
  2. @kwugirl { :sql=>
 "SELECT \"blogs\".* FROM \"blogs\" WHERE \"blogs\".\"id \"

    = $1 LIMIT 1", … :binds=> [[#<ActiveRecord::ConnectionAdapters::PostgreSQLColumn: 0x007fd13a879e58 @array=false, @cast_type=#<ActiveRecord::ConnectionAdapters::PostgreS QL::OID::Integer:0x007fd13a87afd8 @limit=nil, @precision=nil, @range=-2147483648...2147483648, @scale=nil>,…,42]] } ActiveSupport::Notifications.subscribe 'sql.active_record'
  3. @kwugirl { :sql=>
 "SELECT \"blogs\".* FROM \"blogs\" WHERE \"blogs\".\"id \"

    = $1 LIMIT 1", … :binds=> [[#<ActiveRecord::ConnectionAdapters::PostgreSQLColumn: 0x007fd13a879e58 @array=false, @cast_type=#<ActiveRecord::ConnectionAdapters::PostgreS QL::OID::Integer:0x007fd13a87afd8 @limit=nil, @precision=nil, @range=-2147483648...2147483648, @scale=nil>,…,42]] } ActiveSupport::Notifications.subscribe 'sql.active_record'
  4. @kwugirl @instrumenter.instrument( "sql.active_record", :sql => sql, :name => name, :connection_id

    => object_id, :statement_name => statement_name, :binds => binds) { yield } def log(sql, name = "SQL", binds = [], statement_name = nil) # active_record/connection_adapters/abstract_adapter.rb
  5. @kwugirl @instrumenter.instrument( "sql.active_record", :sql => sql, :name => name, :connection_id

    => object_id, :statement_name => statement_name, :binds => binds) { yield } def log(sql, name = "SQL", binds = [], statement_name = nil) # active_record/connection_adapters/abstract_adapter.rb
  6. @kwugirl @instrumenter.instrument( "sql.active_record", :sql => sql, :name => name, :connection_id

    => object_id, :statement_name => statement_name, :binds => binds) { yield } def log(sql, name = "SQL", binds = [], statement_name = nil) # active_record/connection_adapters/abstract_adapter.rb
  7. @kwugirl def log(sql, name = "SQL", binds = [], statement_name

    = nil) @instrumenter.instrument( "sql.active_record", :sql => sql, :name => name, :connection_id => object_id, :statement_name => statement_name, :binds => binds) { yield } puts "====== HELLO IS IT ME YOU'RE LOOKING FOR?!!?? ======" # active_record/connection_adapters/abstract_adapter.rb
  8. @kwugirl active_record/connection_adapters/postgresql_adapter.rb:601:in `exec_cache' active_record/connection_adapters/postgresql_adapter.rb:585:in `execute_and_clear' active_record/connection_adapters/postgresql/database_statements.rb:161:in `exec_query' active_record/connection_adapters/abstract/database_statements.rb:341:in `select' active_record/connection_adapters/abstract/database_statements.rb:37:in

    `select_all' active_record/connection_adapters/abstract/query_cache.rb:70:in `select_all' active_record/querying.rb:39:in `find_by_sql' active_record/relation.rb:639:in `exec_queries' active_record/relation.rb:514:in `load' active_record/relation.rb:243:in `to_a' active_record/relation.rb:617:in `pretty_print' Kernel#caller
  9. @kwugirl doge The White Rabbit, Alice in Wonderland sad Keanu

    pear/pair programming Lionel Richie + Where’s Waldo !!1!one!! the “!1” phenomenon breadfish Slurms MacKenzie, Futurama