mirror of
https://github.com/LCPQ/EMSL_Basis_Set_Exchange_Local
synced 2024-12-22 12:23:39 +01:00
commit
be9c65f77d
23
EMSL_api.py
23
EMSL_api.py
@ -32,6 +32,7 @@ By default is $EMSL_API_ROOT/db/Gausian_uk.db
|
|||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
|
import os
|
||||||
|
|
||||||
from src.docopt import docopt
|
from src.docopt import docopt
|
||||||
from src.EMSL_utility import EMSL_dump
|
from src.EMSL_utility import EMSL_dump
|
||||||
@ -48,6 +49,23 @@ if __name__ == '__main__':
|
|||||||
import os
|
import os
|
||||||
db_path = os.path.dirname(__file__) + "/db/Gamess-us.db"
|
db_path = os.path.dirname(__file__) + "/db/Gamess-us.db"
|
||||||
|
|
||||||
|
# Check if db file is readable
|
||||||
|
if not os.access(db_path,os.R_OK):
|
||||||
|
print >>sys.stderr, "Db file %s is not readable"%(db_path)
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
# Check if the file system allows I/O on sqlite3 (lustre)
|
||||||
|
# If not, copy on /dev/shm and remove after opening
|
||||||
|
try:
|
||||||
|
EMSL_local(db_path=db_path).get_list_basis_available([])
|
||||||
|
except:
|
||||||
|
new_db_path = "/dev/shm/%d.db"%(os.getpid())
|
||||||
|
os.system("cp %s %s"%(db_path,new_db_path))
|
||||||
|
db_path = new_db_path
|
||||||
|
# try again to check
|
||||||
|
EMSL_local(db_path=db_path).get_list_basis_available([])
|
||||||
|
|
||||||
|
|
||||||
# _ _ _ ______ _
|
# _ _ _ ______ _
|
||||||
#| | (_) | | | ___ \ (_)
|
#| | (_) | | | ___ \ (_)
|
||||||
#| | _ ___| |_ | |_/ / __ _ ___ _ ___
|
#| | _ ___| |_ | |_/ / __ _ ___ _ ___
|
||||||
@ -134,3 +152,8 @@ if __name__ == '__main__':
|
|||||||
format=format_dict[format],
|
format=format_dict[format],
|
||||||
contraction=contraction)
|
contraction=contraction)
|
||||||
e.new_db()
|
e.new_db()
|
||||||
|
|
||||||
|
|
||||||
|
# Clean up on exit
|
||||||
|
os.system("rm -f /dev/shm/%d.db"%(os.getpid()))
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user