summaryrefslogtreecommitdiffstats
path: root/dir.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-09-09 02:28:21 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-09-09 02:28:21 +0000
commit1edbfd70aaa1733ec65b96ad216035015587f2a2 (patch)
treee9b400b34c48c7704d0d97138b2342ed894f0154 /dir.c
parent45c4be2723015438d6f41c79430a6df0f1058b2f (diff)
downloadruby-1edbfd70aaa1733ec65b96ad216035015587f2a2.tar.gz
ruby-1edbfd70aaa1733ec65b96ad216035015587f2a2.tar.xz
ruby-1edbfd70aaa1733ec65b96ad216035015587f2a2.zip
* dir.c (dir_data_type): typed.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@24804 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'dir.c')
-rw-r--r--dir.c36
1 files changed, 23 insertions, 13 deletions
diff --git a/dir.c b/dir.c
index 2459658f4..4e20230a6 100644
--- a/dir.c
+++ b/dir.c
@@ -310,27 +310,40 @@ struct dir_data {
};
static void
-mark_dir(struct dir_data *dir)
+dir_mark(void *ptr)
{
+ struct dir_data *dir = ptr;
rb_gc_mark(dir->path);
}
static void
-free_dir(struct dir_data *dir)
+dir_free(void *ptr)
{
+ struct dir_data *dir = ptr;
if (dir) {
if (dir->dir) closedir(dir->dir);
}
xfree(dir);
}
+static size_t
+dir_memsize(const void *ptr)
+{
+ return ptr ? sizeof(struct dir_data) : 0;
+}
+
+static const rb_data_type_t dir_data_type = {
+ "dir",
+ dir_mark, dir_free, dir_memsize
+};
+
static VALUE dir_close(VALUE);
static VALUE
dir_s_alloc(VALUE klass)
{
struct dir_data *dirp;
- VALUE obj = Data_Make_Struct(klass, struct dir_data, mark_dir, free_dir, dirp);
+ VALUE obj = TypedData_Make_Struct(klass, struct dir_data, &dir_data_type, dirp);
dirp->dir = NULL;
dirp->path = Qnil;
@@ -374,7 +387,7 @@ dir_initialize(int argc, VALUE *argv, VALUE dir)
FilePathValue(dirname);
- Data_Get_Struct(dir, struct dir_data, dp);
+ TypedData_Get_Struct(dir, struct dir_data, &dir_data_type, dp);
if (dp->dir) closedir(dp->dir);
dp->dir = NULL;
dp->path = Qnil;
@@ -409,7 +422,7 @@ static VALUE
dir_s_open(int argc, VALUE *argv, VALUE klass)
{
struct dir_data *dp;
- VALUE dir = Data_Make_Struct(klass, struct dir_data, mark_dir, free_dir, dp);
+ VALUE dir = TypedData_Make_Struct(klass, struct dir_data, &dir_data_type, dp);
dir_initialize(argc, argv, dir);
if (rb_block_given_p()) {
@@ -435,7 +448,7 @@ dir_check(VALUE dir)
#define GetDIR(obj, dirp) do {\
dir_check(dir);\
- Data_Get_Struct(obj, struct dir_data, dirp);\
+ TypedData_Get_Struct(obj, struct dir_data, &dir_data_type, dirp); \
if (dirp->dir == NULL) dir_closed();\
} while (0)
@@ -451,7 +464,7 @@ dir_inspect(VALUE dir)
{
struct dir_data *dirp;
- Data_Get_Struct(dir, struct dir_data, dirp);
+ TypedData_Get_Struct(dir, struct dir_data, &dir_data_type, dirp);
if (!NIL_P(dirp->path)) {
const char *c = rb_obj_classname(dir);
return rb_sprintf("#<%s:%s>", c, RSTRING_PTR(dirp->path));
@@ -473,7 +486,7 @@ dir_path(VALUE dir)
{
struct dir_data *dirp;
- Data_Get_Struct(dir, struct dir_data, dirp);
+ TypedData_Get_Struct(dir, struct dir_data, &dir_data_type, dirp);
if (NIL_P(dirp->path)) return Qnil;
return rb_str_dup(dirp->path);
}
@@ -1758,12 +1771,9 @@ static VALUE
dir_open_dir(int argc, VALUE *argv)
{
VALUE dir = rb_funcall2(rb_cDir, rb_intern("open"), argc, argv);
+ struct dir_data *dirp;
- if (TYPE(dir) != T_DATA ||
- RDATA(dir)->dfree != (RUBY_DATA_FUNC)free_dir) {
- rb_raise(rb_eTypeError, "wrong argument type %s (expected Dir)",
- rb_obj_classname(dir));
- }
+ TypedData_Get_Struct(dir, struct dir_data, &dir_data_type, dirp);
return dir;
}