12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- #!/usr/bin/env bash
- export VSCODE_QUALITY="stable"
- while getopts ":i" opt; do
- case "$opt" in
- i)
- export VSCODE_QUALITY="insider"
- ;;
- *)
- ;;
- esac
- done
- check_file() {
- if [[ -f "${1}" ]]; then
- echo applying patch: "${1}"
- if ! git apply --ignore-whitespace "${1}"; then
- echo failed to apply patch "${1}"
- git apply --reject "${1}"
- git apply --reject "../patches/helper/settings.patch"
- read -rp "Press any key when the conflict have been resolved..." -n1 -s
- git restore .vscode/settings.json
- git add .
- git diff --staged -U1 > "${1}"
- fi
- git add .
- git reset -q --hard HEAD
- fi
- }
- cd vscode || { echo "'vscode' dir not found"; exit 1; }
- git add .
- git reset -q --hard HEAD
- for FILE in ../patches/*.patch; do
- check_file "${FILE}"
- done
- if [[ "${VSCODE_QUALITY}" == "insider" ]]; then
- for FILE in ../patches/insider/*.patch; do
- check_file "${FILE}"
- done
- fi
- for FILE in ../patches/linux/*/*.patch; do
- check_file "${FILE}"
- done
|