diff options
Diffstat (limited to '')
| -rw-r--r-- | src/librarian.c | 75 | 
1 files changed, 30 insertions, 45 deletions
| diff --git a/src/librarian.c b/src/librarian.c index 8ed9f74..95f880e 100644 --- a/src/librarian.c +++ b/src/librarian.c @@ -482,16 +482,17 @@ fail:  /**   * Find librarian files for all libraries.   *  + * Found files are appended to `found_files`. + *    * @param   libraries  The sought libraries.   * @param   n          The number of elements in `libraries`.   * @param   path       LIBRARIAN_PATH.   * @param   oldest     Are older versions prefered? - * @return             `NULL`-terminated list of librarian files. - *                     `NULL` if all where not found, or on error, - *                     on failure to find librarian files, `errno` - *                     is set to 0. + * @return             0:             Successful and found all files. + *                     -1 and !errno: Did not find all files, but otherwise successful. + *                     -1 and errno:  An error occurred   */ -static char **find_librarian_files(struct library *libraries, size_t n, char *path, int oldest) +static int find_librarian_files(struct library *libraries, size_t n, char *path, int oldest)  {  	size_t i;  	char *best = NULL; @@ -499,24 +500,21 @@ static char **find_librarian_files(struct library *libraries, size_t n, char *pa  	char *best_ver;  	char *found_ver;  	const char *last = NULL; -	char **rc = NULL;  	void *new; -	size_t ptr = 0; -	int r, saved_errno; +	size_t ffc = found_files_count; +	int r;  	struct found_file f;  	struct found_file *have;  	qsort(libraries, n, sizeof(*libraries), library_name_cmp); -	qsort(found_files, found_files_count, sizeof(*found_files), found_file_name_cmp); -	rc = malloc((n + 1) * sizeof(*rc)); -	t (rc == NULL); -	new = realloc(found_files, (found_files_count + n) * sizeof(*found_files)); +	qsort(found_files, ffc, sizeof(*found_files), found_file_name_cmp); +	new = realloc(found_files, (ffc + n) * sizeof(*found_files));  	t (new == NULL);  	found_files = new;  	for (i = 0; i < n; i++) {  		f.name = libraries[i].name; -		have = bsearch(&f, found_files, found_files_count, sizeof(*found_files), found_file_name_cmp); +		have = bsearch(&f, found_files, ffc, sizeof(*found_files), found_file_name_cmp);  		if (have) {  			if (test_library_version(have->version, libraries + i))  				continue; @@ -536,15 +534,14 @@ static char **find_librarian_files(struct library *libraries, size_t n, char *pa                          if (r)  				free(best);  		} else { -			r = 1, ptr++; +			r = 1, found_files_count++;  		}  		if (r) { -			rc[ptr - 1] = best = found;  			found_ver = strrchr(found, '=');                          assert(found_ver && !strchr(found_ver, '/')); -			found_files[found_files_count + ptr - 1].name = f.name; -			found_files[found_files_count + ptr - 1].version = found_ver + 1; -			found_files[found_files_count + ptr - 1].path = found; +			found_files[found_files_count - 1].name = f.name; +			found_files[found_files_count - 1].version = found_ver + 1; +			found_files[found_files_count - 1].path = best = found;  		}  		last = f.name;  		continue; @@ -557,31 +554,24 @@ static char **find_librarian_files(struct library *libraries, size_t n, char *pa  		continue;  	} -	found_files_count += ptr; -	rc[ptr++] = NULL; -	return rc; +	return 0;  not_found: -	if (libraries[0].upper == libraries[0].lower) { +	if (libraries[i].upper == libraries[i].lower) {  		fprintf(stderr, "%s: cannot find library: %s%s%s", argv0, -			libraries[0].name, libraries[0].upper ? "=" : "", -			libraries[0].upper); +			libraries[i].name, libraries[i].upper ? "=" : "", +			libraries[i].upper);  	} else {  		fprintf(stderr, "%s: cannot find library: %s%s%s%s%s%s%s", argv0, -			libraries[0].name, -			libraries[0].lower ? ">" : "", libraries[0].lower_closed ? "=" : "", -			libraries[0].lower ? libraries[0].lower : "", -			libraries[0].upper ? "<" : "", libraries[0].upper_closed ? "=" : "", -			libraries[0].upper ? libraries[0].upper : ""); +			libraries[i].name, +			libraries[i].lower ? ">" : "", libraries[i].lower_closed ? "=" : "", +			libraries[i].lower ? libraries[i].lower : "", +			libraries[i].upper ? "<" : "", libraries[i].upper_closed ? "=" : "", +			libraries[i].upper ? libraries[i].upper : "");  	}  	errno = 0;  fail: -	saved_errno = errno; -	while (ptr--) -		free(rc[ptr--]); -	free(rc); -	errno = saved_errno; -	return NULL; +	return -1;  } @@ -603,8 +593,6 @@ int main(int argc, char *argv[])  	struct library *libraries_last;  	const char *path_;  	char *path = NULL; -	char **files = NULL; -	char **file;  	int rc;  	/* Parse arguments. */ @@ -656,14 +644,13 @@ int main(int argc, char *argv[])  	t (path == NULL);  	/* Find librarian files. */ -	files = find_librarian_files(libraries, (size_t)(libraries_last - libraries), path, f_oldest); -	if (files == NULL) { +	if (find_librarian_files(libraries, (size_t)(libraries_last - libraries), path, f_oldest)) {  		t (errno);  		goto not_found;  	}  	if (f_locate) { -		for (file = files; *file; file++) -			t (printf("%s\n", *file) < 0); +		while (found_files_count) +			t (printf("%s\n", found_files[--found_files_count].path) < 0);  		goto done;  	} @@ -684,10 +671,8 @@ usage:  	rc = 3;  	goto cleanup;  cleanup: -	if ((file = files)) -		for (; *file; file++) -			free(*file); -	free(files); +	while (found_files_count--) +		free(found_files[found_files_count].path);  	free(found_files);  	free(libraries);  	free(path); | 
