aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2019-07-04 14:31:43 +0200
committerThomas White <taw@physics.org>2019-07-05 11:54:08 +0200
commitd62367db8fee57c01a76543fafb84313329c3650 (patch)
tree6c196ed5bd6a5568dbb165901c582a9e7c7c2360
parent9c97f8f5c0aacec6d4098f1bea89e8b08f7169fe (diff)
Add get_detector_geometry_from_string()
-rw-r--r--libcrystfel/src/detector.c92
-rw-r--r--libcrystfel/src/detector.h6
2 files changed, 79 insertions, 19 deletions
diff --git a/libcrystfel/src/detector.c b/libcrystfel/src/detector.c
index 2fb373f8..60e7528a 100644
--- a/libcrystfel/src/detector.c
+++ b/libcrystfel/src/detector.c
@@ -37,6 +37,7 @@
#include <string.h>
#include <assert.h>
#include <ctype.h>
+#include <sys/stat.h>
#include "image.h"
#include "utils.h"
@@ -1170,6 +1171,7 @@ static void find_min_max_d(struct detector *det)
}
}
+
struct detector *get_detector_geometry(const char *filename,
struct beam_params *beam)
{
@@ -1177,14 +1179,13 @@ struct detector *get_detector_geometry(const char *filename,
}
-struct detector *get_detector_geometry_2(const char *filename,
- struct beam_params *beam,
- char **hdf5_peak_path)
+struct detector *get_detector_geometry_from_string(const char *string,
+ struct beam_params *beam,
+ char **hdf5_peak_path)
{
- FILE *fh;
struct detector *det;
- char *rval;
char **bits;
+ int done = 0;
int i;
int rgi, rgci;
int reject = 0;
@@ -1197,14 +1198,8 @@ struct detector *get_detector_geometry_2(const char *filename,
int n_rg_definitions = 0;
int n_rgc_definitions = 0;
- fh = fopen(filename, "r");
- if ( fh == NULL ) return NULL;
-
det = calloc(1, sizeof(struct detector));
- if ( det == NULL ) {
- fclose(fh);
- return NULL;
- }
+ if ( det == NULL ) return NULL;
if ( beam != NULL ) {
beam->photon_energy = 0.0;
@@ -1262,14 +1257,21 @@ struct detector *get_detector_geometry_2(const char *filename,
int n1, n2;
char **path;
- char line[1024];
+ char *line;
struct badregion *badregion = NULL;
struct panel *panel = NULL;
char wholeval[1024];
- rval = fgets(line, 1023, fh);
- if ( rval == NULL ) break;
- chomp(line);
+ const char *nl = strchr(string, '\n');
+ if ( nl != NULL ) {
+ size_t len = nl - string;
+ line = strndup(string, nl-string);
+ line[len] = '\0';
+ string += len+1;
+ } else {
+ line = strdup(string);
+ done = 1;
+ }
if ( line[0] == ';' ) continue;
@@ -1336,11 +1338,10 @@ struct detector *get_detector_geometry_2(const char *filename,
free(bits);
free(path);
- } while ( rval != NULL );
+ } while ( !done );
if ( det->n_panels == -1 ) {
ERROR("No panel descriptions in geometry file.\n");
- fclose(fh);
free(det);
return NULL;
}
@@ -1702,8 +1703,63 @@ struct detector *get_detector_geometry_2(const char *filename,
if ( reject ) return NULL;
+ return det;
+}
+
+
+char *load_entire_file(const char *filename)
+{
+ struct stat statbuf;
+ int r;
+ char *contents;
+ FILE *fh;
+
+ r = stat(filename, &statbuf);
+ if ( r != 0 ) {
+ ERROR("File '%s' not found\n", filename);
+ return NULL;
+ }
+
+ contents = malloc(statbuf.st_size);
+ if ( contents == NULL ) {
+ ERROR("Failed to allocate memory for file\n");
+ return NULL;
+ }
+
+ fh = fopen(filename, "r");
+ if ( fh == NULL ) {
+ ERROR("Failed to open file '%s'\n", filename);
+ free(contents);
+ return NULL;
+ }
+
+ if ( fread(contents, 1, statbuf.st_size, fh) != statbuf.st_size ) {
+ ERROR("Failed to read file '%s'\n", filename);
+ free(contents);
+ return NULL;
+ }
+
fclose(fh);
+ return contents;
+}
+
+
+struct detector *get_detector_geometry_2(const char *filename,
+ struct beam_params *beam,
+ char **hdf5_peak_path)
+{
+ char *contents;
+ struct detector *det;
+
+ contents = load_entire_file(filename);
+ if ( contents == NULL ) {
+ ERROR("Failed to load geometry file '%s'\n", filename);
+ return NULL;
+ }
+
+ det = get_detector_geometry_from_string(contents, beam, hdf5_peak_path);
+ free(contents);
return det;
}
diff --git a/libcrystfel/src/detector.h b/libcrystfel/src/detector.h
index 2abd928a..0b216715 100644
--- a/libcrystfel/src/detector.h
+++ b/libcrystfel/src/detector.h
@@ -272,7 +272,11 @@ extern struct detector *get_detector_geometry(const char *filename,
extern struct detector *get_detector_geometry_2(const char *filename,
struct beam_params *beam,
- char **hdf5_peak_path);
+ char **hdf5_peak_path);
+
+extern struct detector *get_detector_geometry_from_string(const char *string,
+ struct beam_params *beam,
+ char **hdf5_peak_path);
extern void free_detector_geometry(struct detector *det);