[cli] Command-line expansion client now supports piping in stdin, Unix-style

This commit is contained in:
Al
2016-02-03 13:48:51 -05:00
parent 90b9bb097c
commit 3701d8380f

View File

@@ -3,16 +3,47 @@
#include <stdbool.h> #include <stdbool.h>
#include <string.h> #include <string.h>
#include <sys/time.h> #include <sys/time.h>
#include <unistd.h>
#include "libpostal.h" #include "libpostal.h"
#include "file_utils.h"
#include "log/log.h" #include "log/log.h"
#include "json_encode.h" #include "json_encode.h"
#include "string_utils.h" #include "string_utils.h"
#define LIBPOSTAL_USAGE "Usage: ./libpostal address [...languages] [--json]\n" #define LIBPOSTAL_USAGE "Usage: ./libpostal address [...languages] [--json]\n"
static inline void print_output(char *address, normalize_options_t options, bool use_json) {
size_t num_expansions;
char **strings = expand_address(address, options, &num_expansions);
char *normalized;
if (!use_json) {
for (size_t i = 0; i < num_expansions; i++) {
normalized = strings[i];
printf("%s\n", normalized);
free(normalized);
}
} else {
printf("{\"expansions\": [");
for (size_t i = 0; i < num_expansions; i++) {
normalized = strings[i];
char *json_string = json_encode_string(normalized);
printf("%s%s", json_string, i < num_expansions - 1 ? ", ": "");
free(normalized);
free(json_string);
}
printf("]}\n");
}
free(strings);
}
int main(int argc, char **argv) { int main(int argc, char **argv) {
uint64_t i;
char *arg; char *arg;
char *address = NULL; char *address = NULL;
@@ -39,7 +70,7 @@ int main(int argc, char **argv) {
} }
} }
if (address == NULL) { if (address == NULL && (!use_json || isatty(fileno(stdin)))) {
log_error(LIBPOSTAL_USAGE); log_error(LIBPOSTAL_USAGE);
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@@ -55,34 +86,20 @@ int main(int argc, char **argv) {
options.num_languages = languages->n; options.num_languages = languages->n;
} }
size_t num_expansions; if (address == NULL) {
char *line;
char **strings = expand_address(address, options, &num_expansions); while ((line = file_getline(stdin)) != NULL) {
print_output(line, options, use_json);
string_array_destroy(languages); free(line);
char *normalized;
if (!use_json) {
for (i = 0; i < num_expansions; i++) {
normalized = strings[i];
printf("%s\n", normalized);
free(normalized);
} }
} else { } else {
printf("{\"expansions\": ["); print_output(address, options, use_json);
for (i = 0; i < num_expansions; i++) {
normalized = strings[i];
char *json_string = json_encode_string(normalized);
printf("%s%s", json_string, i < num_expansions - 1 ? ", ": "");
free(normalized);
free(json_string);
}
printf("]}\n");
} }
free(strings); if (languages != NULL) {
string_array_destroy(languages);
}
libpostal_teardown(); libpostal_teardown();
libpostal_teardown_language_classifier();
} }