Improve revision handling.
This commit is contained in:
28
configure.py
28
configure.py
@ -26,10 +26,6 @@ SCRIPT_DIR = os.path.dirname(os.path.abspath(__file__))
|
|||||||
ROOT_DIR = SCRIPT_DIR
|
ROOT_DIR = SCRIPT_DIR
|
||||||
NINJA_BUILD = os.path.join(ROOT_DIR, 'build.ninja')
|
NINJA_BUILD = os.path.join(ROOT_DIR, 'build.ninja')
|
||||||
|
|
||||||
REVISION = 'TODO'
|
|
||||||
#REVISION=$(shell git rev-parse HEAD | head -c 20)
|
|
||||||
#REVSHORT=$(shell echo $(REVISION) | head -c 7)
|
|
||||||
|
|
||||||
CFLAGS_COMMON = [
|
CFLAGS_COMMON = [
|
||||||
'-O2',
|
'-O2',
|
||||||
'-I', '$src',
|
'-I', '$src',
|
||||||
@ -144,7 +140,8 @@ dst = {DST_DIR}
|
|||||||
ninjadir = {NINJA_DIR}
|
ninjadir = {NINJA_DIR}
|
||||||
builddir = $dst
|
builddir = $dst
|
||||||
VERSION = {VERSION}
|
VERSION = {VERSION}
|
||||||
REVISION = {REVISION}
|
STABLE_VERSION = {STABLE_VERSION}
|
||||||
|
OLD_STABLE_VERSION = {OLD_STABLE_VERSION}
|
||||||
CFLAGS = {' '.join(CFLAGS)}
|
CFLAGS = {' '.join(CFLAGS)}
|
||||||
STRIP_ARGS = {' '.join(STRIP_ARGS)}
|
STRIP_ARGS = {' '.join(STRIP_ARGS)}
|
||||||
LIBS = {' '.join(LIBS)}
|
LIBS = {' '.join(LIBS)}
|
||||||
@ -168,11 +165,23 @@ rule config
|
|||||||
description = CONFIG
|
description = CONFIG
|
||||||
command = $src/configure.py -q
|
command = $src/configure.py -q
|
||||||
|
|
||||||
|
rule revstamp
|
||||||
|
description = REVSTAMP
|
||||||
|
command = $in $src $out
|
||||||
|
|
||||||
|
build $dst/gen/REVISION $dst/gen/REVSHORT: revstamp $src/tools/revstamp.py
|
||||||
|
|
||||||
rule importation
|
rule importation
|
||||||
description = IMPORTATION $in
|
description = IMPORTATION $in
|
||||||
depfile = $out.d
|
depfile = $out.d
|
||||||
deps = gcc
|
deps = gcc
|
||||||
command = $src/tools/importation.py -i $in -o $out -I $dst -I $src $options --depsout $depfile -DVERSION=$VERSION -DREVISION=$REVERSION
|
command = $src/tools/importation.py -i $in -o $out -I $dst -I $src $options \
|
||||||
|
--depsout $depfile \
|
||||||
|
-DVERSION=$VERSION \
|
||||||
|
-DSTABLE_VERSION=$STABLE_VERSION \
|
||||||
|
-DOLD_STABLE_VERSION=$OLD_STABLE_VERSION \
|
||||||
|
-FREVISION=$dst/gen/REVISION \
|
||||||
|
-FREVSHORT=$dst/gen/REVSHORT
|
||||||
|
|
||||||
rule compile
|
rule compile
|
||||||
description = CXX $in
|
description = CXX $in
|
||||||
@ -261,15 +270,14 @@ build allclean: all_clean
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
def Importation(target, source, header_mode='cpp', name=None, keep=False, deps=None, implicit=[]):
|
def Importation(target, source, header_mode='cpp', name=None, keep=False, deps=None, implicit=[], options=''):
|
||||||
global output
|
global output
|
||||||
options = ''
|
|
||||||
if keep:
|
if keep:
|
||||||
options += '--keep-first-comment'
|
options += ' --keep-first-comment'
|
||||||
if name:
|
if name:
|
||||||
options += ' --name ' + name + ' --header ' + header_mode
|
options += ' --name ' + name + ' --header ' + header_mode
|
||||||
implicit = ' '.join(implicit)
|
implicit = ' '.join(implicit)
|
||||||
output += f'build {target}: importation {source} | {implicit}\n'
|
output += f'build {target}: importation {source} | $dst/gen/REVISION $dst/gen/REVSHORT {implicit}\n'
|
||||||
if options:
|
if options:
|
||||||
output += f' options = {options}\n'
|
output += f' options = {options}\n'
|
||||||
if deps:
|
if deps:
|
||||||
|
|||||||
@ -12,6 +12,7 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
|
OPTIONS = '-I $src/esp32'
|
||||||
ESP32_FILES = []
|
ESP32_FILES = []
|
||||||
ESP32_ZIP_FILES = []
|
ESP32_ZIP_FILES = []
|
||||||
|
|
||||||
@ -21,7 +22,7 @@ ESP32_ZIP_FILES += [
|
|||||||
'$src/esp32/README.txt'),
|
'$src/esp32/README.txt'),
|
||||||
Importation('$dst/esp32/ESP32forth/ESP32forth.ino',
|
Importation('$dst/esp32/ESP32forth/ESP32forth.ino',
|
||||||
'$src/esp32/ESP32forth.ino',
|
'$src/esp32/ESP32forth.ino',
|
||||||
implicit=['$dst/gen/esp32_boot.h'], keep=True),
|
implicit=['$dst/gen/esp32_boot.h'], keep=True, options=OPTIONS),
|
||||||
]
|
]
|
||||||
Importation('$dst/gen/esp32_boot.h', '$src/esp32/esp32_boot.fs', name='boot')
|
Importation('$dst/gen/esp32_boot.h', '$src/esp32/esp32_boot.fs', name='boot')
|
||||||
|
|
||||||
|
|||||||
21
site/BUILD
21
site/BUILD
@ -20,22 +20,23 @@ REPLACE = [
|
|||||||
'-DOLD_STABLE_VERSION=' + OLD_STABLE_VERSION,
|
'-DOLD_STABLE_VERSION=' + OLD_STABLE_VERSION,
|
||||||
]
|
]
|
||||||
|
|
||||||
UE_REPLACE = REPLACE + ['-DFORTH=uEForth']
|
OPTIONS = '-I $src/site'
|
||||||
ESP_REPLACE = REPLACE + ['-DFORTH=ESP32forth']
|
UE_OPTIONS = OPTIONS + ' -DFORTH=uEForth'
|
||||||
|
ESP_OPTIONS = OPTIONS + ' -DFORTH=ESP32forth'
|
||||||
|
|
||||||
DEPLOY_ITEMS = []
|
DEPLOY_ITEMS = []
|
||||||
|
|
||||||
DEPLOY_ITEMS += [
|
DEPLOY_ITEMS += [
|
||||||
Copy('$dst/deploy/.gcloudignore', '$src/site/.gcloudignore'),
|
Copy('$dst/deploy/.gcloudignore', '$src/site/.gcloudignore'),
|
||||||
Copy('$dst/deploy/ueforth.js', '$dst/web/ueforth.js'),
|
Copy('$dst/deploy/ueforth.js', '$dst/web/ueforth.js'),
|
||||||
Importation('$dst/deploy/index.html', '$src/site/index.html'),
|
Importation('$dst/deploy/index.html', '$src/site/index.html', options=ESP_OPTIONS),
|
||||||
Importation('$dst/deploy/linux.html', '$src/site/linux.html'),
|
Importation('$dst/deploy/linux.html', '$src/site/linux.html', options=UE_OPTIONS),
|
||||||
Importation('$dst/deploy/windows.html', '$src/site/windows.html'),
|
Importation('$dst/deploy/windows.html', '$src/site/windows.html', options=UE_OPTIONS),
|
||||||
Importation('$dst/deploy/web.html', '$src/site/web.html'),
|
Importation('$dst/deploy/web.html', '$src/site/web.html', options=UE_OPTIONS),
|
||||||
Importation('$dst/deploy/ESP32forth.html', '$src/site/ESP32forth.html'),
|
Importation('$dst/deploy/ESP32forth.html', '$src/site/ESP32forth.html', options=ESP_OPTIONS),
|
||||||
Importation('$dst/deploy/pico-ice.html', '$src/site/pico-ice.html'),
|
Importation('$dst/deploy/pico-ice.html', '$src/site/pico-ice.html', options=UE_OPTIONS),
|
||||||
Importation('$dst/deploy/internals.html', '$src/site/internals.html'),
|
Importation('$dst/deploy/internals.html', '$src/site/internals.html', options=UE_OPTIONS),
|
||||||
Importation('$dst/deploy/classic.html', '$src/site/classic.html'),
|
Importation('$dst/deploy/classic.html', '$src/site/classic.html', options=ESP_OPTIONS),
|
||||||
Copy('$dst/deploy/eforth.go', '$src/site/eforth.go'),
|
Copy('$dst/deploy/eforth.go', '$src/site/eforth.go'),
|
||||||
Copy('$dst/deploy/app.yaml', '$src/site/app.yaml'),
|
Copy('$dst/deploy/app.yaml', '$src/site/app.yaml'),
|
||||||
]
|
]
|
||||||
|
|||||||
@ -24,6 +24,7 @@ parser.add_argument('-i', required=True)
|
|||||||
parser.add_argument('-o', required=True)
|
parser.add_argument('-o', required=True)
|
||||||
parser.add_argument('-I', action='append')
|
parser.add_argument('-I', action='append')
|
||||||
parser.add_argument('-D', action='append')
|
parser.add_argument('-D', action='append')
|
||||||
|
parser.add_argument('-F', action='append')
|
||||||
parser.add_argument('--depsout')
|
parser.add_argument('--depsout')
|
||||||
parser.add_argument('--no-out', action='store_true')
|
parser.add_argument('--no-out', action='store_true')
|
||||||
parser.add_argument('--keep-first-comment', action='store_true')
|
parser.add_argument('--keep-first-comment', action='store_true')
|
||||||
@ -32,6 +33,7 @@ parser.add_argument('--header')
|
|||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
bases = args.I or []
|
bases = args.I or []
|
||||||
replacements = args.D or []
|
replacements = args.D or []
|
||||||
|
file_replacements = args.F or []
|
||||||
|
|
||||||
results = []
|
results = []
|
||||||
imported = set([__file__])
|
imported = set([__file__])
|
||||||
@ -57,9 +59,9 @@ def Import(filename):
|
|||||||
sfilename = line.split('"')[1]
|
sfilename = line.split('"')[1]
|
||||||
done = False
|
done = False
|
||||||
for base in bases:
|
for base in bases:
|
||||||
sfilename = os.path.join(base, sfilename)
|
bfilename = os.path.join(base, sfilename)
|
||||||
if os.path.exists(sfilename):
|
if os.path.exists(bfilename):
|
||||||
Import(sfilename)
|
Import(bfilename)
|
||||||
done = True
|
done = True
|
||||||
break
|
break
|
||||||
if not done:
|
if not done:
|
||||||
@ -75,6 +77,10 @@ def Process():
|
|||||||
for r in replacements:
|
for r in replacements:
|
||||||
name, value = r.split('=', 1)
|
name, value = r.split('=', 1)
|
||||||
line = line.replace('{{' + name + '}}', value)
|
line = line.replace('{{' + name + '}}', value)
|
||||||
|
for r in file_replacements:
|
||||||
|
name, filename = r.split('=', 1)
|
||||||
|
imported.add(os.path.abspath(filename))
|
||||||
|
line = line.replace('{{' + name + '}}', open(filename).read())
|
||||||
output.append(line)
|
output.append(line)
|
||||||
# Drop comments.
|
# Drop comments.
|
||||||
comment1 = False
|
comment1 = False
|
||||||
|
|||||||
@ -1,4 +1,17 @@
|
|||||||
#! /usr/bin/env python3
|
#! /usr/bin/env python3
|
||||||
|
# Copyright 2023 Bradley D. Nelson
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
|||||||
32
tools/revstamp.py
Executable file
32
tools/revstamp.py
Executable file
@ -0,0 +1,32 @@
|
|||||||
|
#! /usr/bin/env python3
|
||||||
|
# Copyright 2023 Bradley D. Nelson
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
import os
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
|
||||||
|
base_path = sys.argv[1]
|
||||||
|
revision_file = sys.argv[2]
|
||||||
|
revshort_file = sys.argv[3]
|
||||||
|
|
||||||
|
revision = subprocess.check_output('git rev-parse HEAD ' + base_path, shell=True).splitlines()[0]
|
||||||
|
revshort = revision[:7]
|
||||||
|
|
||||||
|
if not os.path.exists(revision_file) or open(revision_file).read() != revision:
|
||||||
|
with open(revision_file, 'wb') as fh:
|
||||||
|
fh.write(revision)
|
||||||
|
if not os.path.exists(revshort_file) or open(revshort_file).read() != revshort:
|
||||||
|
with open(revshort_file, 'wb') as fh:
|
||||||
|
fh.write(revshort)
|
||||||
Reference in New Issue
Block a user