From 2f95f6bbefc52f171610f8a4c49157907ced3e14 Mon Sep 17 00:00:00 2001 From: Tilman Sauerbeck Date: Thu, 17 Aug 2006 21:23:07 +0200 Subject: [PATCH] Made the Ogg::Vorbis::Tagger object inaccessable after #close was called. --- ext/ext.c | 15 +++++++++++++-- test/test_main.rb | 12 ++++++++++++ 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/ext/ext.c b/ext/ext.c index 67fa6b1..6a45359 100644 --- a/ext/ext.c +++ b/ext/ext.c @@ -25,6 +25,10 @@ #include "vcedit.h" #include "comments.h" +#define CHECK_CLOSED(o) \ + if (!o->state) \ + rb_raise (eClosed, "closed stream"); + typedef struct { vcedit_state *state; VALUE comments; @@ -32,8 +36,8 @@ typedef struct { static VALUE c_close (VALUE self); -static VALUE cComments, eVT, eOpen, eInvalidData, eInvalidComment, - eTempFile, eReopen; +static VALUE cComments, eVT, eClosed, eOpen, eInvalidData, + eInvalidComment, eTempFile, eReopen; static ID id_length; static void @@ -149,6 +153,8 @@ c_close (VALUE self) Data_Get_Struct (self, RbVorbisTagger, o); + CHECK_CLOSED (o); + vcedit_state_unref (o->state); o->state = NULL; @@ -169,6 +175,8 @@ c_write (VALUE self) Data_Get_Struct (self, RbVorbisTagger, o); + CHECK_CLOSED (o); + comments_sync (o->comments, o->state); switch (vcedit_write (o->state)) { @@ -199,6 +207,8 @@ c_comments (VALUE self) Data_Get_Struct (self, RbVorbisTagger, o); + CHECK_CLOSED (o); + return o->comments; } @@ -225,6 +235,7 @@ Init_vorbistagger_ext (void) rb_define_method (cVT, "comments", c_comments, 0); eVT = rb_define_class_under (cVT, "TaggerError", eVorbis); + eClosed = rb_define_class_under (cVT, "ClosedStreamError", eVT); eOpen = rb_define_class_under (cVT, "OpenError", eVT); eInvalidData = rb_define_class_under (cVT, "InvalidDataError", eVT); eInvalidComment = rb_define_class_under (cVT, "InvalidCommentError", diff --git a/test/test_main.rb b/test/test_main.rb index 6da6d6d..3b57719 100644 --- a/test/test_main.rb +++ b/test/test_main.rb @@ -253,6 +253,18 @@ EOF Ogg::Vorbis::Tagger.new(OGG_FILE).close end + def test_close2 + assert_raise(Ogg::Vorbis::Tagger::ClosedStreamError) do + Ogg::Vorbis::Tagger.new(OGG_FILE).close.close + end + + assert_raise(Ogg::Vorbis::Tagger::ClosedStreamError) do + Ogg::Vorbis::Tagger.open(OGG_FILE) do |t| + t.close + end + end + end + def test_open_non_existing_file assert_raises(Ogg::Vorbis::Tagger::OpenError) do Ogg::Vorbis::Tagger.new("foo.bar") -- 2.30.2