You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
421 lines
8.8 KiB
Plaintext
421 lines
8.8 KiB
Plaintext
14 years ago
|
# #!/usr/bin/ruby
|
||
|
snippet #!
|
||
|
#!/usr/bin/ruby
|
||
|
|
||
|
# New Block
|
||
|
snippet =b
|
||
|
=begin rdoc
|
||
|
${1}
|
||
|
=end
|
||
|
snippet y
|
||
|
:yields: ${1:arguments}
|
||
|
snippet rb
|
||
|
#!/usr/bin/env ruby -wKU
|
||
|
|
||
|
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 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 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 eak
|
||
|
each_key { |${1:key}| ${2} }
|
||
|
snippet eal
|
||
|
each_line { |${1:line}| ${2} }
|
||
|
snippet eap
|
||
|
each_pair { |${1:name}, ${2:val}| ${3} }
|
||
|
snippet eas-
|
||
|
each_slice(${1:2}) { |${2:group}| ${3} }
|
||
|
snippet eav
|
||
|
each_value { |${1:val}| ${2} }
|
||
|
snippet eawi
|
||
|
each_with_index { |${1:e}, ${2:i}| ${3} }
|
||
|
snippet reve
|
||
|
reverse_each { |${1:e}| ${2} }
|
||
|
snippet inj
|
||
|
inject(${1:init}) { |${2:mem}, ${3:var}| ${4} }
|
||
|
snippet map
|
||
|
map { |${1:e}| ${2} }
|
||
|
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 det
|
||
|
detect { |${1:e}| ${2} }
|
||
|
snippet fet
|
||
|
fetch(${1:name}) { |${2:key}| ${3} }
|
||
|
snippet fin
|
||
|
find { |${1:e}| ${2} }
|
||
|
snippet fina
|
||
|
find_all { |${1:e}| ${2} }
|
||
|
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 max
|
||
|
max { |a, b|, ${1} }
|
||
|
snippet min
|
||
|
min { |a, b|, ${1} }
|
||
|
snippet par
|
||
|
partition { |${1:e}|, ${2} }
|
||
|
snippet rej
|
||
|
reject { |${1:e}|, ${2} }
|
||
|
snippet sel
|
||
|
select { |${1:e}|, ${2} }
|
||
|
snippet lam
|
||
|
lambda { |${1:args}| ${2} }
|
||
|
snippet do
|
||
|
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}) { ${2} }
|
||
|
snippet asnr
|
||
|
assert_nothing_raised(${1:Exception}) { ${2} }
|
||
|
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}) { ${2} }
|
||
|
snippet asnt
|
||
|
assert_nothing_thrown { ${1} }
|
||
|
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
|