6 #define fstr_ctrl_util_MAIN
17 #define STR_SIZE buffsize
18 #define FILE_NAME_SIZE 512
19 #define ERR_MSG_SIZE 1024
24 snprintf(buff, buff_size,
"%s",
err_msg);
27 static void set_param_err_msg(
fstr_ctrl_data *ctrl,
const char *param_name,
29 static void set_data_err_msg(
fstr_ctrl_data *ctrl,
int line,
int data_no,
31 static void set_record_data_line_err_msg(
fstr_ctrl_data *ctrl,
int r);
32 static char *gettoken(
const char *line);
33 static void strcpy_f2c(
char *dest,
const char *src,
int len);
34 static void strcpy_c2f(
char *dest,
int len,
const char *src);
35 static char *remove_header_space(
char *token);
36 static int Strncmpi(
const char *s1,
const char *s2,
int len);
37 static int Strcmpi(
const char *s1,
const char *s2);
39 static void remove_cr(
char *s);
40 static void format_conv(
const char *format,
char *fmt,
int *array_size);
66 for (i = 0; i < ctrl->
rec_n; i++) {
88 static int is_comment_or_blank_line(
char *buff) {
91 if (buff[0] ==
'\n' || buff[0] == 0 || buff[0] ==
'#' ||
92 (buff[0] ==
'!' && buff[1] ==
'!')) {
97 if (*p !=
' ' && *p !=
'\n') {
109 static int count_line_and_header_number(
const char *fname,
int *line_n,
114 fp = fopen(fname,
"r");
130 if (is_comment_or_blank_line(buff)) {
134 if (buff[0] ==
'!') {
149 static int set_fstr_ctrl_data(
const char *fname,
fstr_ctrl_data *ctrl) {
155 fp = fopen(fname,
"r");
165 while (fgets(buff,
buffsize - 1, fp)) {
168 if (is_comment_or_blank_line(buff)) {
172 if (buff[0] ==
'!') {
178 if (header_count >= 0) {
183 size_t line_size = strlen(buff) + 1;
188 printf(
"Not enough memory\n");
194 snprintf(ctrl->
rec[rec_count].
line, line_size,
"%s", buff);
204 static int create_fstr_ctrl_data(
const char *fname,
fstr_ctrl_data *ctrl) {
206 int line_n, header_n;
207 fstr_ctrl_data_init(ctrl);
209 if (count_line_and_header_number(fname, &line_n, &header_n)) {
213 ctrl->
rec_n = line_n;
216 for (i = 0; i < line_n; i++) {
225 for (i = 0; i < header_n; i++) {
230 if (set_fstr_ctrl_data(fname, ctrl)) {
231 fstr_ctrl_data_finalize(ctrl);
262 err = create_fstr_ctrl_data(filename, ctrl);
279 for (i = 0; i < ctrl->
rec_n; i++) {
283 line_size = strlen(ctrl->
rec[i].
line) + 1;
315 if (create_fstr_ctrl_data(filename, ctrl)) {
344 if (rec_no < 0 || rec_no >= ctrl->
rec_n) {
348 snprintf(buff, buff_size,
"%s", ctrl->
rec[rec_no].
line);
357 static char *h_name =
NULL;
365 if (header_name ==
NULL || header_name[0] == 0) {
370 h_name = (
char *)header_name;
373 if (h_name ==
NULL) {
377 header_name_len = strlen(h_name);
379 for (i = start_index; i < ctrl->
header_n; i++) {
381 char *header = ctrl->
rec[hp].
line;
383 if (Strncmpi(header, h_name, header_name_len) == 0) {
425 header_p = header_name;
427 while (*line_p && (*line_p !=
',') && (*line_p !=
' ') && (*line_p !=
'\n') &&
429 *header_p = (char)
toupper(*line_p);
471 static int param_value_check(
const char *value_list,
char *val,
int *index) {
476 if (value_list ==
NULL || value_list[0] == 0 || value_list[0] ==
'#') {
486 n = strlen(value_list);
488 for (i = 0; i < n; i++) {
489 if (value_list[i] !=
' ') {
503 strcpy(vlist, value_list);
505 token = strtok(vlist,
" ,");
508 if (Strcmpi(token, val) == 0) {
516 token = strtok(
NULL,
", ");
523 static int param_value_convert(
int type,
char *token,
void *val) {
532 switch ((
char)type) {
557 r = sscanf(token, fmt, val);
566 static int param_length_count(
const char *param) {
567 const char *p = param;
569 while (*p !=
'\0' && *p !=
'=' && *p !=
' ') {
577 const char *value_list,
char type,
void *val) {
594 snprintf(header,
sizeof(header),
"%s", ctrl->
rec[h_pos].
line);
605 param_name_len = strlen(param_name);
606 strtok(header,
",\n");
607 token = strtok(
NULL,
",\n");
610 param_pos = remove_header_space(token);
611 param_len = param_length_count(param_pos);
613 if (param_len == param_name_len && Strncmpi(param_pos, param_name, param_name_len) == 0) {
614 if (type ==
'E' || type ==
'e') {
619 eq_pos = strstr(param_pos,
"=");
622 val_pos = eq_pos + 1;
623 val_pos = remove_header_space(val_pos);
635 if (param_value_check(value_list, val_pos, &index)) {
639 if (type ==
'P' || type ==
'p') {
640 *((
int *)val) = index;
644 r = param_value_convert(type, val_pos, val);
653 token = strtok(
NULL,
",\n");
657 if (type ==
'E' || type ==
'e') {
667 static int rcode_of_get_param = 0;
670 const char *value_list,
int necessity,
char type,
674 rcode_of_get_param = rcode;
682 set_param_err_msg(ctrl, param_name,
" is required");
692 set_param_err_msg(ctrl, param_name,
": value is required");
701 set_param_err_msg(ctrl, param_name,
": type conversion fail");
705 snprintf(s,
sizeof(s),
": type range fail(%s)", value_list);
706 set_param_err_msg(ctrl, param_name, s);
740 char *data_line,
size_t data_line_len) {
746 if (data_line_n <= 0 || data_line_n <
line_no) {
752 snprintf(data_line, data_line_len,
"%s", ctrl->
rec[data_pos].
line);
774 token = strtok(data_line, delim);
778 token = strtok(
NULL, delim);
802 va_start(va, format);
809 const char *format, ...) {
812 va_start(va, format);
817 set_record_data_line_err_msg(ctrl, r);
825 const char *format, va_list va) {
835 char fmt_integer[] =
"%d";
836 char fmt_double[] =
"%lf";
837 char fmt_string[] =
"%s";
838 char fmt_char[] =
"%c";
840 int array_size[
buffsize] = {
'\0' };
842 format_conv(format, format_c, array_size);
850 while (format_c[i] != 0) {
851 if (isupper(format_c[i])) {
861 len = strlen(format_c);
864 if (data_line[0] ==
'!') {
865 for (; counter < len; counter++) {
866 if (isupper(format_c[counter])) {
874 token = gettoken(data_line);
876 while (token && counter < len) {
878 necessary = isupper(format_c[counter]);
879 type =
toupper(format_c[counter]) & 0xff;
881 switch ((
char)type) {
902 val_p = va_arg(va,
void *);
905 err = sscanf(token, fmt, val_p);
907 if (err != 1 && necessary) {
911 if ((
char)type ==
'S') {
912 snprintf(buff,
sizeof(buff),
"%s", (
char *)val_p);
913 strcpy_c2f((
char *)val_p, array_size[counter], buff);
916 }
else if (necessary) {
920 token = gettoken(
NULL);
924 for (; counter < len; counter++) {
925 if (isupper(format[counter])) {
935 #define MAX_DATA_ARRAY_NUMBER 256
953 format_conv(format, fmt, array_size);
962 param[i] = va_arg(va,
void *);
965 switch ((
char)type) {
967 param_size[i] =
sizeof(int);
971 param_size[i] =
sizeof(double);
975 param_size[i] =
sizeof(char) * array_size[i];
979 param_size[i] =
sizeof(char);
992 for (i = 1; i <= line_n; i++) {
994 param[3], param[4], param[5], param[6], param[7],
995 param[8], param[9], param[10], param[11],
996 param[12], param[13], param[14], param[15],
997 param[16], param[17], param[18], param[19]);
1004 for (j = 0; j < column_n; j++) {
1006 snprintf(buff,
sizeof(buff),
"%s", (
char *)param[j]);
1007 strcpy_c2f((
char *)param[j], array_size[j], buff);
1010 param[j] += param_size[j];
1015 #undef MAX_DATA_ARRAY_NUMBER
1021 va_start(va, format);
1031 va_start(va, format);
1036 set_record_data_line_err_msg(ctrl, r);
1048 fstr_ctrl_data_finalize(ctrl);
1056 printf(
"header pos: ");
1058 for (i = 0; i < ctrl->
header_n; i++) {
1064 for (i = 0; i < ctrl->
rec_n; i++) {
1074 strcpy_c2f(f_buff, *len,
err_msg);
1138 strcpy_c2f(buff, *buff_size, c_buff);
1146 strcpy_f2c(name, header_name,
STR_SIZE);
1171 strcpy_c2f(header_name, *buff_size, c_buff);
1190 const char *value_list,
char *type,
void *val) {
1194 memset(p_name,
'\0',
sizeof(p_name));
1195 memset(v_list,
'\0',
sizeof(v_list));
1196 strcpy_f2c(p_name, param_name,
STR_SIZE);
1197 strcpy_f2c(v_list, value_list,
STR_SIZE);
1200 if (rcode == 0 && (*type ==
'S' || *type ==
's')) {
1202 snprintf(buff,
sizeof(buff),
"%s", (
char *)val);
1212 const char *value_list,
int *necessity,
char *type,
1217 strcpy_f2c(p_name, param_name,
STR_SIZE);
1218 strcpy_f2c(v_list, value_list,
STR_SIZE);
1223 (*type ==
'S' || *type ==
's')) {
1225 snprintf(buff,
sizeof(buff),
"%s", (
char *)val);
1242 strcpy_f2c(delim_c, delim,
STR_SIZE);
1259 const char *format, va_list va) {
1261 strcpy_f2c(fmt_c, format,
STR_SIZE);
1268 va_start(va, format);
1275 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1276 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1279 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1286 const char *format, va_list va) {
1289 strcpy_f2c(fmt_c, format,
STR_SIZE);
1293 set_record_data_line_err_msg(ctrl, r);
1303 va_start(va, format);
1310 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1311 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1314 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1324 strcpy_f2c(fmt_c, format,
STR_SIZE);
1330 set_record_data_line_err_msg(ctrl, r);
1340 va_start(va, format);
1347 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1348 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1351 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1374 static void set_param_err_msg(
fstr_ctrl_data *ctrl,
const char *param_name,
1376 snprintf(
err_msg,
sizeof(
err_msg),
"fstr control file error(param): line:%d, %s, %s\n",
1382 static void set_data_err_msg(
fstr_ctrl_data *ctrl,
int line,
int data_no,
1385 snprintf(
err_msg,
sizeof(
err_msg),
"fstr control file error(data): line:%d, column:%d : %s\n",
1386 line, data_no, msg);
1389 static void set_record_data_line_err_msg(
fstr_ctrl_data *ctrl,
int r) {
1396 snprintf(msg,
sizeof(msg),
"no error");
1400 snprintf(msg,
sizeof(msg),
"data type converting error");
1404 snprintf(msg,
sizeof(msg),
"data range error");
1408 snprintf(msg,
sizeof(msg),
"data must exist");
1412 snprintf(msg,
sizeof(msg),
"data line does not exist");
1416 snprintf(msg,
sizeof(msg),
"data line unknown error (r:%d)", r);
1419 set_data_err_msg(ctrl,
line_no, pos, msg);
1424 static char *gettoken(
const char *line) {
1433 snprintf(buff,
sizeof(buff),
"%s", line);
1437 if (*p == 0 || *p ==
'\n' || *p ==
'\r') {
1443 if (*p == 0 || *p ==
'\n' || *p ==
'\r' || *p ==
',') {
1461 while (*t ==
' ' && t != h) {
1488 static void strcpy_f2c(
char *dest,
const char *src,
int len) {
1492 for (i = 0; i < len - 1; i++) {
1493 if (src[i] !=
' ') {
1508 static void strcpy_c2f(
char *dest,
int len,
const char *src) {
1512 for (i = 0; i < len; i++) {
1513 if (fg == 0 && src[i] == 0) {
1528 static char *remove_header_space(
char *token) {
1544 static int Strncmpi(
const char *s1,
const char *s2,
int len) {
1551 while (*p1 && *p2 && i < len) {
1564 static int Strcmpi(
const char *s1,
const char *s2) {
1569 while (*p1 && *p2) {
1589 void Strupr(
char *s) {
1599 static void remove_cr(
char *s) {
1601 if (*s ==
'\n' || *s ==
'\r') {
1612 static void format_conv(
const char *format,
char *fmt,
int *array_size) {
1613 char *p = (
char *)format;
1616 char num_str[
buffsize] = {
'\0' } ;
1621 if (
'0' <= *p && *p <=
'9') {
1623 num_str[num_index] = *p;
1632 num_str[num_index] = 0;
1633 sscanf(num_str,
"%d", &n);
1634 array_size[i - 1] = n;
1654 num_str[num_index] = 0;
1655 sscanf(num_str,
"%d", &n);
1656 array_size[i - 1] = n;
int fg_fortran_get_data_array_v
int fstr_ctrl_get_param_ex(int *ctrl, const char *param_name, const char *value_list, int *necessity, char *type, void *val)
int fstr_ctrl_get_c_h_line_no(int *ctrl)
int fstr_ctrl_close(int *ctrl)
int fstr_ctrl_get_rec_number(int *ctrl)
int c_fstr_ctrl_seek_next_header(fstr_ctrl_data *ctrl)
int fstr_ctrl_get_data_n_in_line(int *ctrl, int *line_no, const char *delim)
int c_fstr_ctrl_get_rec_number(fstr_ctrl_data *ctrl)
int c_fstr_ctrl_get_current_header_name(fstr_ctrl_data *ctrl, char *header_name)
int fstr_ctrl_get_data_line_n(int *ctrl)
int fstr_ctrl_tmp_rewind(fstr_ctrl_data *ctrl)
int fstr_ctrl_seek_next_header(int *ctrl)
int fstr_ctrl_get_data_v10(int *ctrl, int *line_no, const char *format, void *v1, void *v2, void *v3, void *v4, void *v5, void *v6, void *v7, void *v8, void *v9, void *v10)
int fstr_ctrl_get_data_v_f(fstr_ctrl_data *ctrl, int line_no, const char *format, va_list va)
void fstr_ctrl_get_err_msg(char *f_buff, int *len)
int fstr_ctrl_get_data_array_ex_v10(int *ctrl, const char *format, void *v1, void *v2, void *v3, void *v4, void *v5, void *v6, void *v7, void *v8, void *v9, void *v10)
int fstr_ctrl_get_data_error_pos(void)
int fstr_ctrl_get_line(int *ctrl, int *rec_no, char *buff, int *buff_size)
int c_fstr_ctrl_get_data_array_v(fstr_ctrl_data *ctrl, const char *format, va_list va)
int fstr_ctrl_get_data_ex_v_f(fstr_ctrl_data *ctrl, int line_no, const char *format, va_list va)
int fstr_ctrl_get_data_error_line(void)
int c_fstr_ctrl_close(fstr_ctrl_data *ctrl)
int c_fstr_ctrl_copy_data_line(fstr_ctrl_data *ctrl, int line_no, char *data_line, size_t data_line_len)
fstr_ctrl_data * c_fstr_ctrl_open(const char *filename)
int fstr_ctrl_get_data_array_ex(int *ctrl, const char *format,...)
int c_fstr_ctrl_get_data_array(fstr_ctrl_data *ctrl, const char *format,...)
int fstr_ctrl_seek_header(int *ctrl, const char *header_name)
int c_fstr_ctrl_get_param_ex(fstr_ctrl_data *ctrl, const char *param_name, const char *value_list, int necessity, char type, void *val)
int fstr_ctrl_open(char *filename)
void fstr_ctrl_dump(int *ctrl)
int c_fstr_ctrl_seek_header(fstr_ctrl_data *ctrl, const char *header_name)
int c_fstr_ctrl_get_data_array_ex(fstr_ctrl_data *ctrl, const char *format,...)
void c_fstr_ctrl_get_err_msg(char *buff, size_t buff_size)
int c_fstr_ctrl_get_data_line_n(fstr_ctrl_data *ctrl)
int c_fstr_ctrl_get_data_error_pos(void)
char err_msg[ERR_MSG_SIZE]
int c_fstr_ctrl_get_current_header_pos(fstr_ctrl_data *ctrl)
int c_fstr_ctrl_get_data_ex(fstr_ctrl_data *ctrl, int line_no, const char *format,...)
int c_fstr_ctrl_get_line(fstr_ctrl_data *ctrl, int rec_no, char *buff, size_t buff_size)
int c_fstr_ctrl_get_data_n_in_line(fstr_ctrl_data *ctrl, int line_no, const char *delim)
int fstr_ctrl_get_data_ex_v10(int *ctrl, int *line_no, const char *format, void *v1, void *v2, void *v3, void *v4, void *v5, void *v6, void *v7, void *v8, void *v9, void *v10)
int fstr_ctrl_get_data(int *ctrl, int *line_no, const char *format,...)
int c_fstr_ctrl_get_current_header_line_no(fstr_ctrl_data *ctrl)
int fstr_ctrl_get_c_h_name(int *ctrl, char *header_name, int *buff_size)
int fstr_ctrl_get_data_ex(int *ctrl, int *line_no, const char *format,...)
int fstr_ctrl_get_c_h_pos(int *ctrl)
int fstr_ctrl_get_data_array_ex_v_f(fstr_ctrl_data *ctrl, const char *format, va_list va)
#define MAX_DATA_ARRAY_NUMBER
int c_fstr_ctrl_get_data(fstr_ctrl_data *ctrl, int line_no, const char *format,...)
int fstr_ctrl_rewind(int *ctrl)
void c_fstr_ctrl_dump(fstr_ctrl_data *ctrl)
int c_fstr_ctrl_get_param(fstr_ctrl_data *ctrl, const char *param_name, const char *value_list, char type, void *val)
int c_fstr_ctrl_get_data_v(fstr_ctrl_data *ctrl, int line_no, const char *format, va_list va)
int fstr_ctrl_get_param(int *ctrl, const char *param_name, const char *value_list, char *type, void *val)
int c_fstr_ctrl_get_data_error_line(void)
#define FSTR_CTRL_RCODE_PARAM_TYPE_ERROR
#define FSTR_CTRL_RCODE_DATA_TYPE_ERROR
#define FSTR_CTRL_RCODE_DATA_RANGE_ERROR
#define FSTR_CTRL_RCODE_PARAM_NOTHING
fstr_ctrl_data * ctrl_list[ctrl_list_size]
#define FSTR_CTRL_RCODE_DATA_ERROR
#define FSTR_CTRL_RCODE_DATA_SUCCESS
#define FSTR_CTRL_RCODE_PARAM_RANGE_ERROR
#define FSTR_CTRL_RCODE_DATA_LINE_NOTHING
#define FSTR_CTRL_RCODE_PARAM_VALUE_NOTHING
#define FSTR_CTRL_RCODE_DATA_NOTHING
#define FSTR_CTRL_RCODE_PARAM_SUCCESS
HECMW_Comm HECMW_comm_get_comm(void)
int HECMW_comm_get_rank(void)
int HECMW_Bcast(void *buffer, int count, HECMW_Datatype datatype, int root, HECMW_Comm comm)
#define HECMW_malloc(size)
integer(kind=kint) myrank
PARALLEL EXECUTION.