Gilles Peskine | 0f4df8f | 2021-01-18 20:31:07 +0100 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
| 3 | set -eu |
| 4 | |
| 5 | usage () { |
| 6 | cat <<EOF |
| 7 | Usage: $0 PATH_TO_PSA_CRYPTO_API_TREE |
| 8 | Update the rendered copy of the PSA Cryptography API specification. |
| 9 | |
| 10 | 1. Check out the desired version of the PSA Crypto API specification. |
| 11 | git clone https://github.com/ARMmbed/psa-crypto-api |
| 12 | git checkout <TAG> |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 13 | 2. Build the specification and extensions. |
Gilles Peskine | 0f4df8f | 2021-01-18 20:31:07 +0100 | [diff] [blame] | 14 | cd psa-crypto-api |
| 15 | sudo docker build -t psa_api - <psa-crypto-api/scripts/Dockerfile |
Gilles Peskine | df93ecd | 2022-04-12 18:01:11 +0200 | [diff] [blame] | 16 | sudo docker run -i -t -u \$(id -u):\$(id -g) -v \$PWD:/var/lib/builds psa_api -c make |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 17 | for d in ext-*; do |
| 18 | sudo docker run -i -t -u \$(id -u):\$(id -g) -v \$PWD:/var/lib/builds psa_api -c "make -C $d"; |
| 19 | done |
Gilles Peskine | 0f4df8f | 2021-01-18 20:31:07 +0100 | [diff] [blame] | 20 | cd .. |
| 21 | 3. Copy the rendered files. |
| 22 | $0 psa-crypto-api |
Gilles Peskine | b92fd9c | 2022-04-12 18:28:42 +0200 | [diff] [blame] | 23 | 4. If this is a new numbered version: |
| 24 | edit docs/psa/index.md # Add the new version |
| 25 | make |
| 26 | ln -snf <VERSION> docs/latest |
| 27 | 5. Commit the changes. |
Gilles Peskine | c2db5f0 | 2021-01-18 20:36:53 +0100 | [diff] [blame] | 28 | git add docs/html docs/PSA_Cryptography_API_Specification.pdf |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 29 | git add docs |
Gilles Peskine | c2db5f0 | 2021-01-18 20:36:53 +0100 | [diff] [blame] | 30 | git commit |
Gilles Peskine | 0f4df8f | 2021-01-18 20:31:07 +0100 | [diff] [blame] | 31 | EOF |
| 32 | } |
| 33 | |
| 34 | if [ $# -ne 1 ] || [ "$1" = "--help" ]; then |
| 35 | usage |
| 36 | exit $(($# != 1)) |
| 37 | fi |
| 38 | |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 39 | # get_version DIRECTORY [EXTENSION_NAME] |
| 40 | # --> $version |
| 41 | get_version () { |
| 42 | version=$(sed -n 's/^\(Version[^0-9A-Za-z][^0-9A-Za-z]*\)//; T; y/ /_/; p; q' "$1/sphinx-build/html/index.html") |
| 43 | if [ -z "$version" ]; then |
| 44 | suffix= |
| 45 | if [ -n "$2" ]; then |
| 46 | suffix=" in $2" |
| 47 | fi |
| 48 | echo >&2 "Fatal error: unable to determine the version$suffix." |
| 49 | exit 1 |
| 50 | fi |
| 51 | if [ ! -d "docs/$version" ]; then |
| 52 | mkdir "docs/$version" |
| 53 | cat <<EOF |
Gilles Peskine | 4519de7 | 2022-04-07 13:44:25 +0200 | [diff] [blame] | 54 | NOTE: Please update "Past versions" in docs/psa/index.md to add $version |
| 55 | then run make. |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 56 | EOF |
| 57 | if [ -z "$2" ]; then |
| 58 | cat <<EOF |
Gilles Peskine | 4519de7 | 2022-04-07 13:44:25 +0200 | [diff] [blame] | 59 | NOTE: You may need to update the "latest" symbolic link. |
| 60 | ln -snf "$version" docs/latest |
| 61 | EOF |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 62 | fi |
| 63 | fi |
| 64 | } |
Gilles Peskine | 4519de7 | 2022-04-07 13:44:25 +0200 | [diff] [blame] | 65 | |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 66 | get_version "$1" "" |
Gilles Peskine | 4519de7 | 2022-04-07 13:44:25 +0200 | [diff] [blame] | 67 | rsync -a --delete "$1/sphinx-build/html" "docs/$version/" |
| 68 | rsync -a "$1/sphinx-build/latex/psa_crypto_api.pdf" "docs/$version/PSA_Cryptography_API_Specification.pdf" |
Gilles Peskine | d108ecd | 2022-04-12 18:30:58 +0200 | [diff] [blame] | 69 | |
| 70 | for d in "$1"/ext-*; do |
| 71 | get_version "$d" "${d##*/}" |
| 72 | rsync -a --delete --include='psa_*.pdf' --exclude='*' "$d/sphinx-build/latex/" "docs/$version/" |
| 73 | rsync -a --delete "$d/sphinx-build/html" "docs/$version/" |
| 74 | done |