summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-03-03 15:57:15 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-03-03 15:57:15 +0000
commit294f45b0fc23b91bf5291fd2936f2076f375e467 (patch)
tree2abb7f737521889c80d5c6230eaede1bd353211f /lib
parent27cc677088c21785815b1c137ec8e65e51c2dc83 (diff)
* lib/prime.rb (Prime::prime?): used to return a wrong answer.
[ruby-core:22646]. * test/test_prime.rb (test_prime?): test case for [ruby-core:22646]. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@22741 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib')
-rw-r--r--lib/prime.rb2
1 files changed, 2 insertions, 0 deletions
diff --git a/lib/prime.rb b/lib/prime.rb
index 650d279bc4..ce71d5e00f 100644
--- a/lib/prime.rb
+++ b/lib/prime.rb
@@ -144,6 +144,8 @@ class Prime
# +value+:: an arbitrary integer to be checked.
# +generator+:: optional. A pseudo-prime generator.
def prime?(value, generator = Prime::Generator23.new)
+ value = -value if value < 0
+ return false if value < 2
for num in generator
q,r = value.divmod num
return true if q < num