mirror of
https://gitlab.com/scemama/EZFIO.git
synced 2025-01-08 20:33:06 +01:00
Corrected ninja bugs
This commit is contained in:
parent
71f5255582
commit
0cce47969a
3
Makefile
3
Makefile
@ -25,7 +25,7 @@
|
|||||||
include version
|
include version
|
||||||
include make.config
|
include make.config
|
||||||
|
|
||||||
.PHONY: default clean veryclean archive configure
|
.PHONY: default clean veryclean archive
|
||||||
|
|
||||||
default: make.config
|
default: make.config
|
||||||
cd src && $(MAKE)
|
cd src && $(MAKE)
|
||||||
@ -34,7 +34,6 @@ clean:
|
|||||||
- bash -c "[[ -f lib/libezfio.a ]] && rm $$PWD/lib/*"
|
- bash -c "[[ -f lib/libezfio.a ]] && rm $$PWD/lib/*"
|
||||||
- bash -c "[[ -f Python/ezfio.py ]] && rm $$PWD/Python/*"
|
- bash -c "[[ -f Python/ezfio.py ]] && rm $$PWD/Python/*"
|
||||||
- bash -c "[[ -f Ocaml/ezfio.ml ]] && rm $$PWD/Ocaml/*"
|
- bash -c "[[ -f Ocaml/ezfio.ml ]] && rm $$PWD/Ocaml/*"
|
||||||
- bash -c "[[ -f Bash/ezfio.sh ]] && rm $$PWD/Bash/*"
|
|
||||||
- $(MAKE) -C $$PWD/src veryclean
|
- $(MAKE) -C $$PWD/src veryclean
|
||||||
|
|
||||||
archive: distclean
|
archive: distclean
|
||||||
|
11
build.ninja
11
build.ninja
@ -1,16 +1,16 @@
|
|||||||
include version
|
include version
|
||||||
|
|
||||||
rule build_generated_ninja
|
rule build_generated_ninja
|
||||||
command = python $in ninja
|
command = python configure.py
|
||||||
description = Creating generated.ninja
|
description = Creating generated.ninja
|
||||||
generator = 1
|
|
||||||
|
|
||||||
rule run_ninja
|
rule run_ninja
|
||||||
command = bash -c 'source .make.config.sh ; exec bash -c "$$NINJA -f $in"'
|
command = bash -c 'source .make.config.sh ; $$NINJA -f $in'
|
||||||
description = Building Fortran library
|
description = Building Fortran library
|
||||||
|
pool = console
|
||||||
|
|
||||||
rule build_archive
|
rule build_archive
|
||||||
command = git archive --format=tar HEAD > EZFIO.${version}.tar && mkdir -p EZFIO && cd EZFIO && tar -xvf ../EZFIO.${version}.tar && cd .. && rm EZFIO.${version}.tar && tar -zcvf EZFIO.${version}.tar.gz EZFIO && rm -rf EZFIO
|
command = git archive --format=tar HEAD > EZFIO.${VERSION}.tar && mkdir -p EZFIO && cd EZFIO && tar -xvf ../EZFIO.${VERSION}.tar && cd .. && rm EZFIO.${VERSION}.tar && tar -zcvf EZFIO.${VERSION}.tar.gz EZFIO && rm -rf EZFIO
|
||||||
description = Building archive
|
description = Building archive
|
||||||
|
|
||||||
rule clean_all
|
rule clean_all
|
||||||
@ -18,9 +18,10 @@ rule clean_all
|
|||||||
description = Cleaning directory
|
description = Cleaning directory
|
||||||
|
|
||||||
|
|
||||||
build make.config .make.config.sh generated.ninja: build_generated_ninja configure.py
|
build make.config .make.config.sh generated.ninja impossible_target: build_generated_ninja
|
||||||
|
|
||||||
build all: run_ninja generated.ninja
|
build all: run_ninja generated.ninja
|
||||||
|
|
||||||
default all
|
default all
|
||||||
|
|
||||||
build EZFIO.${VERSION}.tar.gz: build_archive
|
build EZFIO.${VERSION}.tar.gz: build_archive
|
||||||
|
64
configure.py
64
configure.py
@ -2,6 +2,20 @@
|
|||||||
|
|
||||||
import os,sys
|
import os,sys
|
||||||
|
|
||||||
|
def write_if_different(filename,s):
|
||||||
|
try:
|
||||||
|
with open(filename, "r") as f:
|
||||||
|
ref = f.read()
|
||||||
|
except:
|
||||||
|
ref = ""
|
||||||
|
|
||||||
|
if ref == s:
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
with open(filename, "w") as f:
|
||||||
|
f.write(s)
|
||||||
|
|
||||||
|
|
||||||
with open("version",'r') as f:
|
with open("version",'r') as f:
|
||||||
version = f.read().strip().rsplit('=')[1]
|
version = f.read().strip().rsplit('=')[1]
|
||||||
|
|
||||||
@ -13,22 +27,37 @@ d_default = {
|
|||||||
"RANLIB" : 'ranlib',
|
"RANLIB" : 'ranlib',
|
||||||
"AR" : 'ar',
|
"AR" : 'ar',
|
||||||
"NINJA" : 'ninja',
|
"NINJA" : 'ninja',
|
||||||
"CONFIG_FILES" :
|
|
||||||
' '.join([ os.path.join("config",x) for x in os.listdir('config') if x != '.empty'])
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CONFIG_FILES=' '.join([ os.path.join("config",x) for x in os.listdir('config') if x != '.empty'])
|
||||||
|
|
||||||
def create_make_config():
|
def create_make_config():
|
||||||
|
|
||||||
|
try:
|
||||||
|
d = read_make_config()
|
||||||
|
except:
|
||||||
|
d = {}
|
||||||
|
|
||||||
fmt = { "make.config" :'{0}={1}\n' ,
|
fmt = { "make.config" :'{0}={1}\n' ,
|
||||||
".make.config.sh": '{0}="{1}"\n' }
|
".make.config.sh": 'export {0}="{1}"\n' }
|
||||||
for filename in fmt:
|
|
||||||
with open(filename,'w') as out:
|
|
||||||
for var,default in d_default.iteritems():
|
for var,default in d_default.iteritems():
|
||||||
|
if var not in d:
|
||||||
try:
|
try:
|
||||||
cur = os.environ[var]
|
cur = os.environ[var]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
cur = default
|
cur = default
|
||||||
out.write(fmt[filename].format(var,cur))
|
d[var]=cur
|
||||||
|
|
||||||
|
for filename in fmt:
|
||||||
|
out = ""
|
||||||
|
for var,default in d_default.iteritems():
|
||||||
|
cur = d[var]
|
||||||
|
out += fmt[filename].format(var,cur)
|
||||||
|
write_if_different(filename,out)
|
||||||
|
|
||||||
|
return d
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def read_make_config():
|
def read_make_config():
|
||||||
@ -47,9 +76,7 @@ def read_make_config():
|
|||||||
|
|
||||||
def create_build_ninja():
|
def create_build_ninja():
|
||||||
|
|
||||||
create_make_config()
|
d=create_make_config()
|
||||||
|
|
||||||
d = read_make_config()
|
|
||||||
|
|
||||||
d["irpf90_files"] = [ "src/{0}".format(x) for x in
|
d["irpf90_files"] = [ "src/{0}".format(x) for x in
|
||||||
"""
|
"""
|
||||||
@ -71,20 +98,13 @@ def create_build_ninja():
|
|||||||
|
|
||||||
|
|
||||||
template = """
|
template = """
|
||||||
rule build_archive
|
|
||||||
command = git archive --format=tar HEAD > EZFIO.{VERSION}.tar && mkdir -p EZFIO && cd EZFIO && tar -xvf ../EZFIO.{VERSION}.tar && cd .. && rm EZFIO.{VERSION}.tar && tar -zcvf EZFIO.{VERSION}.tar.gz EZFIO && rm -rf EZFIO
|
|
||||||
description = Building archive
|
|
||||||
|
|
||||||
rule build_make_config
|
|
||||||
command = python configure.py
|
|
||||||
description = Creating make.config
|
|
||||||
|
|
||||||
rule compile_irpf90
|
rule compile_irpf90
|
||||||
command = cd src ; {IRPF90} --ninja
|
command = bash -c 'source .make.config.sh ; cd src ; {IRPF90} --ninja'
|
||||||
description = Compiling IRPF90
|
description = Compiling IRPF90
|
||||||
|
|
||||||
rule build_irpf90_a
|
rule build_irpf90_a
|
||||||
command = {NINJA} -C src/IRPF90_temp
|
command = {NINJA} -C src/IRPF90_temp && touch $out
|
||||||
description = Compiling Fortran files
|
description = Compiling Fortran files
|
||||||
|
|
||||||
rule build_libezfio_a
|
rule build_libezfio_a
|
||||||
@ -103,9 +123,6 @@ rule build_ocaml
|
|||||||
command = cd src ; python create_ocaml.py
|
command = cd src ; python create_ocaml.py
|
||||||
description = Building Ocaml module
|
description = Building Ocaml module
|
||||||
|
|
||||||
|
|
||||||
build make.config: build_make_config | configure.py
|
|
||||||
|
|
||||||
build {irpf90_files}: compile_irpf90 | {irpf90_sources} {CONFIG_FILES}
|
build {irpf90_files}: compile_irpf90 | {irpf90_sources} {CONFIG_FILES}
|
||||||
|
|
||||||
build src/IRPF90_temp/irpf90.a: build_irpf90_a | {irpf90_files}
|
build src/IRPF90_temp/irpf90.a: build_irpf90_a | {irpf90_files}
|
||||||
@ -119,9 +136,8 @@ build Python/ezfio.py: build_python | lib/libezfio.a
|
|||||||
build Ocaml/ezfio.ml: build_ocaml | lib/libezfio.a
|
build Ocaml/ezfio.ml: build_ocaml | lib/libezfio.a
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
d["CONFIG_FILES"] = CONFIG_FILES
|
||||||
with open('generated.ninja','w') as f:
|
write_if_different('generated.ninja',template.format(**d))
|
||||||
f.write(template.format(**d))
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
Loading…
Reference in New Issue
Block a user