Re: librados compound operations

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Mar 28, 2011 at 03:46:21PM -0700, Sage Weil wrote:
> One weird thing I noticed is with the constructor.  In Rados:: did
> 
> +    static ObjectOperation *operation_create();
> 
> and the user then deletes it when they're done (after using it for one or 
> more calls to operate() or aio_operate()).  Is that the the approach we 
> want?  Because right above that in the header is
> 
>      int ioctx_create(const char *name, IoCtx &pioctx);
> 
> which is a totally different convention.  It does match

The usual argument about that is that returning a pointer is only good
when the only possible failure, now and forever, is running out of
memory. The int can communicate more reasons for failure.

So the real question to ask is, how guaranteed is that to work? For
example, in the case of ioctx, the extra name argument might need to
be unique among concurrent operations, etc.

> +void librados::ObjectOperation::write(uint64_t off, const bufferlist& bl)
> +{
> +  ::ObjectOperation *o = (::ObjectOperation *)impl;
> +  bufferlist c = bl;
> +  o->write(off, c);
> +}

Losing constness always makes me a bit sad.

-- 
:(){ :|:&};:
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [CEPH Users]     [Ceph Large]     [Information on CEPH]     [Linux BTRFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux