-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathbase_class.rb
41 lines (30 loc) · 1.03 KB
/
base_class.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
require 'contracts'
require_relative '../helpers/debug_helper'
class BaseClass
include Contracts
end
# Fix bugs in Contracts::MethodHandler
module Contracts
class MethodHandler
# Override this with two small (but important) changes.
def validate_decorators!
return if decorators.size == 1
# 1. Weird bug; thinks this method has 55 contracts!
return if method_name == :psych_yaml_as
# 2. Original has #{name}, which is not defined; #{method_name} works.
# This is fixed in the GitHub project, but not yet in the Ruby gem.
fail %{
Oops, it looks like method '#{method_name}' has multiple contracts:
#{decorators.map { |x| x[1][0].inspect }.join("\n")}
Did you accidentally put more than one contract on a single function, like so?
Contract String => String
Contract Num => String
def foo x
end
If you did NOT, then you have probably discovered a bug in this library.
Please file it along with the relevant code at:
https://github.com/egonSchiele/contracts.ruby/issues
}
end
end
end