Slash Boxes
NOTE: use Perl; is on undef hiatus. You can read content, but you can't post it. More info will be forthcoming forthcomingly.

All the Perl that's Practical to Extract and Report

use Perl Log In

Log In

[ Create a new account ]

xsawyerx (8978)

  (email not shown publicly)

Journal of xsawyerx (8978)

Wednesday February 24, 2010
07:40 AM

Writing your own Search::GIN extractor

[ #40207 ]

original post can be found on my blog. note: It has code embedded so it's easier to view it there.

I stumbled into a tricky situation with Search::GIN that required me to have a reverse indexing with set introspection. This situation isn't so rare, so I thought it would be helpful to share how I did it.

Suppose I have an object. The object has an attribute. The attribute is a set of objects. I need to be able to fetch the objects according to the value of an attribute of the objects in the set in the attribute of the original object. Err.. ya know what? Here's an example!

I have a few music preferences (blues, jazz, etc.), a few simpsons characters (Lisa, Homer, Barney). Each of them likes certain types of music. Lisa likes blues and jazz, while Barney only likes blues and Homer just likes stupid commercial jingles.

First define the objects:
See here

The create them:
See here

I want to be able to fetch all the people who like a certain type of music. This is a bit difficult since a person likes a set of music styles. Search::GIN::Extract::Attributes doesn't cover sets (though it would be cool if it could in the future) and I obviously don't want to go over all characters and do it.

Instead I wrote an extractor that does that:
See here

In order to use this extractor, in my DB interface (which extends KiokuX::Model) I do this:
See here

And viola!

Now using Search::GIN::Query::Manual, I can search for any Character that likes Blues music:
See here

I wanted to write all the code in this post but for some reason I can't put more than a few lines of code here and it always double spaces it. How do others put code here?

The Fine Print: The following comments are owned by whoever posted them. We are not responsible for them in any way.
More | Login | Reply
Loading... please wait.