aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--ext/pathname/lib/pathname.rb7
-rw-r--r--ext/pathname/pathname.c25
-rw-r--r--test/pathname/test_pathname.rb2
4 files changed, 30 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index 1fc1e55c0f..ee1ee791e0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sun Aug 8 07:29:55 2010 Tanaka Akira <akr@fsij.org>
+
+ * ext/pathname/pathname.c (path_fnmatch): Pathname#fnmatch and
+ Pathname#fnmatch? translated from pathname.rb.
+
Sun Aug 8 07:18:22 2010 Tanaka Akira <akr@fsij.org>
* include/ruby/subst.h (snprintf): redefinition moved from ruby.h.
diff --git a/ext/pathname/lib/pathname.rb b/ext/pathname/lib/pathname.rb
index b3bc42d9a1..d2373ebdb1 100644
--- a/ext/pathname/lib/pathname.rb
+++ b/ext/pathname/lib/pathname.rb
@@ -512,13 +512,6 @@ end
class Pathname # * File *
- # See <tt>File.fnmatch</tt>. Return +true+ if the receiver matches the given
- # pattern.
- def fnmatch(pattern, *args) File.fnmatch(pattern, @path, *args) end
-
- # See <tt>File.fnmatch?</tt> (same as #fnmatch).
- def fnmatch?(pattern, *args) File.fnmatch?(pattern, @path, *args) end
-
# See <tt>File.ftype</tt>. Returns "type" of file ("file", "directory",
# etc).
def ftype() File.ftype(@path) end
diff --git a/ext/pathname/pathname.c b/ext/pathname/pathname.c
index e317e85618..81b6d23e6d 100644
--- a/ext/pathname/pathname.c
+++ b/ext/pathname/pathname.c
@@ -128,8 +128,8 @@ path_hash(VALUE self)
/*
* call-seq:
- * pathname.to_s => string
- * pathname.to_path => string
+ * pathname.to_s -> string
+ * pathname.to_path -> string
*
* Return the path as a String.
*
@@ -296,6 +296,25 @@ path_lchown(VALUE self, VALUE owner, VALUE group)
}
/*
+ * call-seq:
+ * pathname.fnmatch(pattern, [flags]) -> string
+ * pathname.fnmatch?(pattern, [flags]) -> string
+ *
+ * See <tt>File.fnmatch</tt>. Return +true+ if the receiver matches the given
+ * pattern.
+ */
+static VALUE
+path_fnmatch(int argc, VALUE *argv, VALUE self)
+{
+ VALUE str = get_strpath(self);
+ VALUE pattern, flags;
+ if (rb_scan_args(argc, argv, "11", &pattern, &flags) == 1)
+ return rb_funcall(rb_cFile, rb_intern("fnmatch"), 2, pattern, str);
+ else
+ return rb_funcall(rb_cFile, rb_intern("fnmatch"), 3, pattern, str, flags);
+}
+
+/*
* == Pathname
*
* Pathname represents a pathname which locates a file in a filesystem.
@@ -502,4 +521,6 @@ Init_pathname()
rb_define_method(rb_cPathname, "lchmod", path_lchmod, 1);
rb_define_method(rb_cPathname, "chown", path_chown, 2);
rb_define_method(rb_cPathname, "lchown", path_lchown, 2);
+ rb_define_method(rb_cPathname, "fnmatch", path_fnmatch, -1);
+ rb_define_method(rb_cPathname, "fnmatch?", path_fnmatch, -1);
}
diff --git a/test/pathname/test_pathname.rb b/test/pathname/test_pathname.rb
index c34d61f408..318e06b640 100644
--- a/test/pathname/test_pathname.rb
+++ b/test/pathname/test_pathname.rb
@@ -788,6 +788,8 @@ class TestPathname < Test::Unit::TestCase
path = Pathname("a")
assert_equal(true, path.fnmatch("*"))
assert_equal(false, path.fnmatch("*.*"))
+ assert_equal(false, Pathname(".foo").fnmatch("*"))
+ assert_equal(true, Pathname(".foo").fnmatch("*", File::FNM_DOTMATCH))
end
def test_fnmatch?