6 #define fstr_ctrl_util_MAIN
17 #define STR_SIZE buffsize
18 #define FILE_NAME_SIZE 512
19 #define ERR_MSG_SIZE 1024
25 static void set_param_err_msg(
fstr_ctrl_data *ctrl,
const char *param_name,
27 static void set_data_err_msg(
fstr_ctrl_data *ctrl,
int line,
int data_no,
29 static void set_record_data_line_err_msg(
fstr_ctrl_data *ctrl,
int r);
30 static char *gettoken(
const char *line);
31 static void strcpy_f2c(
char *dest,
const char *src,
int len);
32 static void strcpy_c2f(
char *dest,
int len,
const char *src);
33 static char *remove_header_space(
char *token);
34 static int Strncmpi(
const char *s1,
const char *s2,
int len);
35 static int Strcmpi(
const char *s1,
const char *s2);
37 static void remove_cr(
char *s);
38 static void format_conv(
const char *format,
char *fmt,
int *array_size);
64 for (i = 0; i < ctrl->
rec_n; i++) {
86 static int is_comment_or_blank_line(
char *buff) {
89 if (buff[0] ==
'\n' || buff[0] == 0 || buff[0] ==
'#' ||
90 (buff[0] ==
'!' && buff[1] ==
'!')) {
95 if (*p !=
' ' && *p !=
'\n') {
107 static int count_line_and_header_number(
const char *fname,
int *line_n,
112 fp = fopen(fname,
"r");
128 if (is_comment_or_blank_line(buff)) {
132 if (buff[0] ==
'!') {
147 static int set_fstr_ctrl_data(
const char *fname,
fstr_ctrl_data *ctrl) {
153 fp = fopen(fname,
"r");
163 while (fgets(buff,
buffsize - 1, fp)) {
166 if (is_comment_or_blank_line(buff)) {
170 if (buff[0] ==
'!') {
176 if (header_count >= 0) {
185 printf(
"Not enough memory\n");
191 strcpy(ctrl->
rec[rec_count].
line, buff);
201 static int create_fstr_ctrl_data(
const char *fname,
fstr_ctrl_data *ctrl) {
203 int line_n, header_n;
204 fstr_ctrl_data_init(ctrl);
206 if (count_line_and_header_number(fname, &line_n, &header_n)) {
210 ctrl->
rec_n = line_n;
213 for (i = 0; i < line_n; i++) {
222 for (i = 0; i < header_n; i++) {
227 if (set_fstr_ctrl_data(fname, ctrl)) {
228 fstr_ctrl_data_finalize(ctrl);
259 err = create_fstr_ctrl_data(filename, ctrl);
276 for (i = 0; i < ctrl->
rec_n; i++) {
280 line_size = strlen(ctrl->
rec[i].
line) + 1;
312 if (create_fstr_ctrl_data(filename, ctrl)) {
340 if (rec_no < 0 || rec_no >= ctrl->
rec_n) {
344 strcpy(buff, ctrl->
rec[rec_no].
line);
353 static char *h_name =
NULL;
361 if (header_name ==
NULL || header_name[0] == 0) {
366 h_name = (
char *)header_name;
369 if (h_name ==
NULL) {
373 header_name_len = strlen(h_name);
375 for (i = start_index; i < ctrl->
header_n; i++) {
377 char *header = ctrl->
rec[hp].
line;
379 if (Strncmpi(header, h_name, header_name_len) == 0) {
421 header_p = header_name;
423 while (*line_p && (*line_p !=
',') && (*line_p !=
' ') && (*line_p !=
'\n') &&
425 *header_p = (char)
toupper(*line_p);
467 static int param_value_check(
const char *value_list,
char *val,
int *index) {
472 if (value_list ==
NULL || value_list[0] == 0 || value_list[0] ==
'#') {
482 n = strlen(value_list);
484 for (i = 0; i < n; i++) {
485 if (value_list[i] !=
' ') {
499 strcpy(vlist, value_list);
501 token = strtok(vlist,
" ,");
504 if (Strcmpi(token, val) == 0) {
512 token = strtok(
NULL,
", ");
519 static int param_value_convert(
int type,
char *token,
void *val) {
528 switch ((
char)type) {
553 r = sscanf(token, fmt, val);
562 static int param_length_count(
const char *param) {
563 const char *p = param;
565 while (*p !=
'\0' && *p !=
'=' && *p !=
' ') {
573 const char *value_list,
char type,
void *val) {
590 strcpy(header, ctrl->
rec[h_pos].
line);
601 param_name_len = strlen(param_name);
602 strtok(header,
",\n");
603 token = strtok(
NULL,
",\n");
606 param_pos = remove_header_space(token);
607 param_len = param_length_count(param_pos);
609 if (param_len == param_name_len && Strncmpi(param_pos, param_name, param_name_len) == 0) {
610 if (type ==
'E' || type ==
'e') {
615 eq_pos = strstr(param_pos,
"=");
618 val_pos = eq_pos + 1;
619 val_pos = remove_header_space(val_pos);
631 if (param_value_check(value_list, val_pos, &index)) {
635 if (type ==
'P' || type ==
'p') {
636 *((
int *)val) = index;
640 r = param_value_convert(type, val_pos, val);
649 token = strtok(
NULL,
",\n");
653 if (type ==
'E' || type ==
'e') {
663 static int rcode_of_get_param = 0;
666 const char *value_list,
int necessity,
char type,
670 rcode_of_get_param = rcode;
678 set_param_err_msg(ctrl, param_name,
" is required");
688 set_param_err_msg(ctrl, param_name,
": value is required");
697 set_param_err_msg(ctrl, param_name,
": type conversion fail");
701 sprintf(s,
": type range fail(%s)", value_list);
702 set_param_err_msg(ctrl, param_name, s);
742 if (data_line_n <= 0 || data_line_n <
line_no) {
748 strcpy(data_line, ctrl->
rec[data_pos].
line);
769 token = strtok(data_line, delim);
773 token = strtok(
NULL, delim);
797 va_start(va, format);
804 const char *format, ...) {
807 va_start(va, format);
812 set_record_data_line_err_msg(ctrl, r);
820 const char *format, va_list va) {
830 char fmt_integer[] =
"%d";
831 char fmt_double[] =
"%lf";
832 char fmt_string[] =
"%s";
833 char fmt_char[] =
"%c";
835 int array_size[
buffsize] = {
'\0' };
837 format_conv(format, format_c, array_size);
844 while (format_c[i] != 0) {
845 if (isupper(format_c[i])) {
855 len = strlen(format_c);
858 if (data_line[0] ==
'!') {
859 for (; counter < len; counter++) {
860 if (isupper(format_c[counter])) {
868 token = gettoken(data_line);
870 while (token && counter < len) {
872 necessary = isupper(format_c[counter]);
873 type =
toupper(format_c[counter]) & 0xff;
875 switch ((
char)type) {
896 val_p = va_arg(va,
void *);
899 err = sscanf(token, fmt, val_p);
901 if (err != 1 && necessary) {
905 if ((
char)type ==
'S') {
906 strcpy(buff, (
char *)val_p);
907 strcpy_c2f((
char *)val_p, array_size[counter], buff);
910 }
else if (necessary) {
914 token = gettoken(
NULL);
918 for (; counter < len; counter++) {
919 if (isupper(format[counter])) {
929 #define MAX_DATA_ARRAY_NUMBER 256
947 format_conv(format, fmt, array_size);
956 param[i] = va_arg(va,
void *);
959 switch ((
char)type) {
961 param_size[i] =
sizeof(int);
965 param_size[i] =
sizeof(double);
969 param_size[i] =
sizeof(char) * array_size[i];
973 param_size[i] =
sizeof(char);
986 for (i = 1; i <= line_n; i++) {
988 param[3], param[4], param[5], param[6], param[7],
989 param[8], param[9], param[10], param[11],
990 param[12], param[13], param[14], param[15],
991 param[16], param[17], param[18], param[19]);
998 for (j = 0; j < column_n; j++) {
1000 strcpy(buff, (
char *)param[j]);
1001 strcpy_c2f((
char *)param[j], array_size[j], buff);
1004 param[j] += param_size[j];
1009 #undef MAX_DATA_ARRAY_NUMBER
1015 va_start(va, format);
1025 va_start(va, format);
1030 set_record_data_line_err_msg(ctrl, r);
1042 fstr_ctrl_data_finalize(ctrl);
1050 printf(
"header pos: ");
1052 for (i = 0; i < ctrl->
header_n; i++) {
1058 for (i = 0; i < ctrl->
rec_n; i++) {
1068 strcpy_c2f(f_buff, *len,
err_msg);
1131 strcpy_c2f(buff, *buff_size, c_buff);
1139 strcpy_f2c(name, header_name,
STR_SIZE);
1164 strcpy_c2f(header_name, *buff_size, c_buff);
1183 const char *value_list,
char *type,
void *val) {
1187 memset(p_name,
'\0',
sizeof(p_name));
1188 memset(v_list,
'\0',
sizeof(v_list));
1189 strcpy_f2c(p_name, param_name,
STR_SIZE);
1190 strcpy_f2c(v_list, value_list,
STR_SIZE);
1193 if (rcode == 0 && (*type ==
'S' || *type ==
's')) {
1195 strcpy(buff, (
char *)val);
1205 const char *value_list,
int *necessity,
char *type,
1210 strcpy_f2c(p_name, param_name,
STR_SIZE);
1211 strcpy_f2c(v_list, value_list,
STR_SIZE);
1216 (*type ==
'S' || *type ==
's')) {
1218 strcpy(buff, (
char *)val);
1235 strcpy_f2c(delim_c, delim,
STR_SIZE);
1252 const char *format, va_list va) {
1254 strcpy_f2c(fmt_c, format,
STR_SIZE);
1261 va_start(va, format);
1268 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1269 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1272 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1279 const char *format, va_list va) {
1282 strcpy_f2c(fmt_c, format,
STR_SIZE);
1286 set_record_data_line_err_msg(ctrl, r);
1296 va_start(va, format);
1303 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1304 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1307 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1317 strcpy_f2c(fmt_c, format,
STR_SIZE);
1323 set_record_data_line_err_msg(ctrl, r);
1333 va_start(va, format);
1340 void *v1,
void *v2,
void *v3,
void *v4,
void *v5,
1341 void *v6,
void *v7,
void *v8,
void *v9,
void *v10) {
1344 v1, v2, v3, v4, v5, v6, v7, v8, v9, v10);
1367 static void set_param_err_msg(
fstr_ctrl_data *ctrl,
const char *param_name,
1369 snprintf(
err_msg,
sizeof(
err_msg),
"fstr control file error(param): line:%d, %s, %s\n",
1375 static void set_data_err_msg(
fstr_ctrl_data *ctrl,
int line,
int data_no,
1378 snprintf(
err_msg,
sizeof(
err_msg),
"fstr control file error(data): line:%d, column:%d : %s\n",
1379 line, data_no, msg);
1382 static void set_record_data_line_err_msg(
fstr_ctrl_data *ctrl,
int r) {
1389 strcpy(msg,
"no error");
1393 strcpy(msg,
"data type converting error");
1397 strcpy(msg,
"data range error");
1401 strcpy(msg,
"data must exist");
1405 strcpy(msg,
"data line does not exist");
1409 sprintf(msg,
"data line unknown error (r:%d)", r);
1412 set_data_err_msg(ctrl,
line_no, pos, msg);
1417 static char *gettoken(
const char *line) {
1430 if (*p == 0 || *p ==
'\n' || *p ==
'\r') {
1436 if (*p == 0 || *p ==
'\n' || *p ==
'\r' || *p ==
',') {
1454 while (*t ==
' ' && t != h) {
1481 static void strcpy_f2c(
char *dest,
const char *src,
int len) {
1485 for (i = 0; i < len - 1; i++) {
1486 if (src[i] !=
' ') {
1501 static void strcpy_c2f(
char *dest,
int len,
const char *src) {
1505 for (i = 0; i < len; i++) {
1506 if (fg == 0 && src[i] == 0) {
1521 static char *remove_header_space(
char *token) {
1537 static int Strncmpi(
const char *s1,
const char *s2,
int len) {
1544 while (*p1 && *p2 && i < len) {
1557 static int Strcmpi(
const char *s1,
const char *s2) {
1562 while (*p1 && *p2) {
1582 void Strupr(
char *s) {
1592 static void remove_cr(
char *s) {
1594 if (*s ==
'\n' || *s ==
'\r') {
1605 static void format_conv(
const char *format,
char *fmt,
int *array_size) {
1606 char *p = (
char *)format;
1609 char num_str[
buffsize] = {
'\0' } ;
1614 if (
'0' <= *p && *p <=
'9') {
1616 num_str[num_index] = *p;
1625 num_str[num_index] = 0;
1626 sscanf(num_str,
"%d", &n);
1627 array_size[i - 1] = n;
1647 num_str[num_index] = 0;
1648 sscanf(num_str,
"%d", &n);
1649 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)
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_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.