| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | # |
| 3 | # Copyright (C) 2018 The Android Open Source Project |
| 4 | # |
| 5 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 6 | # you may not use this file except in compliance with the License. |
| 7 | # You may obtain a copy of the License at |
| 8 | # |
| 9 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 10 | # |
| 11 | # Unless required by applicable law or agreed to in writing, software |
| 12 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 13 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 14 | # See the License for the specific language governing permissions and |
| 15 | # limitations under the License. |
| 16 | |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 17 | # This script updates SQLite source files with a SQLite tarball. The tarball is |
| 18 | # downloaded from the sqlite website. |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 19 | # |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 20 | # Usage: UPDATE-SOURCE.bash [-nF] <year> <sqlite-release> |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 21 | # |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 22 | # This script must be executed in $ANDROID_BUILD_TOP/external/sqlite/. However, |
| 23 | # for testing it can run anywhere: use the -F switch. |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 24 | # |
| 25 | |
| 26 | set -e |
| 27 | |
| 28 | script_name="$(basename "$0")" |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 29 | script_dir=$(dirname $(realpath ${BASH_SOURCE[0]})) |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 30 | |
| Lee Shombert | 152fb62 | 2024-03-25 15:35:08 -0700 | [diff] [blame] | 31 | source $script_dir/common-functions.sh |
| 32 | |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 33 | usage() { |
| 34 | if [[ $# -gt 0 ]]; then echo "$*" >&2; fi |
| Lee Shombert | 152fb62 | 2024-03-25 15:35:08 -0700 | [diff] [blame] | 35 | echo "Usage: ${script_name} [-nF] [-u <url>] <year> <version>" |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 36 | echo " year the 4-digit year the sqlite version was released" |
| 37 | echo " version the sqlite version as <major>.<minor>[.<patch>]" |
| 38 | echo " the patch level defaults to 0" |
| 39 | echo " -n dry-run: evaluate arguments but d not change anything" |
| Lee Shombert | 152fb62 | 2024-03-25 15:35:08 -0700 | [diff] [blame] | 40 | echo " -u url download the tarball from the specified url" |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 41 | echo " -F force execution even if not in external/sqlite" |
| 42 | echo |
| Shai Barack | 4049550 | 2024-01-29 17:51:51 +0000 | [diff] [blame] | 43 | echo "Example:" |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 44 | echo "${script_name} 2023 3.42" |
| 45 | } |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 46 | |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 47 | dry_run= |
| 48 | force= |
| Lee Shombert | 152fb62 | 2024-03-25 15:35:08 -0700 | [diff] [blame] | 49 | src_tarball_url= |
| 50 | while getopts "hnFu:" option; do |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 51 | case $option in |
| 52 | h) usage; exit 0;; |
| 53 | n) dry_run=y;; |
| Lee Shombert | 152fb62 | 2024-03-25 15:35:08 -0700 | [diff] [blame] | 54 | u) src_tarball_url=$OPTARG;; |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 55 | F) force=y;; |
| 56 | *) usage "unknown switch"; exit 1;; |
| 57 | esac |
| 58 | done |
| 59 | shift $((OPTIND- 1)) |
| 60 | |
| 61 | if [[ $# -lt 2 ]]; then |
| 62 | usage; die "missing required arguments" |
| 63 | elif [[ $# -gt 2 ]]; then |
| 64 | die "extra arguments on command line" |
| 65 | fi |
| 66 | year=$1 |
| 67 | validate_year "$year" || die "invalid year" |
| 68 | sqlite_release=$(normalize_release "$2") || die "invalid release" |
| 69 | |
| 70 | sqlite_base="sqlite-autoconf-${sqlite_release}" |
| 71 | sqlite_file="${sqlite_base}.tar.gz" |
| Lee Shombert | 152fb62 | 2024-03-25 15:35:08 -0700 | [diff] [blame] | 72 | if [[ -z $src_tarball_url ]]; then |
| 73 | src_tarball_url="https://www.sqlite.org/$year/${sqlite_file}" |
| 74 | fi |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 75 | |
| 76 | if [[ -n $dry_run ]]; then |
| 77 | echo "fetching $src_tarball_url" |
| 78 | echo "installing in dist/$sqlite_base" |
| 79 | exit 0 |
| 80 | fi |
| 81 | |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 82 | pwd="$(pwd)" |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 83 | if [[ -z $force && ! "$pwd" =~ .*/external/sqlite/? ]] ; then |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 84 | die 'Execute this script in $ANDROID_BUILD_TOP/external/sqlite/' |
| 85 | fi |
| 86 | |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 87 | source_tgz=$(mktemp /tmp/sqlite-${sqlite_release}.zip.XXXXXX) |
| 88 | source_ext_dir="${source_tgz}.extracted" |
| 89 | trap "rm -r ${source_tgz} ${source_ext_dir}" EXIT |
| Shai Barack | 4049550 | 2024-01-29 17:51:51 +0000 | [diff] [blame] | 90 | wget ${src_tarball_url} -O ${source_tgz} |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 91 | |
| 92 | echo |
| 93 | echo "# Extracting the source tgz..." |
| 94 | echo_and_exec rm -fr "$source_ext_dir" |
| 95 | echo_and_exec mkdir -p "$source_ext_dir" |
| 96 | echo_and_exec tar xvf "$source_tgz" -C "$source_ext_dir" --strip-components=1 |
| 97 | |
| 98 | echo |
| 99 | echo "# Making file sqlite3.c in $source_ext_dir ..." |
| 100 | ( |
| 101 | cd "$source_ext_dir" |
| 102 | echo_and_exec ./configure |
| 103 | echo_and_exec make -j 4 sqlite3.c |
| 104 | ) |
| 105 | |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 106 | export dist_dir="dist/${sqlite_base}" |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 107 | echo |
| 108 | echo "# Copying the source files ..." |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 109 | echo_and_exec rm -rf ${dist_dir} |
| Shai Barack | 4049550 | 2024-01-29 17:51:51 +0000 | [diff] [blame] | 110 | echo_and_exec mkdir -p "${dist_dir}" |
| 111 | echo_and_exec mkdir -p "${dist_dir}/orig" |
| 112 | for to in ${dist_dir}/orig/ ${dist_dir}/ ; do |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 113 | echo_and_exec cp "$source_ext_dir/"{shell.c,sqlite3.c,sqlite3.h,sqlite3ext.h} "$to" |
| 114 | done |
| 115 | |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 116 | export patch_dir=${script_dir}/dist |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 117 | echo |
| 118 | echo "# Applying Android.patch ..." |
| 119 | ( |
| Shai Barack | 4049550 | 2024-01-29 17:51:51 +0000 | [diff] [blame] | 120 | cd ${dist_dir} |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 121 | echo "PATCHING IN $dist_dir" >&2 |
| 122 | echo_and_exec patch -i ${patch_dir}/Android.patch |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 123 | ) |
| 124 | |
| 125 | echo |
| 126 | echo "# Regenerating Android.patch ..." |
| 127 | ( |
| Shai Barack | 4049550 | 2024-01-29 17:51:51 +0000 | [diff] [blame] | 128 | cd ${dist_dir} |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 129 | echo_and_exec bash -c '(for x in orig/*; do diff -u -d $x ${x#orig/}; done) > Android.patch' |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 130 | echo_and_exec cp Android.patch ${patch_dir}/ |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 131 | ) |
| 132 | |
| Shai Barack | 4049550 | 2024-01-29 17:51:51 +0000 | [diff] [blame] | 133 | echo |
| 134 | echo "# Generating metadata ..." |
| 135 | ( |
| 136 | export SQLITE_URL=${src_tarball_url} |
| Lee Shombert | fd845c3 | 2024-03-24 11:06:59 -0700 | [diff] [blame] | 137 | export SQLITE_VERSION=$(prettify_release ${sqlite_release}) |
| Shai Barack | 4049550 | 2024-01-29 17:51:51 +0000 | [diff] [blame] | 138 | export YEAR=$(date +%Y) |
| 139 | export MONTH=$(date +%M) |
| 140 | export DAY=$(date +%D) |
| 141 | envsubst < README.version.TEMPLATE > ${dist_dir}/README.version |
| 142 | envsubst < METADATA.TEMPLATE > ${dist_dir}/METADATA |
| 143 | ) |
| 144 | |
| Makoto Onuki | 86e5272 | 2018-12-21 13:45:51 -0800 | [diff] [blame] | 145 | cat <<EOF |
| 146 | |
| 147 | ======================================================= |
| 148 | |
| 149 | Finished successfully! |
| 150 | |
| 151 | Make sure to update README.version |
| 152 | |
| 153 | ======================================================= |
| 154 | |
| 155 | EOF |
| 156 | |