You can access the class index cursor using:
'make-class-cursor' for all instances and
'make-inverted-cursor' on a specific slot index

You can also use the convenience macros:
'with-inverted-cursor' and 'with-class-cursor'

These will be documented in the new manual, but for now you can look at them
in src/elephant/classindex.lisp.

You can rely on get-instances-by-range returning ascending orders, but you shouldn't
rely on the ordering of duplicates.

You do make the good point that I should add an option to the map operators to return
objects in reverse order.  I'll think about this.

Ian

On Apr 22, 2007, at 5:34 AM, Mac Chan wrote:

Hi Ian,

On 4/21/07, Ian Eslick <[EMAIL PROTECTED]> wrote:
This example could be done even more cleanly using the class indexing
facilities.  If you feel inclined to experiment with them, this would
be a good contribution to improve the example.

Actually it turned out to be an interesting exercise. Please see the
attached file.

I have some questions, though.


* Displaying all the blog entries in descending order

Using the b-tree index, one could iterate through the entries with a
cursor as shown in the original example code:

(with-btree-cursor (curs *my-blog*)
 (loop
  for (m k v) = (multiple-value-list (cursor-first curs))
  then (multiple-value-list (cursor-next curs))
  while m
  collect v))

Now after I replace the explicit index with a class index, I couldn't
figure out how to use cursor on the class index. Maybe there's an
undocumented way to do this?

(loop
for v in
(sort (get-instances-by-class 'blog-entry) #'> :key #'entry-date)
collect v)

Now I have to get all the instances from that class. I assumed the
result returned by get-instances-by-class is just a list of OID's?
Elephant will only fetch the values when I use the accessor functions
on the OID handle, right?

Another downside with this approach is that I need to manually sort
the entries (I guess if my assumption from the previous paragraph is
true, then I'm really paying the penalty here if there are a lot of
entries to sort) whereas in the original code it's taken care of by
the cursor API.




* Displaying all the blog entries for a particular month in descending
order

(with-btree-cursor (curs (get-index *my-blog* 'month))
 (loop
  for (m k v) = (multiple-value-list
                 (cursor-set curs month-year))
  then (multiple-value-list (cursor-next-dup curs))
  while m
  collect v))

(loop
for v in
(multiple-value-bind (start end)
    (the-month-range month-year)
  (nreverse (get-instances-by-range 'blog-entry 'date start end)))
collect v)

In this case both the cursor and the get-instances-by-range API are
rather easy to use. Unlike get-instances-by-class,
get-instances-by-range seems to always return the result sorted, is
that correct?

When I first read the documenation, I couldn't think of a use case for
cursor-next-dup.  It is really handy as shown in the original example.




* Displaying href links to previous blog entries (month/year)

(loop
for (m k v) = (multiple-value-list (cursor-first curs))
then (multiple-value-list (cursor-next-nodup curs))
while m
collect v)))

(let ((month-year))
 (loop
  for entry in (get-instances-by-class 'blog-entry) do
  (multiple-value-bind (second minute hour date month year)
      (decode-universal-time (entry-date entry))
    (declare (ignore second minute hour date))
    (pushnew (encode-universal-time 0 0 0 1 month year) month-year)))
 (sort month-year #'>))

Now the cursor API is much easier to use in this case. Again, since I
can't figure out a way to use cursor on the class index, I need to go
through _all_ the entries, collect and sort the date myself.

I believe I'm not using this stuff right, so please show us the way :-)

Regards,
-- Mac
<hunchentoot.blog.lisp>
_______________________________________________
elephant-devel site list
elephant-devel@common-lisp.net
http://common-lisp.net/mailman/listinfo/elephant-devel

_______________________________________________
elephant-devel site list
elephant-devel@common-lisp.net
http://common-lisp.net/mailman/listinfo/elephant-devel

Reply via email to