6 #define fstr_ctrl_util_MAIN
17 #define STR_SIZE buffsize
18 #define FILE_NAME_SIZE 512
24 static void set_param_err_msg(
fstr_ctrl_data *ctrl,
const char *param_name,
26 static void set_data_err_msg(
fstr_ctrl_data *ctrl,
int line,
int data_no,
28 static void set_record_data_line_err_msg(
fstr_ctrl_data *ctrl,
int r);
29 static char *gettoken(
const char *line);
30 static void strcpy_f2c(
char *dest,
const char *src,
int len);
31 static void strcpy_c2f(
char *dest,
int len,
const char *src);
32 static char *remove_header_space(
char *token);
33 static int Strncmpi(
const char *s1,
const char *s2,
int len);
34 static int Strcmpi(
const char *s1,
const char *s2);
36 static void remove_cr(
char *s);
37 static void format_conv(
const char *format,
char *fmt,
int *array_size);
63 for (i = 0; i < ctrl->
rec_n; i++) {
85 static int is_comment_or_blank_line(
char *buff) {
88 if (buff[0] ==
'\n' || buff[0] == 0 || buff[0] ==
'#' ||
89 (buff[0] ==
'!' && buff[1] ==
'!')) {
94 if (*p !=
' ' && *p !=
'\n') {
106 static int count_line_and_header_number(
const char *fname,
int *line_n,
111 fp = fopen(fname,
"r");
127 if (is_comment_or_blank_line(buff)) {
131 if (buff[0] ==
'!') {
146 static int set_fstr_ctrl_data(
const char *fname,
fstr_ctrl_data *ctrl) {
152 fp = fopen(fname,
"r");
162 while (fgets(buff,
buffsize - 1, fp)) {
165 if (is_comment_or_blank_line(buff)) {
169 if (buff[0] ==
'!') {
175 if (header_count >= 0) {
184 printf(
"Not enough memory\n");
190 strcpy(ctrl->
rec[rec_count].
line, buff);
200 static int create_fstr_ctrl_data(
const char *fname,
fstr_ctrl_data *ctrl) {
202 int line_n, header_n;
203 fstr_ctrl_data_init(ctrl);
205 if (count_line_and_header_number(fname, &line_n, &header_n)) {
209 ctrl->
rec_n = line_n;
212 for (i = 0; i < line_n; i++) {
221 for (i = 0; i < header_n; i++) {
226 if (set_fstr_ctrl_data(fname, ctrl)) {
227 fstr_ctrl_data_finalize(ctrl);
258 err = create_fstr_ctrl_data(filename, ctrl);
275 for (i = 0; i < ctrl->
rec_n; i++) {
279 line_size = strlen(ctrl->
rec[i].
line) + 1;
311 if (create_fstr_ctrl_data(filename, ctrl)) {
339 if (rec_no < 0 || rec_no >= ctrl->
rec_n) {
343 strcpy(buff, ctrl->
rec[rec_no].
line);
352 static char *h_name =
NULL;
360 if (header_name ==
NULL || header_name[0] == 0) {
365 h_name = (
char *)header_name;
368 if (h_name ==
NULL) {
372 header_name_len = strlen(h_name);
374 for (i = start_index; i < ctrl->
header_n; i++) {
376 char *header = ctrl->
rec[hp].
line;
378 if (Strncmpi(header, h_name, header_name_len) == 0) {
420 header_p = header_name;
422 while (*line_p && (*line_p !=
',') && (*line_p !=
' ') && (*line_p !=
'\n') &&
424 *header_p = (char)
toupper(*line_p);
466 static int param_value_check(
const char *value_list,
char *val,
int *index) {
471 if (value_list ==
NULL || value_list[0] == 0 || value_list[0] ==
'#') {
481 n = strlen(value_list);
483 for (i = 0; i < n; i++) {
484 if (value_list[i] !=
' ') {
498 strcpy(vlist, value_list);
500 token = strtok(vlist,
" ,");
503 if (Strcmpi(token, val) == 0) {
511 token = strtok(
NULL,
", ");
518 static int param_value_convert(
int type,
char *token,
void *val) {
527 switch ((
char)type) {
552 r = sscanf(token, fmt, val);
561 static int param_length_count(
const char *param) {
562 const char *p = param;
564 while (*p !=
'\0' && *p !=
'=' && *p !=
' ') {
572 const char *value_list,
char type,
void *val) {
589 strcpy(header, ctrl->
rec[h_pos].
line);
600 param_name_len = strlen(param_name);
601 strtok(header,
",\n");
602 token = strtok(
NULL,
",\n");
605 param_pos = remove_header_space(token);
606 param_len = param_length_count(param_pos);
608 if (param_len == param_name_len && Strncmpi(param_pos, param_name, param_name_len) == 0) {
609 if (type ==
'E' || type ==
'e') {
614 eq_pos = strstr(param_pos,
"=");
617 val_pos = eq_pos + 1;
618 val_pos = remove_header_space(val_pos);
630 if (param_value_check(value_list, val_pos, &index)) {
634 if (type ==
'P' || type ==
'p') {
635 *((
int *)val) = index;
639 r = param_value_convert(type, val_pos, val);
648 token = strtok(
NULL,
",\n");
652 if (type ==
'E' || type ==
'e') {
662 static int rcode_of_get_param = 0;
665 const char *value_list,
int necessity,
char type,
669 rcode_of_get_param = rcode;
677 set_param_err_msg(ctrl, param_name,
" is required");
687 set_param_err_msg(ctrl, param_name,
": value is required");
696 set_param_err_msg(ctrl, param_name,
": type conversion fail");
700 sprintf(s,
": type range fail(%s)", value_list);
701 set_param_err_msg(ctrl, param_name, s);
741 if (data_line_n <= 0 || data_line_n <
line_no) {
747 strcpy(data_line, ctrl->
rec[data_pos].
line);
768 token = strtok(data_line, delim);
772 token = strtok(
NULL, delim);
796 va_start(va, format);
803 const char *format, ...) {
806 va_start(va, format);
811 set_record_data_line_err_msg(ctrl, r);
819 const char *format, va_list va) {
829 char fmt_integer[] =
"%d";
830 char fmt_double[] =
"%lf";
831 char fmt_string[] =
"%s";
832 char fmt_char[] =
"%c";
834 int array_size[
buffsize] = {
'\0' };
836 format_conv(format, format_c, array_size);
843 while (format_c[i] != 0) {
844 if (isupper(format_c[i])) {
854 len = strlen(format_c);
857 if (data_line[0] ==
'!') {
858 for (; counter < len; counter++) {
859 if (isupper(format_c[counter])) {
867 token = gettoken(data_line);
869 while (token && counter < len) {
871 necessary = isupper(format_c[counter]);
872 type =
toupper(format_c[counter]) & 0xff;
874 switch ((
char)type) {
895 val_p = va_arg(va,
void *);
898 err = sscanf(token, fmt, val_p);
900 if (err != 1 && necessary) {
904 if ((
char)type ==
'S') {
905 strcpy(buff, (
char *)val_p);
906 strcpy_c2f((
char *)val_p, array_size[counter], buff);
909 }
else if (necessary) {
913 token = gettoken(
NULL);
917 for (; counter < len; counter++) {
918 if (isupper(format[counter])) {
928 #define MAX_DATA_ARRAY_NUMBER 256
946 format_conv(format, fmt, array_size);
955 param[i] = va_arg(va,
void *);
958 switch ((
char)type) {
960 param_size[i] =
sizeof(int);
964 param_size[i] =
sizeof(double);
968 param_size[i] =
sizeof(char) * array_size[i];
972 param_size[i] =
sizeof(char);
985 for (i = 1; i <= line_n; i++) {
987 param[3], param[4], param[5], param[6], param[7],
988 param[8], param[9], param[10], param[11],
989 param[12], param[13], param[14], param[15],
990 param[16], param[17], param[18], param[19]);
997 for (j = 0; j < column_n; j++) {
999 strcpy(buff, (
char *)param[j]);
1000 strcpy_c2f((
char *)param[j], array_size[j], buff);
1003 param[j] += param_size[j];
1008 #undef MAX_DATA_ARRAY_NUMBER
1014 va_start(va, format);
1024 va_start(va, format);
1029 set_record_data_line_err_msg(ctrl, r);
1041 fstr_ctrl_data_finalize(ctrl);
1049 printf(
"header pos: ");
1051 for (i = 0; i < ctrl->
header_n; i++) {
1057 for (i = 0; i < ctrl->
rec_n; i++) {
1067 strcpy_c2f(f_buff, *len,
err_msg);
1130 strcpy_c2f(buff, *buff_size, c_buff);
1138 strcpy_f2c(name, header_name,
STR_SIZE);
1163 strcpy_c2f(header_name, *buff_size, c_buff);
1182 const char *value_list,
char *type,
void *val) {
1186 memset(p_name,
'\0',
sizeof(p_name));
1187 memset(v_list,
'\0',
sizeof(v_list));
1188 strcpy_f2c(p_name, param_name,
STR_SIZE);
1189 strcpy_f2c(v_list, value_list,
STR_SIZE);
1192 if (rcode == 0 && (*type ==
'S' || *type ==
's')) {
1194 strcpy(buff, (
char *)val);
1204 const char *value_list,
int *necessity,
char *type,
1209 strcpy_f2c(p_name, param_name,
STR_SIZE);
1210 strcpy_f2c(v_list, value_list,
STR_SIZE);
1215 (*type ==
'S' || *type ==
's')) {
1217 strcpy(buff, (
char *)val);
1234 strcpy_f2c(delim_c, delim,
STR_SIZE);
1251 const char *format, va_list va) {
1253 strcpy_f2c(fmt_c, format,
STR_SIZE);
1260 va_start(va, format);
1267 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1268 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1271 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1278 const char *format, va_list va) {
1281 strcpy_f2c(fmt_c, format,
STR_SIZE);
1285 set_record_data_line_err_msg(ctrl, r);
1295 va_start(va, format);
1302 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1303 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1306 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1316 strcpy_f2c(fmt_c, format,
STR_SIZE);
1322 set_record_data_line_err_msg(ctrl, r);
1332 va_start(va, format);
1339 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1340 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1343 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1366 static void set_param_err_msg(
fstr_ctrl_data *ctrl,
const char *param_name,
1368 sprintf(
err_msg,
"fstr control file error(param): line:%d, %s, %s\n",
1374 static void set_data_err_msg(
fstr_ctrl_data *ctrl,
int line,
int data_no,
1377 sprintf(
err_msg,
"fstr control file error(data): line:%d, column:%d : %s\n",
1378 line, data_no, msg);
1381 static void set_record_data_line_err_msg(
fstr_ctrl_data *ctrl,
int r) {
1388 strcpy(msg,
"no error");
1392 strcpy(msg,
"data type converting error");
1396 strcpy(msg,
"data range error");
1400 strcpy(msg,
"data must exist");
1404 strcpy(msg,
"data line does not exist");
1408 sprintf(msg,
"data line unknown error (r:%d)", r);
1411 set_data_err_msg(ctrl,
line_no, pos, msg);
1416 static char *gettoken(
const char *line) {
1429 if (*p == 0 || *p ==
'\n' || *p ==
'\r') {
1435 if (*p == 0 || *p ==
'\n' || *p ==
'\r' || *p ==
',') {
1453 while (*t ==
' ' && t != h) {
1480 static void strcpy_f2c(
char *dest,
const char *src,
int len) {
1484 for (i = 0; i < len - 1; i++) {
1485 if (src[i] !=
' ') {
1500 static void strcpy_c2f(
char *dest,
int len,
const char *src) {
1504 for (i = 0; i < len; i++) {
1505 if (fg == 0 && src[i] == 0) {
1520 static char *remove_header_space(
char *token) {
1536 static int Strncmpi(
const char *s1,
const char *s2,
int len) {
1543 while (*p1 && *p2 && i < len) {
1556 static int Strcmpi(
const char *s1,
const char *s2) {
1561 while (*p1 && *p2) {
1581 void Strupr(
char *s) {
1591 static void remove_cr(
char *s) {
1593 if (*s ==
'\n' || *s ==
'\r') {
1604 static void format_conv(
const char *format,
char *fmt,
int *array_size) {
1605 char *p = (
char *)format;
1608 char num_str[
buffsize] = {
'\0' } ;
1613 if (
'0' <= *p && *p <=
'9') {
1615 num_str[num_index] = *p;
1624 num_str[num_index] = 0;
1625 sscanf(num_str,
"%d", &n);
1626 array_size[i - 1] = n;
1646 num_str[num_index] = 0;
1647 sscanf(num_str,
"%d", &n);
1648 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)
void c_fstr_ctrl_get_err_msg(char *buff)
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)
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,...)
int c_fstr_ctrl_get_data_line_n(fstr_ctrl_data *ctrl)
int c_fstr_ctrl_get_data_error_pos(void)
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_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 c_fstr_ctrl_copy_data_line(fstr_ctrl_data *ctrl, int line_no, char *data_line)
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)
int c_fstr_ctrl_get_line(fstr_ctrl_data *ctrl, int rec_no, char *buff)
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.