From c833ece5f78b8c2e43263e08ccbd3ce1628bf610 Mon Sep 17 00:00:00 2001 From: Samuel Williams Date: Fri, 22 Oct 2021 15:05:00 +1300 Subject: Rework implementation of `IO::Buffer.for(string)` to use string locking. --- io_buffer.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) (limited to 'io_buffer.c') diff --git a/io_buffer.c b/io_buffer.c index 1acc942987..9b8f85ed4c 100644 --- a/io_buffer.c +++ b/io_buffer.c @@ -182,6 +182,10 @@ io_buffer_free(struct rb_io_buffer *data) io_buffer_unmap(data->base, data->size); } + if (RB_TYPE_P(data->source, T_STRING)) { + rb_str_unlocktmp(data->source); + } + data->base = NULL; #if defined(_WIN32) @@ -252,6 +256,21 @@ rb_io_buffer_type_allocate(VALUE self) return instance; } +VALUE +rb_io_buffer_type_for(VALUE klass, VALUE string) +{ + VALUE instance = rb_io_buffer_type_allocate(klass); + + struct rb_io_buffer *data = NULL; + TypedData_Get_Struct(instance, struct rb_io_buffer, &rb_io_buffer_type, data); + + rb_str_locktmp(string); + + io_buffer_initialize(data, RSTRING_PTR(string), RSTRING_LEN(string), RB_IO_BUFFER_EXTERNAL, string); + + return instance; +} + VALUE rb_io_buffer_new(void *base, size_t size, enum rb_io_buffer_flags flags) { @@ -1029,6 +1048,7 @@ Init_IO_Buffer(void) rb_cIOBuffer = rb_define_class_under(rb_cIO, "Buffer", rb_cObject); rb_define_alloc_func(rb_cIOBuffer, rb_io_buffer_type_allocate); + rb_define_singleton_method(rb_cIOBuffer, "for", rb_io_buffer_type_for, 1); #ifdef _WIN32 SYSTEM_INFO info; -- cgit v1.2.1