[#390749] Why are there so many similar/identical methods in core classes — Kassym Dorsel <k.dorsel@...>

Let's look at the Array class and start with method aliases.

14 messages 2011/12/02

[#390755] Inverse Operation of Module#include — Su Zhang <su.comp.lang.ruby@...>

Hi list,

21 messages 2011/12/02
[#390759] Re: Inverse Operation of Module#include — Ryan Davis <ryand-ruby@...> 2011/12/02

[#390764] Re: Inverse Operation of Module#include — Isaac Sanders <isaacbfsanders@...> 2011/12/02

I would suggest an Adapter pattern use here. IF there is something that has

[#390876] black magical hash element vivification — Chad Perrin <code@...>

Ruby (1.9.3p0 to be precise, installed with RVM) is not behaving as I

12 messages 2011/12/05

[#390918] WEB SURVEY about Ruby Community — Intransition <transfire@...>

Did any one else get this survey request?

14 messages 2011/12/07

[#390976] Confusing results from string multiplication — Rob Marshall <robmarshall@...>

Hi,

19 messages 2011/12/08

[#391019] How can I do h["foo"] += "bar" if h["foo"] does not exist? — "Andrew S." <andrewinfosec@...>

Hi there,

13 messages 2011/12/09

[#391027] reading from file without end-of-lines — Janko Muzykant <umrzykus@...>

hi,

20 messages 2011/12/09
[#391028] Re: reading from file without end-of-lines — Gavin Sinclair <gsinclair@...> 2011/12/09

> i'm trying to read a few text values from single file:

[#391031] Re: reading from file without end-of-lines — Robert Klemme <shortcutter@...> 2011/12/09

On Fri, Dec 9, 2011 at 9:58 AM, Gavin Sinclair <gsinclair@gmail.com> wrote:

[#391042] Re: reading from file without end-of-lines — Gavin Sinclair <gsinclair@...> 2011/12/09

On Fri, Dec 9, 2011 at 8:18 PM, Robert Klemme

[#391135] I need advice on what to do next. — Nathan Kossaeth <system_freak_2004@...>

I am new to programming. I read the ebook "Learn to Program" by Chris

23 messages 2011/12/12

[#391216] perf optimization using profile results — Chuck Remes <cremes.devlist@...>

I need some help with optimizing a set of libraries that I use. They are ffi-rzmq, zmqmachine and rzmq_brokers (all up on github).

13 messages 2011/12/13
[#391218] Re: perf optimization using profile results — Chuck Remes <cremes.devlist@...> 2011/12/13

On Dec 13, 2011, at 9:57 AM, Chuck Remes wrote:

[#391234] Re: perf optimization using profile results — Charles Oliver Nutter <headius@...> 2011/12/14

A couple quick observations.

[#391238] Re: perf optimization using profile results — Chuck Remes <cremes.devlist@...> 2011/12/14

On Dec 13, 2011, at 7:03 PM, Charles Oliver Nutter wrote:

[#391324] ruby 1.9 threading performance goes non-linear — Joel VanderWerf <joelvanderwerf@...>

12 messages 2011/12/16
[#391325] Re: ruby 1.9 threading performance goes non-linear — Eric Wong <normalperson@...> 2011/12/16

Joel VanderWerf <joelvanderwerf@gmail.com> wrote:

[#391420] Accessing class instance variables from an instance? — "Shareef J." <shareef@...>

Hi there,

26 messages 2011/12/20
[#391454] Re: Accessing class instance variables from an instance? — Khat Harr <myphatproxy@...> 2011/12/21

Actually, now that I'm thinking about it the existing behavior sort of

[#391456] Re: Accessing class instance variables from an instance? — Josh Cheek <josh.cheek@...> 2011/12/21

On Tue, Dec 20, 2011 at 9:42 PM, Khat Harr <myphatproxy@hotmail.com> wrote:

[#391545] Kernel#exit raises an exception? — Khat Harr <myphatproxy@...>

While I was working on embedding an interpreter I wrote a function to

13 messages 2011/12/24

[#391618] rvmsh: An easy installer for RVM — Bryan Dunsmore <dunsmoreb@...>

I have recently begun work on a project called [rvmsh]

12 messages 2011/12/29

[#391783] Mailspam — Gunther Diemant <g.diemant@...>

Is there a way to stop this mailspam of Luca (Mail)?

12 messages 2011/12/29

[#391790] What’s the standard way of implementing #hash for value objects in Ruby? — Nikolai Weibull <now@...>

Hi!

23 messages 2011/12/29
[#391792] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Gunther Diemant <g.diemant@...> 2011/12/29

I think you can't access instance variables from a class method, so

[#391793] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Nikolai Weibull <now@...> 2011/12/29

On Thu, Dec 29, 2011 at 15:52, Gunther Diemant <g.diemant@gmx.net> wrote:

[#391811] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Robert Klemme <shortcutter@...> 2011/12/29

On Thu, Dec 29, 2011 at 4:06 PM, Nikolai Weibull <now@bitwi.se> wrote:

[#391812] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Nikolai Weibull <now@...> 2011/12/29

On Fri, Dec 30, 2011 at 00:26, Robert Klemme <shortcutter@googlemail.com> w=

[#391816] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Josh Cheek <josh.cheek@...> 2011/12/30

On Thu, Dec 29, 2011 at 5:47 PM, Nikolai Weibull <now@bitwi.se> wrote:

[#391833] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Robert Klemme <shortcutter@...> 2011/12/30

On Fri, Dec 30, 2011 at 12:47 AM, Nikolai Weibull <now@bitwi.se> wrote:

Re: [Ruby C] Using DATA_PTR in multiple methods

From: "Matthew S." <mattbastard@...>
Date: 2011-12-06 17:02:46 UTC
List: ruby-talk #390906
>
> First, it seems the allocation is done through tsk_img_open_sing().  So
> then in your allocate(), you actually want something like this:
>
> static VALUE allocate(VALUE klass){
>   TSK_IMG_INFO *ptr;
>   ptr = tsk_img_open_sing( ... );
>   return Data_Wrap_Struct(klass, 0, deallocate, ptr);
> }
>
> But are you sure that xfree() is the delete function corresponds to
> tsk_img_open_sing()?
>
> With this, the problem is that you cannot pass the filename (except
> maybe
> through some global variable), so you want to do it in the initialize().
> Then instead you can just use DATA_PTR directly:
>
> DATA_PTR(self) = tsk_img_open_sing(filename, TSK_IMG_TYPE_DETECT, 0);
>
> If this seems getting too "unclean", then you can use an intermediate
> handle:
>
> struct myHandle
> {
>   TSK_IMG_INFO *image;
> };
>
> static VALUE allocate(VALUE klass){
>   myHandle *ptr;
>   return Data_Make_Struct(klass, myHandle, 0, deallocate, ptr);
> } // but you have to modify deallocate()
>
> VALUE initialize(VALUE self){
>   ...
>   myHandle* ptr;
>   Data_Get_Struct(self, myHandle, ptr);
>   ptr->image = tsk_img_open_sing(filename, TSK_IMG_TYPE_DETECT, 0);
>   ...
> }
>
> Hope this helps.
>
> Regards,
>
> Bill

These were very helpful suggestions.  You're right, the
tsk_img_open_sing() function is the right way to go for allocation, and
the corresponding tsk_img_close() was the proper deallocation function.
Looking into the lib's source it became clear that the intention was to
protect alloc and dealloc by wrapping them in open() and close()
methods, which makes sense for an I/O module like this.  The lesson I
take from this is to follow the source library's way of doing things,
rather than seek a generic approach.

I was wary of opening the image during the ruby allocate() function, as
that seemed to violate Ruby's separation of concerns: allocate() is for
reserving memory, while init() is the place for constructing the object
itself.

I used your suggestion to wrap the TSK_IMG_INFO in another struct and my
init() went like so:

  struct myHandle* ptr;
  Data_Get_Struct(self, struct myHandle, ptr);
  ptr->image = tsk_img_open_sing(filename, TSK_IMG_TYPE_DETECT, 0);

with myHandle prototyped as you illustrated.  Assigning the
tsk_img_open() function to DATA_PTR(self) worked OK, but it made it
difficult to access components of the TSK_IMG_INFO struct, which made it
impractical.

With the intermediate handle in place, I was able to access the lower
level pointer in other instance methods like so:

TSK_IMG_INFO *image = ptr->image;

Which seems a safer means of retrieval than touching DATA_PTR.

Deallocation had to be re-written as follows, to dereference the
TSK_IMG_INFO pointer:

static void deallocate(struct myHandle * ptr){
  TSK_IMG_INFO *image = ptr->image;
  tsk_img_close(image);
}

Thanks for the enlightening suggestions.

Matthew S.

-- 
Posted via http://www.ruby-forum.com/.

In This Thread