# #!/usr/bin/env ruby snippet #! #!/usr/bin/env ruby # New Block snippet =b =begin rdoc ${1} =end snippet y :yields: ${1:arguments} snippet rb #!/usr/bin/env ruby -wKU snippet beg begin ${3} rescue ${1:Exception} => ${2:e} end snippet req require "${1}"${2} snippet # # => snippet end __END__ snippet case case ${1:object} when ${2:condition} ${3} end snippet when when ${1:condition} ${2} snippet def def ${1:method_name} ${2} end snippet deft def test_${1:case_name} ${2} end snippet if if ${1:condition} ${2} end snippet ife if ${1:condition} ${2} else ${3} end snippet elsif elsif ${1:condition} ${2} snippet unless unless ${1:condition} ${2} end snippet while while ${1:condition} ${2} end snippet for for ${1:e} in ${2:c} ${3} end snippet until until ${1:condition} ${2} end snippet cla class .. end class ${1:`substitute(Filename(), '^.', '\u&', '')`} ${2} end snippet cla class .. initialize .. end class ${1:`substitute(Filename(), '^.', '\u&', '')`} def initialize(${2:args}) ${3} end end snippet cla class .. < ParentClass .. initialize .. end class ${1:`substitute(Filename(), '^.', '\u&', '')`} < ${2:ParentClass} def initialize(${3:args}) ${4} end end snippet cla ClassName = Struct .. do .. end ${1:`substitute(Filename(), '^.', '\u&', '')`} = Struct.new(:${2:attr_names}) do def ${3:method_name} ${4} end end snippet cla class BlankSlate .. initialize .. end class ${1:BlankSlate} instance_methods.each { |meth| undef_method(meth) unless meth =~ /\A__/ } snippet cla class << self .. end class << ${1:self} ${2} end # class .. < DelegateClass .. initialize .. end snippet cla- class ${1:`substitute(Filename(), '^.', '\u&', '')`} < DelegateClass(${2:ParentClass}) def initialize(${3:args}) super(${4:del_obj}) ${5} end end snippet mod module .. end module ${1:`substitute(Filename(), '^.', '\u&', '')`} ${2} end snippet mod module .. module_function .. end module ${1:`substitute(Filename(), '^.', '\u&', '')`} module_function ${2} end snippet mod module .. ClassMethods .. end module ${1:`substitute(Filename(), '^.', '\u&', '')`} module ClassMethods ${2} end module InstanceMethods end def self.included(receiver) receiver.extend ClassMethods receiver.send :include, InstanceMethods end end # attr_reader snippet r attr_reader :${1:attr_names} # attr_writer snippet w attr_writer :${1:attr_names} # attr_accessor snippet rw attr_accessor :${1:attr_names} # include Enumerable snippet Enum include Enumerable def each(&block) ${1} end # include Comparable snippet Comp include Comparable def <=>(other) ${1} end # extend Forwardable snippet Forw- extend Forwardable # def self snippet defs def self.${1:class_method_name} ${2} end # def method_missing snippet defmm def method_missing(meth, *args, &blk) ${1} end snippet defd def_delegator :${1:@del_obj}, :${2:del_meth}, :${3:new_name} snippet defds def_delegators :${1:@del_obj}, :${2:del_methods} snippet am alias_method :${1:new_name}, :${2:old_name} snippet app if __FILE__ == $PROGRAM_NAME ${1} end # usage_if() snippet usai if ARGV.${1} abort "Usage: #{$PROGRAM_NAME} ${2:ARGS_GO_HERE}"${3} end # usage_unless() snippet usau unless ARGV.${1} abort "Usage: #{$PROGRAM_NAME} ${2:ARGS_GO_HERE}"${3} end snippet array Array.new(${1:10}) { |${2:i}| ${3} } snippet hash Hash.new { |${1:hash}, ${2:key}| $1[$2] = ${3} } snippet file File.foreach() { |line| .. } File.foreach(${1:"path/to/file"}) { |${2:line}| ${3} } snippet file File.read() File.read(${1:"path/to/file"})${2} snippet Dir Dir.global() { |file| .. } Dir.glob(${1:"dir/glob/*"}) { |${2:file}| ${3} } snippet Dir Dir[".."] Dir[${1:"glob/**/*.rb"}]${2} snippet dir Filename.dirname(__FILE__) snippet deli delete_if { |${1:e}| ${2} } snippet fil fill(${1:range}) { |${2:i}| ${3} } # flatten_once() snippet flao inject(Array.new) { |${1:arr}, ${2:a}| $1.push(*$2)}${3} snippet zip zip(${1:enums}) { |${2:row}| ${3} } # downto(0) { |n| .. } snippet dow downto(${1:0}) { |${2:n}| ${3} } snippet ste step(${1:2}) { |${2:n}| ${3} } snippet tim times { |${1:n}| ${2} } snippet upt upto(${1:1.0/0.0}) { |${2:n}| ${3} } snippet loo loop { ${1} } snippet ea each { |${1:e}| ${2} } snippet ead each do |${1:e}| ${2} end snippet eab each_byte { |${1:byte}| ${2} } snippet eac- each_char { |chr| .. } each_char { |${1:chr}| ${2} } snippet eac- each_cons(..) { |group| .. } each_cons(${1:2}) { |${2:group}| ${3} } snippet eai each_index { |${1:i}| ${2} } snippet eaid each_index do |${1:i}| ${2} end snippet eak each_key { |${1:key}| ${2} } snippet eakd each_key do |${1:key}| ${2} end snippet eal each_line { |${1:line}| ${2} } snippet eald each_line do |${1:line}| ${2} end snippet eap each_pair { |${1:name}, ${2:val}| ${3} } snippet eapd each_pair do |${1:name}, ${2:val}| ${3} end snippet eas- each_slice(${1:2}) { |${2:group}| ${3} } snippet easd- each_slice(${1:2}) do |${2:group}| ${3} end snippet eav each_value { |${1:val}| ${2} } snippet eavd each_value do |${1:val}| ${2} end snippet eawi each_with_index { |${1:e}, ${2:i}| ${3} } snippet eawid each_with_index do |${1:e},${2:i}| ${3} end snippet reve reverse_each { |${1:e}| ${2} } snippet reved reverse_each do |${1:e}| ${2} end snippet inj inject(${1:init}) { |${2:mem}, ${3:var}| ${4} } snippet injd inject(${1:init}) do |${2:mem}, ${3:var}| ${4} end snippet map map { |${1:e}| ${2} } snippet mapd map do |${1:e}| ${2} end snippet mapwi- enum_with_index.map { |${1:e}, ${2:i}| ${3} } snippet sor sort { |a, b| ${1} } snippet sorb sort_by { |${1:e}| ${2} } snippet ran sort_by { rand } snippet all all? { |${1:e}| ${2} } snippet any any? { |${1:e}| ${2} } snippet cl classify { |${1:e}| ${2} } snippet col collect { |${1:e}| ${2} } snippet cold collect do |${1:e}| ${2} end snippet det detect { |${1:e}| ${2} } snippet detd detect do |${1:e}| ${2} end snippet fet fetch(${1:name}) { |${2:key}| ${3} } snippet fin find { |${1:e}| ${2} } snippet find find do |${1:e}| ${2} end snippet fina find_all { |${1:e}| ${2} } snippet finad find_all do |${1:e}| ${2} end snippet gre grep(${1:/pattern/}) { |${2:match}| ${3} } snippet sub ${1:g}sub(${2:/pattern/}) { |${3:match}| ${4} } snippet sca scan(${1:/pattern/}) { |${2:match}| ${3} } snippet scad scan(${1:/pattern/}) do |${2:match}| ${3} end snippet max max { |a, b| ${1} } snippet min min { |a, b| ${1} } snippet par partition { |${1:e}| ${2} } snippet pard partition do |${1:e}| ${2} end snippet rej reject { |${1:e}| ${2} } snippet rejd reject do |${1:e}| ${2} end snippet sel select { |${1:e}| ${2} } snippet seld select do |${1:e}| ${2} end snippet lam lambda { |${1:args}| ${2} } snippet doo do ${1} end snippet dov do |${1:variable}| ${2} end snippet : :${1:key} => ${2:"value"}${3} snippet ope open(${1:"path/or/url/or/pipe"}, "${2:w}") { |${3:io}| ${4} } # path_from_here() snippet patfh File.join(File.dirname(__FILE__), *%2[${1:rel path here}])${2} # unix_filter {} snippet unif ARGF.each_line${1} do |${2:line}| ${3} end # option_parse {} snippet optp require "optparse" options = {${1:default => "args"}} ARGV.options do |opts| opts.banner = "Usage: #{File.basename($PROGRAM_NAME)} snippet opt opts.on( "-${1:o}", "--${2:long-option-name}", ${3:String}, "${4:Option description.}") do |${5:opt}| ${6} end snippet tc require "test/unit" require "${1:library_file_name}" class Test${2:$1} < Test::Unit::TestCase def test_${3:case_name} ${4} end end snippet ts require "test/unit" require "tc_${1:test_case_file}" require "tc_${2:test_case_file}"${3} snippet as assert ${1:test}, "${2:Failure message.}"${3} snippet ase assert_equal ${1:expected}, ${2:actual}${3} snippet asne assert_not_equal ${1:unexpected}, ${2:actual}${3} snippet asid assert_in_delta ${1:expected_float}, ${2:actual_float}, ${3:2 ** -20}${4} snippet asio assert_instance_of ${1:ExpectedClass}, ${2:actual_instance}${3} snippet asko assert_kind_of ${1:ExpectedKind}, ${2:actual_instance}${3} snippet asn assert_nil ${1:instance}${2} snippet asnn assert_not_nil ${1:instance}${2} snippet asm assert_match /${1:expected_pattern}/, ${2:actual_string}${3} snippet asnm assert_no_match /${1:unexpected_pattern}/, ${2:actual_string}${3} snippet aso assert_operator ${1:left}, :${2:operator}, ${3:right}${4} snippet asr assert_raise ${1:Exception} do ${2} end snippet asnr assert_nothing_raised ${1:Exception} do ${2} end snippet asrt assert_respond_to ${1:object}, :${2:method}${3} snippet ass assert_same(..) assert_same ${1:expected}, ${2:actual}${3} snippet ass assert_send(..) assert_send [${1:object}, :${2:message}, ${3:args}]${4} snippet asns assert_not_same ${1:unexpected}, ${2:actual}${3} snippet ast assert_throws :${1:expected} do ${2} end snippet asnt assert_nothing_thrown do ${1} end snippet fl flunk "${1:Failure message.}"${2} # Benchmark.bmbm do .. end snippet bm- TESTS = ${1:10_000} Benchmark.bmbm do |results| ${2} end snippet rep results.report("${1:name}:") { TESTS.times { ${2} }} # Marshal.dump(.., file) snippet Md File.open(${1:"path/to/file.dump"}, "wb") { |${2:file}| Marshal.dump(${3:obj}, $2) }${4} # Mashal.load(obj) snippet Ml File.open(${1:"path/to/file.dump"}, "rb") { |${2:file}| Marshal.load($2) }${3} # deep_copy(..) snippet deec Marshal.load(Marshal.dump(${1:obj_to_copy}))${2} snippet Pn- PStore.new(${1:"file_name.pstore"})${2} snippet tra transaction(${1:true}) { ${2} } # xmlread(..) snippet xml- REXML::Document.new(File.read(${1:"path/to/file"}))${2} # xpath(..) { .. } snippet xpa elements.each(${1:"//Xpath"}) do |${2:node}| ${3} end # class_from_name() snippet clafn split("::").inject(Object) { |par, const| par.const_get(const) } # singleton_class() snippet sinc class << self; self end snippet nam namespace :${1:`Filename()`} do ${2} end snippet tas desc "${1:Task description\}" task :${2:task_name => [:dependent, :tasks]} do ${3} end # block snippet b {|${1:var}| ${2}} snippet begin begin raise 'A test exception.' rescue Exception => e puts e.message puts e.backtrace.inspect else # other exception ensure # always executed end #migrations snippet mac add_column :${1:table_name}, :${2:column_name}, :${3:data_type} snippet mrc remove_column :${1:table_name}, :${2:column_name} snippet mrenc rename_column :${1:table_name}, :${2:old_column_name}, :${3:new_column_name} #rspec snippet it it "${1:spec_name}" do ${2} end snippet desc describe ${1:class_name} do ${2} end snippet cont context "${1:message}" do ${2} end snippet bef before(:${1:each}) do ${2} end snippet aft after(:${1:each}) do ${2} end #debugging snippet debug require 'ruby-debug'; debugger; true;