[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[GNUnet-SVN] r11526 - gnunet/src/fs
From: |
gnunet |
Subject: |
[GNUnet-SVN] r11526 - gnunet/src/fs |
Date: |
Wed, 26 May 2010 21:55:24 +0200 |
Author: grothoff
Date: 2010-05-26 21:55:24 +0200 (Wed, 26 May 2010)
New Revision: 11526
Modified:
gnunet/src/fs/fs.h
gnunet/src/fs/fs_unindex.c
gnunet/src/fs/gnunet-service-fs_indexing.c
Log:
change unindex processing order to avoid transient dangling DB entries
Modified: gnunet/src/fs/fs.h
===================================================================
--- gnunet/src/fs/fs.h 2010-05-26 19:13:02 UTC (rev 11525)
+++ gnunet/src/fs/fs.h 2010-05-26 19:55:24 UTC (rev 11526)
@@ -1352,16 +1352,16 @@
UNINDEX_STATE_HASHING = 0,
/**
- * We're notifying the FS service about
- * the unindexing.
+ * We're telling the datastore to delete
+ * the respective entries.
*/
- UNINDEX_STATE_FS_NOTIFY = 1,
+ UNINDEX_STATE_DS_REMOVE = 1,
/**
- * We're telling the datastore to delete
- * the respective entries.
+ * We're notifying the FS service about
+ * the unindexing.
*/
- UNINDEX_STATE_DS_REMOVE = 2,
+ UNINDEX_STATE_FS_NOTIFY = 2,
/**
* We're done.
Modified: gnunet/src/fs/fs_unindex.c
===================================================================
--- gnunet/src/fs/fs_unindex.c 2010-05-26 19:13:02 UTC (rev 11525)
+++ gnunet/src/fs/fs_unindex.c 2010-05-26 19:55:24 UTC (rev 11526)
@@ -226,49 +226,6 @@
/**
- * Function called when the tree encoder has
- * processed all blocks. Clean up.
- *
- * @param cls our unindexing context
- * @param tc not used
- */
-static void
-unindex_finish (void *cls,
- const struct GNUNET_SCHEDULER_TaskContext *tc)
-{
- struct GNUNET_FS_UnindexContext *uc = cls;
- char *emsg;
- struct GNUNET_FS_Uri *uri;
- struct GNUNET_FS_ProgressInfo pi;
-
- GNUNET_FS_tree_encoder_finish (uc->tc,
- &uri,
- &emsg);
- uc->tc = NULL;
- if (uri != NULL)
- GNUNET_FS_uri_destroy (uri);
- GNUNET_DISK_file_close (uc->fh);
- uc->fh = NULL;
- GNUNET_DATASTORE_disconnect (uc->dsh, GNUNET_NO);
- uc->dsh = NULL;
- if (emsg != NULL)
- {
- uc->state = UNINDEX_STATE_ERROR;
- uc->emsg = emsg;
- signal_unindex_error (uc);
- }
- else
- {
- uc->state = UNINDEX_STATE_COMPLETE;
- pi.status = GNUNET_FS_STATUS_UNINDEX_COMPLETED;
- pi.value.unindex.eta = GNUNET_TIME_UNIT_ZERO;
- GNUNET_FS_unindex_make_status_ (&pi, uc, uc->file_size);
- }
- GNUNET_FS_unindex_sync_ (uc);
-}
-
-
-/**
* Function called with the response from the
* FS service to our unindexing request.
*
@@ -280,6 +237,7 @@
const struct GNUNET_MessageHeader *msg)
{
struct GNUNET_FS_UnindexContext *uc = cls;
+ struct GNUNET_FS_ProgressInfo pi;
if (uc->client != NULL)
{
@@ -291,7 +249,7 @@
uc->state = UNINDEX_STATE_ERROR;
uc->emsg = GNUNET_strdup (_("Unexpected time for a response from `fs'
service."));
GNUNET_FS_unindex_sync_ (uc);
- signal_unindex_error (uc);
+ signal_unindex_error (uc);
return;
}
if (NULL == msg)
@@ -310,13 +268,60 @@
signal_unindex_error (uc);
return;
}
- uc->state = UNINDEX_STATE_DS_REMOVE;
+ uc->state = UNINDEX_STATE_COMPLETE;
+ pi.status = GNUNET_FS_STATUS_UNINDEX_COMPLETED;
+ pi.value.unindex.eta = GNUNET_TIME_UNIT_ZERO;
GNUNET_FS_unindex_sync_ (uc);
- GNUNET_FS_unindex_do_remove_ (uc);
+ GNUNET_FS_unindex_make_status_ (&pi, uc, uc->file_size);
}
/**
+ * Function called when the tree encoder has
+ * processed all blocks. Clean up.
+ *
+ * @param cls our unindexing context
+ * @param tc not used
+ */
+static void
+unindex_finish (void *cls,
+ const struct GNUNET_SCHEDULER_TaskContext *tc)
+{
+ struct GNUNET_FS_UnindexContext *uc = cls;
+ char *emsg;
+ struct GNUNET_FS_Uri *uri;
+ struct UnindexMessage req;
+
+ GNUNET_FS_tree_encoder_finish (uc->tc,
+ &uri,
+ &emsg);
+ uc->tc = NULL;
+ if (uri != NULL)
+ GNUNET_FS_uri_destroy (uri);
+ GNUNET_DISK_file_close (uc->fh);
+ uc->fh = NULL;
+ GNUNET_DATASTORE_disconnect (uc->dsh, GNUNET_NO);
+ uc->dsh = NULL;
+ uc->state = UNINDEX_STATE_FS_NOTIFY;
+ GNUNET_FS_unindex_sync_ (uc);
+ uc->client = GNUNET_CLIENT_connect (uc->h->sched,
+ "fs",
+ uc->h->cfg);
+ req.header.size = htons (sizeof (struct UnindexMessage));
+ req.header.type = htons (GNUNET_MESSAGE_TYPE_FS_UNINDEX);
+ req.reserved = 0;
+ req.file_id = uc->file_id;
+ GNUNET_break (GNUNET_OK ==
+ GNUNET_CLIENT_transmit_and_get_response (uc->client,
+ &req.header,
+
GNUNET_CONSTANTS_SERVICE_TIMEOUT,
+ GNUNET_YES,
+ &process_fs_response,
+ uc));
+}
+
+
+/**
* Connect to the datastore and remove the blocks.
*
* @param uc context for the unindex operation.
@@ -370,7 +375,6 @@
const GNUNET_HashCode *file_id)
{
struct GNUNET_FS_UnindexContext *uc = cls;
- struct UnindexMessage req;
uc->fhc = NULL;
if (uc->state != UNINDEX_STATE_HASHING)
@@ -387,22 +391,9 @@
return;
}
uc->file_id = *file_id;
- uc->state = UNINDEX_STATE_FS_NOTIFY;
+ uc->state = UNINDEX_STATE_DS_REMOVE;
GNUNET_FS_unindex_sync_ (uc);
- uc->client = GNUNET_CLIENT_connect (uc->h->sched,
- "fs",
- uc->h->cfg);
- req.header.size = htons (sizeof (struct UnindexMessage));
- req.header.type = htons (GNUNET_MESSAGE_TYPE_FS_UNINDEX);
- req.reserved = 0;
- req.file_id = *file_id;
- GNUNET_break (GNUNET_OK ==
- GNUNET_CLIENT_transmit_and_get_response (uc->client,
- &req.header,
-
GNUNET_CONSTANTS_SERVICE_TIMEOUT,
- GNUNET_YES,
- &process_fs_response,
- uc));
+ GNUNET_FS_unindex_do_remove_ (uc);
}
Modified: gnunet/src/fs/gnunet-service-fs_indexing.c
===================================================================
--- gnunet/src/fs/gnunet-service-fs_indexing.c 2010-05-26 19:13:02 UTC (rev
11525)
+++ gnunet/src/fs/gnunet-service-fs_indexing.c 2010-05-26 19:55:24 UTC (rev
11526)
@@ -206,7 +206,6 @@
GNUNET_free (fn);
return;
}
-
while ( (GNUNET_OK ==
GNUNET_BIO_read (rh,
"Hash of indexed file",
@@ -478,7 +477,7 @@
struct IndexInfo *next;
struct GNUNET_SERVER_TransmitContext *tc;
int found;
-
+
um = (const struct UnindexMessage*) message;
found = GNUNET_NO;
prev = NULL;
@@ -494,6 +493,10 @@
indexed_files = next;
else
prev->next = next;
+ GNUNET_break (GNUNET_OK ==
+ GNUNET_CONTAINER_multihashmap_remove (ifm,
+ &pos->file_id,
+ (void*)
pos->filename));
GNUNET_free (pos);
found = GNUNET_YES;
}
@@ -621,7 +624,7 @@
GNUNET_h2s (&odb->file_id),
fn,
(unsigned long long) off,
- STRERROR (errno));
+ (fn == NULL) ? _("not indexed") : STRERROR (errno));
if (fh != NULL)
GNUNET_DISK_file_close (fh);
GNUNET_DATASTORE_remove (dsh,
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [GNUnet-SVN] r11526 - gnunet/src/fs,
gnunet <=