Skip to content

Instantly share code, notes, and snippets.


Ravil Bayramgalin brainopia

View GitHub Profile
brainopia /
Created Nov 28, 2018 — forked from techgaun/
OpenSSH 7.4 on Ubuntu 16.04

Installing OpenSSH 7.4 on Ubuntu 16.04

sudo apt install -y build-essential libssl-dev zlib1g-dev
wget ""
tar xfz openssh-7.4p1.tar.gz
cd openssh-7.4p1
sudo make install
View main.rb
require 'yaml'
require 'json'
require 'bundler/inline'
gemfile _install=true do
source ''
gem 'pry'
gem 'puma'
gem 'sinatra', require: 'sinatra/base'
View swagger-docs.rb
module Docs
def self.extended(version)
version.include Swagger::Blocks
def root
Swagger::Blocks.build_root_json [self]
concerning :App do
View normalizer.rb
# Usually normalization is performed during `before_validation`
# or in a setter. But neither would help with normalization of
# where conditions.
# This will add `normalize` to ActiveRecord with support for
# where conditions. For example,
# class User
# normalize(:email) { email.downcase }
# end
View tilt-jbuilder.rb
# This class is used to render jbuilder templates in grape.
# There is an existing grape-jbuilder gem but it depends
# on tilt-jbuilder gem which
# - does not support partial! with :collection
# - does not support template compilation
# In constrast this template handler supports all features of jbuilder
# and uses template compilation (5x-10x times faster than without).
class Tilt::Jbuilder < Tilt::Template
View docs.gemspec do |s| = 'docs'
s.version = '0.0.1'
s.files = ['docs.rb']
s.require_path = '.'
s.add_dependency('swagger-ui_rails', ">= 2.1.0.alpha.7.1")
View replace_superclass_pointer_in_memory.rb
require 'fiddle'
A =
B =
C = A
p C.superclass # => A
(Fiddle::Pointer[Fiddle.dlwrap C] + 16)[0, 8] = Fiddle::Pointer[Fiddle.dlwrap B].ref
p C.superclass # => B
View method_calls.rb
def method_calls(detailed: false, thread: nil)
[].tap do |log|
ident = -1
trace =, :return, :c_call, :c_return) do |tp|
break if thread and thread != Thread.current
case tp.event
when :call, :c_call
if tp.event == :call or detailed
ident += 1
View reduce_allocations_rails_32.rb
# rails 3.X patch to remove extra allocations on field access
module ActiveRecord::AttributeMethods::Read::ClassMethods
def internal_attribute_access_code(attr_name, cast_code)
access_code = "(v=@attributes[attr_name]) && #{cast_code}"
unless attr_name == primary_key
access_code.insert(0, "missing_attribute(attr_name, caller) unless @attributes.has_key?(attr_name); ")
if cache_attribute?(attr_name)
View gist:8f0a7d83509c80b53c45
def track_sql(&block)
timing = 0
track = ->(_,start,finish,_,data) do
Thread.exclusive do
timing[data[:name]] += (finish - start)
ActiveSupport::Notifications.subscribed(track, 'sql.active_record', &block)