aboutsummaryrefslogtreecommitdiffstats
path: root/complex.c
diff options
context:
space:
mode:
authortadf <tadf@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-07-05 13:46:10 +0000
committertadf <tadf@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-07-05 13:46:10 +0000
commitb50cc1fe570b9eac594d5b8d8bbdde0bce5d5587 (patch)
tree47c71f9acc1f4a31c40a38945fda632de92f7e43 /complex.c
parent5a763bb525d3d0d51e4f2ea0da4a3fa514656a4a (diff)
downloadruby-b50cc1fe570b9eac594d5b8d8bbdde0bce5d5587.tar.gz
* complex.c (nucomp_s_polar): now arg is optional.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@23961 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'complex.c')
-rw-r--r--complex.c20
1 files changed, 16 insertions, 4 deletions
diff --git a/complex.c b/complex.c
index d64c628128..3ccc50974c 100644
--- a/complex.c
+++ b/complex.c
@@ -548,13 +548,25 @@ f_complex_polar(VALUE klass, VALUE x, VALUE y)
/*
* call-seq:
- * Complex.polar(abs, arg) -> complex
+ * Complex.polar(abs[, arg]) -> complex
*
* Returns a complex object which denotes the given polar form.
*/
static VALUE
-nucomp_s_polar(VALUE klass, VALUE abs, VALUE arg)
+nucomp_s_polar(int argc, VALUE *argv, VALUE klass)
{
+ VALUE abs, arg;
+
+ switch (rb_scan_args(argc, argv, "11", &abs, &arg)) {
+ case 1:
+ nucomp_real_check(abs);
+ arg = ZERO;
+ break;
+ default:
+ nucomp_real_check(abs);
+ nucomp_real_check(arg);
+ break;
+ }
return f_complex_polar(klass, abs, arg);
}
@@ -1260,7 +1272,7 @@ rb_complex_new(VALUE x, VALUE y)
VALUE
rb_complex_polar(VALUE x, VALUE y)
{
- return nucomp_s_polar(rb_cComplex, x, y);
+ return f_complex_polar(rb_cComplex, x, y);
}
static VALUE nucomp_s_convert(int argc, VALUE *argv, VALUE klass);
@@ -1840,7 +1852,7 @@ Init_Complex(void)
rb_define_singleton_method(rb_cComplex, "rectangular", nucomp_s_new, -1);
rb_define_singleton_method(rb_cComplex, "rect", nucomp_s_new, -1);
- rb_define_singleton_method(rb_cComplex, "polar", nucomp_s_polar, 2);
+ rb_define_singleton_method(rb_cComplex, "polar", nucomp_s_polar, -1);
rb_define_global_function("Complex", nucomp_f_complex, -1);