1
0
mirror of https://github.com/TREX-CoE/trexio.git synced 2025-01-07 03:43:25 +01:00

Add support for Python with statement

(see PEP 343 for more details)
This commit is contained in:
q-posev 2022-03-07 14:12:31 +01:00
parent 7a2a60f347
commit 0e75cb42b5
2 changed files with 31 additions and 13 deletions

View File

@ -32,7 +32,7 @@ try:
elif TEST_TREXIO_BACKEND == trexio.TREXIO_TEXT: elif TEST_TREXIO_BACKEND == trexio.TREXIO_TEXT:
shutil.rmtree(output_filename) shutil.rmtree(output_filename)
except: except:
print ('Nothing to remove.') print('Nothing to remove.')
#=========================================================# #=========================================================#
#============ WRITE THE DATA IN THE TEST FILE ============# #============ WRITE THE DATA IN THE TEST FILE ============#
@ -40,6 +40,17 @@ except:
trexio.info() trexio.info()
# test with ... as ... block
with trexio.File(output_filename, mode='w', back_end=TEST_TREXIO_BACKEND) as tfile:
trexio.write_metadata_description(tfile, "Test file produced by the Python API")
assert trexio.has_metadata_description(tfile)
assert tfile.isOpen
# the file handle can remain existing but the file itself is closed upon exit from the `with` block
assert not tfile.isOpen
# create TREXIO file and open it for writing # create TREXIO file and open it for writing
test_file = trexio.File(output_filename, mode='w', back_end=TEST_TREXIO_BACKEND) test_file = trexio.File(output_filename, mode='w', back_end=TEST_TREXIO_BACKEND)
assert test_file.exists assert test_file.exists
@ -281,7 +292,7 @@ assert rpoint_group==point_group
# another way to read only if the variable exists # another way to read only if the variable exists
if trexio.has_ao_num(test_file2): if trexio.has_ao_num(test_file2):
rmo_num = trexio.read_ao_num(test_file2) rao_num = trexio.read_ao_num(test_file2)
else: else:
print("Pass on reading the non-existing variable ao_num: checked") print("Pass on reading the non-existing variable ao_num: checked")
@ -290,12 +301,12 @@ else:
# cleaning (remove the TREXIO file) # cleaning (remove the TREXIO file)
try: try:
if TEST_TREXIO_BACKEND == trexio.TREXIO_HDF5: if TEST_TREXIO_BACKEND == trexio.TREXIO_HDF5:
os.remove(output_filename) os.remove(output_filename)
elif TEST_TREXIO_BACKEND == trexio.TREXIO_TEXT: elif TEST_TREXIO_BACKEND == trexio.TREXIO_TEXT:
shutil.rmtree(output_filename) shutil.rmtree(output_filename)
except: except:
print (f'No output file {output_filename} has been produced') print(f'No output file {output_filename} has been produced')
#==========================================================# #==========================================================#

View File

@ -720,8 +720,7 @@ class File:
def __init__(self, filename, mode='r', back_end=TREXIO_HDF5, def __init__(self, filename, mode='r', back_end=TREXIO_HDF5,
pytrexio_s=None, info=None): pytrexio_s=None, info=None):
"""This is a TREXIO File constructor.""" """TREXIO File class constructor."""
self.filename = filename self.filename = filename
self.mode = mode self.mode = mode
self.back_end = back_end self.back_end = back_end
@ -740,9 +739,19 @@ class File:
self.info = info self.info = info
def __enter__(self):
"""Enter statement for with ... as ... handling."""
return self
def __exit__(self, *args):
"""Exit statement for with ... as ... handling."""
if self.isOpen:
self.close()
def close(self): def close(self):
"""Close a TREXIO File.""" """Close a TREXIO File."""
if self.isOpen: if self.isOpen:
_close(self.pytrexio_s) _close(self.pytrexio_s)
self.isOpen = False self.isOpen = False
@ -752,13 +761,11 @@ class File:
def inquire(self): def inquire(self):
"""Inquire whether a TREXIO file exists.""" """Inquire whether a TREXIO file exists."""
self.exists = _inquire(self.filename) self.exists = _inquire(self.filename)
def __del__(self): def __del__(self):
"""This is a TREXIO File destructor.""" """TREXIO File class destructor."""
if self.isOpen: if self.isOpen:
_close(self.pytrexio_s) _close(self.pytrexio_s)
elif self.isOpen is None: elif self.isOpen is None: