aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/im-sandbox.c25
-rw-r--r--src/im-sandbox.h6
-rw-r--r--src/indexamajig.c10
3 files changed, 25 insertions, 16 deletions
diff --git a/src/im-sandbox.c b/src/im-sandbox.c
index ad2bc5fc..0f57fd0c 100644
--- a/src/im-sandbox.c
+++ b/src/im-sandbox.c
@@ -955,9 +955,11 @@ char *create_tempdir(const char *temp_location)
}
-void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
- int config_basename, FILE *fh,
- Stream *stream, const char *tmpdir, int serial_start)
+/* Returns the number of frames processed (not necessarily indexed).
+ * If the return value is zero, something is probably wrong. */
+int create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
+ int config_basename, FILE *fh,
+ Stream *stream, const char *tmpdir, int serial_start)
{
int i;
struct sandbox *sb;
@@ -977,7 +979,7 @@ void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
sb = calloc(1, sizeof(struct sandbox));
if ( sb == NULL ) {
ERROR("Couldn't allocate memory for sandbox.\n");
- return;
+ return 0;
}
sb->n_processed_last_stats = 0;
@@ -994,7 +996,7 @@ void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
if ( setup_shm(sb) ) {
ERROR("Failed to set up SHM.\n");
free(sb);
- return;
+ return 0;
}
sb->shared->n_processed = 0;
@@ -1007,7 +1009,7 @@ void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
S_IRUSR | S_IWUSR, 0);
if ( sb->queue_sem == SEM_FAILED ) {
ERROR("Failed to create semaphore: %s\n", strerror(errno));
- return;
+ return 0;
}
sb->pids = calloc(n_proc, sizeof(pid_t));
@@ -1017,7 +1019,7 @@ void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
|| (sb->last_response == NULL) )
{
ERROR("Couldn't allocate memory for PIDs.\n");
- return;
+ return 0;
}
/* Fill the queue */
@@ -1039,7 +1041,7 @@ void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
r = sigaction(SIGCHLD, &sa, NULL);
if ( r == -1 ) {
ERROR("Failed to set signal handler!\n");
- return;
+ return 0;
}
/* Set up signal handler to clean up semaphore on exit */
@@ -1049,12 +1051,12 @@ void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
r = sigaction(SIGINT, &sa, NULL);
if ( r == -1 ) {
ERROR("Failed to set signal handler!\n");
- return;
+ return 0;
}
r = sigaction(SIGQUIT, &sa, NULL);
if ( r == -1 ) {
ERROR("Failed to set signal handler!\n");
- return;
+ return 0;
}
taccs = time_accounts_init();
@@ -1145,9 +1147,12 @@ void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
sb->shared->n_processed, sb->shared->n_hadcrystals,
100.0 * sb->shared->n_hadcrystals / sb->shared->n_processed,
sb->shared->n_crystals);
+ r = sb->shared->n_processed;
delete_temporary_folder(sb->tmpdir, n_proc);
munmap(sb->shared, sizeof(struct sb_shm));
free(sb);
+
+ return r;
}
diff --git a/src/im-sandbox.h b/src/im-sandbox.h
index e5f3422b..eddced68 100644
--- a/src/im-sandbox.h
+++ b/src/im-sandbox.h
@@ -80,8 +80,8 @@ extern char *create_tempdir(const char *temp_location);
extern void set_last_task(char *lt, const char *task);
-extern void create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
- int config_basename, FILE *fh, Stream *stream,
- const char *tempdir, int serial_start);
+extern int create_sandbox(struct index_args *iargs, int n_proc, char *prefix,
+ int config_basename, FILE *fh, Stream *stream,
+ const char *tempdir, int serial_start);
#endif /* IM_SANDBOX_H */
diff --git a/src/indexamajig.c b/src/indexamajig.c
index f9b2c94d..f452b033 100644
--- a/src/indexamajig.c
+++ b/src/indexamajig.c
@@ -1288,8 +1288,8 @@ int main(int argc, char *argv[])
gsl_set_error_handler_off();
- create_sandbox(&iargs, n_proc, prefix, config_basename, fh,
- st, tmpdir, serial_start);
+ r = create_sandbox(&iargs, n_proc, prefix, config_basename, fh,
+ st, tmpdir, serial_start);
free_imagefile_field_list(iargs.copyme);
cell_free(iargs.cell);
@@ -1302,5 +1302,9 @@ int main(int argc, char *argv[])
close_stream(st);
cleanup_indexing(iargs.ipriv);
- return 0;
+ if ( r ) {
+ return 0;
+ } else {
+ return 1; /* No patterns processed */
+ }
}