From 0733cb22ba517866c1a4e2811f1ce2a6c41f9d4a Mon Sep 17 00:00:00 2001 From: Giles Knap Date: Mon, 20 Nov 2023 07:57:30 +0000 Subject: [PATCH] update to latest dependencies --- .github/workflows/build.sh | 7 +++---- Dockerfile | 17 +++++++++++------ README.md | 8 +++++++- build | 7 ++----- ibek-support | 2 +- requirements.txt | 5 +++-- requirements_ec.txt | 3 +++ 7 files changed, 30 insertions(+), 19 deletions(-) create mode 100644 requirements_ec.txt diff --git a/.github/workflows/build.sh b/.github/workflows/build.sh index 090e4d8..412a0e9 100755 --- a/.github/workflows/build.sh +++ b/.github/workflows/build.sh @@ -19,10 +19,10 @@ if [[ "${PUSH}" == 'true' ]] ; then EC_PUSH='--push' ; fi THIS=$(dirname ${0}) set -xe -mkdir -p ${CACHE} +mkdir -p ${EC_CACHE} # get the current version of ec CLI -pip install -r ${THIS}/../../requirements.txt +pip install -r ${THIS}/../../requirements_ec.txt # add cache arguments - local file cache passed by github seems to be most reliable export EC_CARGS=" @@ -37,8 +37,7 @@ export EC_CARGS=" ec -v dev build ${EC_TAG} ${EC_PLATFORM} ${EC_PUSH} ${EC_CARGS} # extract the ioc schema from the runtime image -ec dev launch-local ${EC_TAG} --execute \ -'ibek ioc generate-schema /epics/ibek/*.ibek.support.yaml' > ibek.ioc.schema.json +ec dev launch-local ${EC_TAG} --execute 'ibek ioc generate-schema' > ibek.ioc.schema.json # run acceptance tests shopt -s nullglob # expand to nothing if no tests are found diff --git a/Dockerfile b/Dockerfile index 80c289f..57475f4 100644 --- a/Dockerfile +++ b/Dockerfile @@ -6,11 +6,13 @@ ARG REGISTRY=ghcr.io/epics-containers FROM ${REGISTRY}/epics-base-${TARGET_ARCHITECTURE}-developer:${BASE} AS developer -# get latest ibek while under dev. In future the epics-base version will be used -RUN pip install --upgrade ibek==1.4.2 +# Get latest ibek while in development. Will come from epics-base when stable +COPY requirements.txt requirements.txt +RUN pip install --upgrade -r requirements.txt -# the devcontainer mounts the project root to /epics/ioc-template -WORKDIR /epics/ioc-template/ibek-support +# The devcontainer mounts the project root to /epics/ioc-adsimdetector. Using +# the same location here makes devcontainer/runtime differences transparent. +WORKDIR /epics/ioc-pmac/ibek-support # copy the global ibek files COPY ibek-support/_global/ _global @@ -22,7 +24,7 @@ COPY ibek-support/asyn/ asyn/ RUN asyn/install.sh R4-42 COPY ibek-support/autosave/ autosave/ -RUN autosave/install.sh R5-10-2 +RUN autosave/install.sh R5-11 COPY ibek-support/busy/ busy/ RUN busy/install.sh R1-7-3 @@ -39,7 +41,10 @@ RUN motor/install.sh R7-2-3b1 COPY ibek-support/pmac/ pmac/ RUN pmac/install.sh 2-4-10 -# Generate template IOC source tree / generate Makefile / compile +COPY ibek-support/ADAravis/ ADAravis/ +RUN ADAravis/install.sh R2-3 + +# create IOC source tree, generate Makefile and compile IOC Instance RUN ibek ioc build ##### runtime preparation stage ################################################ diff --git a/README.md b/README.md index 79220df..3530e3c 100644 --- a/README.md +++ b/README.md @@ -1 +1,7 @@ -A container image for a generic IOC to support delta tau motion controllers. +An epics-containers generic IOC source file for Delta Tau pmac motion controllers. + +Generates a Generic IOC for running in a container and +creating IOC instances to control pmac motion controllers. + +See the https://epics-containers.github.io + diff --git a/build b/build index b96d509..ca9d319 100755 --- a/build +++ b/build @@ -1,7 +1,7 @@ #!/bin/bash ################################################################################ -# generic local build script for epics-containers ioc repositories # +# generic local build script for epics-containers ioc repositories # ################################################################################ # pass rtems as first argument to build RTEMS on cross-compiler @@ -18,7 +18,4 @@ git submodule update --init ec dev build --arch ${TARGET_ARCHITECTURE} # get the schema file from the developer container and save it locally -ec dev launch-local --execute \ -'ibek ioc generate-schema /epics/ibek/*.ibek.support.yaml' \ -> ibek.ioc.schema.json - +ec dev launch-local --execute 'ibek ioc generate-schema' > ibek.ioc.schema.json diff --git a/ibek-support b/ibek-support index 9272b54..cf52a39 160000 --- a/ibek-support +++ b/ibek-support @@ -1 +1 @@ -Subproject commit 9272b54090ce883719654460891be0fcb1091113 +Subproject commit cf52a39c8a0f6d3b5d590ea911b8e7870306834d diff --git a/requirements.txt b/requirements.txt index 6343875..cea131a 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,2 +1,3 @@ -epics-containers-cli==2.6.3 -#git+https://github.com/epics-containers/epics-containers-cli.git@dev +ibek==1.5.0 +# to install direct from github during development in the dev branch: +#git+https://github.com/epics-containers/ibek.git@dev diff --git a/requirements_ec.txt b/requirements_ec.txt new file mode 100644 index 0000000..ac3632c --- /dev/null +++ b/requirements_ec.txt @@ -0,0 +1,3 @@ +epics-containers-cli==2.6.4 +# to install direct from github during development in the dev branch: +#git+https://github.com/epics-containers/epics-containers-cli.git@dev