Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar
diff options
context:
space:
mode:
authorTomeu Vizoso <tomeu@tomeuvizoso.net>2007-09-10 16:03:40 (GMT)
committer Tomeu Vizoso <tomeu@tomeuvizoso.net>2007-09-10 16:03:40 (GMT)
commit79237f31140ff90e79937c821ebf00600eece1e7 (patch)
tree37386824c9ecb36bb3294fe412e24aba91365b24 /sugar
parente9449d0ab047108d137283ed711574f1ef236684 (diff)
Add a parameter to datastore.find() for filtering out unwanted metadata properties.
Diffstat (limited to 'sugar')
-rw-r--r--sugar/datastore/datastore.py22
-rw-r--r--sugar/datastore/dbus_helpers.py8
2 files changed, 20 insertions, 10 deletions
diff --git a/sugar/datastore/datastore.py b/sugar/datastore/datastore.py
index 2ab2426..eb88458 100644
--- a/sugar/datastore/datastore.py
+++ b/sugar/datastore/datastore.py
@@ -158,7 +158,7 @@ class DSObject(object):
def destroy(self):
if self._destroyed:
logging.warning('This DSObject has already been destroyed!.')
- import pdb;pdb.set_trace()
+ import traceback;traceback.print_stack()
return
self._destroyed = True
if self._file_path and self._owns_file:
@@ -199,17 +199,27 @@ def write(ds_object, update_mtime=True, transfer_ownership=False, reply_handler=
properties['mtime'] = datetime.now().isoformat()
properties['timestamp'] = int(time.time())
+ if ds_object._file_path is None:
+ file_path = ''
+ else:
+ file_path = ds_object._file_path
+
+ # FIXME: this func will be sync for creates regardless of the handlers
+ # supplied. This is very bad API, need to decide what to do here.
if ds_object.object_id:
dbus_helpers.update(ds_object.object_id,
properties,
- ds_object.file_path,
+ file_path,
transfer_ownership,
reply_handler=reply_handler,
error_handler=error_handler,
timeout=timeout)
else:
+ if reply_handler or error_handler:
+ logging.warning('datastore.write() cannot currently be called async' \
+ ' for creates, see https://dev.laptop.org/ticket/3071')
ds_object.object_id = dbus_helpers.create(properties,
- ds_object.file_path,
+ file_path,
transfer_ownership)
# TODO: register the object for updates
logging.debug('Written object %s to the datastore.' % ds_object.object_id)
@@ -218,8 +228,8 @@ def delete(object_id):
logging.debug('datastore.delete')
dbus_helpers.delete(object_id)
-def find(query, sorting=None, limit=None, offset=None, reply_handler=None,
- error_handler=None):
+def find(query, sorting=None, limit=None, offset=None, properties=[],
+ reply_handler=None, error_handler=None):
query = query.copy()
@@ -230,7 +240,7 @@ def find(query, sorting=None, limit=None, offset=None, reply_handler=None,
if offset:
query['offset'] = offset
- props_list, total_count = dbus_helpers.find(query, reply_handler, error_handler)
+ props_list, total_count = dbus_helpers.find(query, properties, reply_handler, error_handler)
objects = []
for props in props_list:
diff --git a/sugar/datastore/dbus_helpers.py b/sugar/datastore/dbus_helpers.py
index 88dfb6d..b0b636c 100644
--- a/sugar/datastore/dbus_helpers.py
+++ b/sugar/datastore/dbus_helpers.py
@@ -74,13 +74,13 @@ def get_filename(uid):
logging.debug('dbus_helpers.get_filename: %s, %s' % (uid, filename))
return filename
-def find(query, reply_handler, error_handler):
+def find(query, properties, reply_handler, error_handler):
logging.debug('dbus_helpers.find: %r' % query)
if reply_handler and error_handler:
- return _get_data_store().find(query, reply_handler=reply_handler,
- error_handler=error_handler)
+ return _get_data_store().find(query, properties,
+ reply_handler=reply_handler, error_handler=error_handler)
else:
- return _get_data_store().find(query)
+ return _get_data_store().find(query, properties)
def mount(uri, options):
return _get_data_store().mount(uri, options)