/* -*- C -*- */ #include #include #include "orte/constants.h" #include "opal/util/argv.h" #include "orte/runtime/runtime.h" #include "orte/util/proc_info.h" #include "orte/util/name_fns.h" #include "orte/runtime/orte_globals.h" #define LINE_LENGTH 10000 int main(int argc, char* argv[]) { char text[LINE_LENGTH]; char **invals=NULL; int i, j; if (1 < argc) { if (ORTE_SUCCESS != orte_init(&argc, &argv, ORTE_PROC_NON_MPI)) { fprintf(stderr, "Failed orte_init\n"); exit(1); } } memset(text, 0, sizeof(text)); while (fgets(text, sizeof(text), stdin)) { /* remove trailing newline */ if ('\n' == text[strlen(text)-1]) { text[strlen(text)-1] = '\0'; } /* break the line on white space */ for (i=0, j=0; i < LINE_LENGTH && '\0' != text[i]; i++) { if (isspace(text[i])) { if (j < i) { text[i] = '\0'; opal_argv_append_nosize(&invals, &text[j]); } j = i+1; } } if (i < LINE_LENGTH && j < i+1) { opal_argv_append_nosize(&invals, &text[j]); } if (NULL == invals) { fprintf(stderr, "stdin complete (text strlen: %lu)\n", strlen(text)); break; } for (i=0; NULL != invals[i]; i++) { fprintf(stdout, "%s\t1\n", invals[i]); } if (NULL != invals) { opal_argv_free(invals); invals = NULL; } memset(text, 0, sizeof(text)); } if (1 < argc) { fprintf(stderr, "%s: FINALIZING\n", ORTE_NAME_PRINT(ORTE_PROC_MY_NAME)); fflush(stderr); if (ORTE_SUCCESS != orte_finalize()) { fprintf(stderr, "Failed orte_finalize\n"); exit(1); } } return 0; }