mirror of
https://github.com/TREX-CoE/trexio.git
synced 2025-01-07 03:43:25 +01:00
return type cast of exit codes and back ends in C
add top-level string_of_error function in Python
This commit is contained in:
parent
721352cb89
commit
0b223b9d6e
@ -174,7 +174,7 @@ typedef int32_t trexio_exit_code;
|
|||||||
# We need to force Emacs not to indent the Python code:
|
# We need to force Emacs not to indent the Python code:
|
||||||
# -*- org-src-preserve-indentation: t
|
# -*- org-src-preserve-indentation: t
|
||||||
|
|
||||||
#+begin_src python :var table=table-exit-codes :results drawer :exports none
|
#+begin_src python :var table=table-exit-codes :results drawer
|
||||||
""" This script generates the C and Fortran constants for the error
|
""" This script generates the C and Fortran constants for the error
|
||||||
codes from the org-mode table.
|
codes from the org-mode table.
|
||||||
"""
|
"""
|
||||||
@ -182,7 +182,7 @@ typedef int32_t trexio_exit_code;
|
|||||||
result = [ "#+begin_src c :tangle prefix_front.h :exports none" ]
|
result = [ "#+begin_src c :tangle prefix_front.h :exports none" ]
|
||||||
for (text, code,_) in table:
|
for (text, code,_) in table:
|
||||||
text=text.replace("~","")
|
text=text.replace("~","")
|
||||||
result += [ f"#define {text:30s} {code:d} //((trexio_exit_code) {code:d})" ]
|
result += [ f"#define {text:30s} ((trexio_exit_code) {code:d})" ]
|
||||||
result += [ "#+end_src" ]
|
result += [ "#+end_src" ]
|
||||||
|
|
||||||
result += [ "" ]
|
result += [ "" ]
|
||||||
@ -210,32 +210,32 @@ return '\n'.join(result)
|
|||||||
#+RESULTS:
|
#+RESULTS:
|
||||||
:RESULTS:
|
:RESULTS:
|
||||||
#+begin_src c :tangle prefix_front.h :exports none
|
#+begin_src c :tangle prefix_front.h :exports none
|
||||||
#define TREXIO_FAILURE -1 //((trexio_exit_code) -1)
|
#define TREXIO_FAILURE ((trexio_exit_code) -1)
|
||||||
#define TREXIO_SUCCESS 0 //((trexio_exit_code) 0)
|
#define TREXIO_SUCCESS ((trexio_exit_code) 0)
|
||||||
#define TREXIO_INVALID_ARG_1 1 //((trexio_exit_code) 1)
|
#define TREXIO_INVALID_ARG_1 ((trexio_exit_code) 1)
|
||||||
#define TREXIO_INVALID_ARG_2 2 //((trexio_exit_code) 2)
|
#define TREXIO_INVALID_ARG_2 ((trexio_exit_code) 2)
|
||||||
#define TREXIO_INVALID_ARG_3 3 //((trexio_exit_code) 3)
|
#define TREXIO_INVALID_ARG_3 ((trexio_exit_code) 3)
|
||||||
#define TREXIO_INVALID_ARG_4 4 //((trexio_exit_code) 4)
|
#define TREXIO_INVALID_ARG_4 ((trexio_exit_code) 4)
|
||||||
#define TREXIO_INVALID_ARG_5 5 //((trexio_exit_code) 5)
|
#define TREXIO_INVALID_ARG_5 ((trexio_exit_code) 5)
|
||||||
#define TREXIO_END 6 //((trexio_exit_code) 6)
|
#define TREXIO_END ((trexio_exit_code) 6)
|
||||||
#define TREXIO_READONLY 7 //((trexio_exit_code) 7)
|
#define TREXIO_READONLY ((trexio_exit_code) 7)
|
||||||
#define TREXIO_ERRNO 8 //((trexio_exit_code) 8)
|
#define TREXIO_ERRNO ((trexio_exit_code) 8)
|
||||||
#define TREXIO_INVALID_ID 9 //((trexio_exit_code) 9)
|
#define TREXIO_INVALID_ID ((trexio_exit_code) 9)
|
||||||
#define TREXIO_ALLOCATION_FAILED 10 //((trexio_exit_code) 10)
|
#define TREXIO_ALLOCATION_FAILED ((trexio_exit_code) 10)
|
||||||
#define TREXIO_HAS_NOT 11 //((trexio_exit_code) 11)
|
#define TREXIO_HAS_NOT ((trexio_exit_code) 11)
|
||||||
#define TREXIO_INVALID_NUM 12 //((trexio_exit_code) 12)
|
#define TREXIO_INVALID_NUM ((trexio_exit_code) 12)
|
||||||
#define TREXIO_ATTR_ALREADY_EXISTS 13 //((trexio_exit_code) 13)
|
#define TREXIO_ATTR_ALREADY_EXISTS ((trexio_exit_code) 13)
|
||||||
#define TREXIO_DSET_ALREADY_EXISTS 14 //((trexio_exit_code) 14)
|
#define TREXIO_DSET_ALREADY_EXISTS ((trexio_exit_code) 14)
|
||||||
#define TREXIO_OPEN_ERROR 15 //((trexio_exit_code) 15)
|
#define TREXIO_OPEN_ERROR ((trexio_exit_code) 15)
|
||||||
#define TREXIO_LOCK_ERROR 16 //((trexio_exit_code) 16)
|
#define TREXIO_LOCK_ERROR ((trexio_exit_code) 16)
|
||||||
#define TREXIO_UNLOCK_ERROR 17 //((trexio_exit_code) 17)
|
#define TREXIO_UNLOCK_ERROR ((trexio_exit_code) 17)
|
||||||
#define TREXIO_FILE_ERROR 18 //((trexio_exit_code) 18)
|
#define TREXIO_FILE_ERROR ((trexio_exit_code) 18)
|
||||||
#define TREXIO_GROUP_READ_ERROR 19 //((trexio_exit_code) 19)
|
#define TREXIO_GROUP_READ_ERROR ((trexio_exit_code) 19)
|
||||||
#define TREXIO_GROUP_WRITE_ERROR 20 //((trexio_exit_code) 20)
|
#define TREXIO_GROUP_WRITE_ERROR ((trexio_exit_code) 20)
|
||||||
#define TREXIO_ELEM_READ_ERROR 21 //((trexio_exit_code) 21)
|
#define TREXIO_ELEM_READ_ERROR ((trexio_exit_code) 21)
|
||||||
#define TREXIO_ELEM_WRITE_ERROR 22 //((trexio_exit_code) 22)
|
#define TREXIO_ELEM_WRITE_ERROR ((trexio_exit_code) 22)
|
||||||
#define TREXIO_UNSAFE_ARRAY_DIM 23 //((trexio_exit_code) 23)
|
#define TREXIO_UNSAFE_ARRAY_DIM ((trexio_exit_code) 23)
|
||||||
#define TREXIO_INVALID_STR_LEN 30 //((trexio_exit_code) 30)
|
#define TREXIO_INVALID_STR_LEN ((trexio_exit_code) 30)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
#+begin_src f90 :tangle prefix_fortran.f90 :exports none
|
#+begin_src f90 :tangle prefix_fortran.f90 :exports none
|
||||||
@ -268,6 +268,7 @@ return '\n'.join(result)
|
|||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
#+begin_src python :tangle prefix_python.py :exports none
|
#+begin_src python :tangle prefix_python.py :exports none
|
||||||
|
# define TREXIO exit codes
|
||||||
TREXIO_FAILURE = -1
|
TREXIO_FAILURE = -1
|
||||||
TREXIO_SUCCESS = 0
|
TREXIO_SUCCESS = 0
|
||||||
TREXIO_INVALID_ARG_1 = 1
|
TREXIO_INVALID_ARG_1 = 1
|
||||||
@ -297,7 +298,6 @@ return '\n'.join(result)
|
|||||||
#+end_src
|
#+end_src
|
||||||
:END:
|
:END:
|
||||||
|
|
||||||
|
|
||||||
*** Decoding errors
|
*** Decoding errors
|
||||||
|
|
||||||
The ~trexio_string_of_error~ converts an exit code into a string. The
|
The ~trexio_string_of_error~ converts an exit code into a string. The
|
||||||
@ -414,7 +414,8 @@ return '\n'.join(result)
|
|||||||
break;
|
break;
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
# Source
|
**** C source code
|
||||||
|
|
||||||
#+begin_src c :tangle prefix_front.c :noweb yes
|
#+begin_src c :tangle prefix_front.c :noweb yes
|
||||||
const char*
|
const char*
|
||||||
trexio_string_of_error (const trexio_exit_code error)
|
trexio_string_of_error (const trexio_exit_code error)
|
||||||
@ -432,7 +433,8 @@ trexio_string_of_error_f (const trexio_exit_code error, char result[<<MAX_STRING
|
|||||||
}
|
}
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
# Fortran interface
|
**** Fortran interface
|
||||||
|
|
||||||
#+begin_src f90 :tangle prefix_fortran.f90 :noexport :noweb yes
|
#+begin_src f90 :tangle prefix_fortran.f90 :noexport :noweb yes
|
||||||
interface
|
interface
|
||||||
subroutine trexio_string_of_error (error, string) bind(C, name='trexio_string_of_error_f')
|
subroutine trexio_string_of_error (error, string) bind(C, name='trexio_string_of_error_f')
|
||||||
@ -444,6 +446,23 @@ interface
|
|||||||
end interface
|
end interface
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
**** Python interface
|
||||||
|
|
||||||
|
#+begin_src python :tangle prefix_python.py :noexport
|
||||||
|
def string_of_error(return_code: int) -> str:
|
||||||
|
try:
|
||||||
|
from pytrexio import trexio_string_of_error
|
||||||
|
except ImportError:
|
||||||
|
raise
|
||||||
|
|
||||||
|
try:
|
||||||
|
error_str = trexio_string_of_error(trexio_return_code)
|
||||||
|
except:
|
||||||
|
raise
|
||||||
|
|
||||||
|
return error_str
|
||||||
|
#+end_src
|
||||||
|
|
||||||
** Back ends
|
** Back ends
|
||||||
|
|
||||||
TREXIO has several back ends:
|
TREXIO has several back ends:
|
||||||
@ -460,10 +479,10 @@ end interface
|
|||||||
#+begin_src c :tangle prefix_front.h
|
#+begin_src c :tangle prefix_front.h
|
||||||
typedef int32_t back_end_t;
|
typedef int32_t back_end_t;
|
||||||
|
|
||||||
#define TREXIO_HDF5 0 //( (back_end_t) 0 )
|
#define TREXIO_HDF5 ( (back_end_t) 0 )
|
||||||
#define TREXIO_TEXT 1 //( (back_end_t) 1 )
|
#define TREXIO_TEXT ( (back_end_t) 1 )
|
||||||
/*#define TREXIO_JSON ( (back_end_t) 2 )*/
|
/*#define TREXIO_JSON ( (back_end_t) 2 )*/
|
||||||
#define TREXIO_INVALID_BACK_END 2 //( (back_end_t) 2 )
|
#define TREXIO_INVALID_BACK_END ( (back_end_t) 2 )
|
||||||
|
|
||||||
#define TREXIO_DELIM "\n"
|
#define TREXIO_DELIM "\n"
|
||||||
#+end_src
|
#+end_src
|
||||||
@ -2480,8 +2499,7 @@ def write_$group_str$(trexio_file, str_w) -> None:
|
|||||||
def read_$group_str$(trexio_file):
|
def read_$group_str$(trexio_file):
|
||||||
try:
|
try:
|
||||||
from pytrexio import (trexio_read_$group_str$,
|
from pytrexio import (trexio_read_$group_str$,
|
||||||
trexio_string_of_error,
|
trexio_string_of_error
|
||||||
PYTREXIO_MAX_STR_LENGTH
|
|
||||||
)
|
)
|
||||||
except ImportError:
|
except ImportError:
|
||||||
raise
|
raise
|
||||||
|
Loading…
Reference in New Issue
Block a user