-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrun_dev.sh
executable file
·123 lines (101 loc) · 3.32 KB
/
run_dev.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#!/bin/bash
# trap signals to exit processes started by the script and
# terminate them when the script exits or fails
trap "trap - SIGTERM && kill -- -$$" SIGINT SIGTERM EXIT
set -e
PYTHON=${PYTHON:-python3.10}
# If Python doesn't exist, try a generic version 3.
if ! command -v $PYTHON &> /dev/null; then
if command -v python3; then
PYTHON=python3
# Check if the installed Python version is 3.10 or later.
if ! ${PYTHON} -c "import sys; sys.exit( 0 if (sys.version_info[1]>=10) else 1)" ; then
echo ERROR: Python 3.10 or later not found.
echo Please install it or set the PYTHON environment variable to point to it.
exit 1
fi
else
echo ERROR: Python 3 not found.
echo Please install it or set the PYTHON environment variable to point to it.
exit 1
fi
fi
# Parse command line arguments.
NO_AI=0
DEPS_ONLY=0
VITE_OPTS=
UVICORN_HOST="localhost"
UVICORN_OPTS="$UVICORN_OPTS --port 5001"
while [[ $# -gt 0 ]]; do
key="$1"
case $key in
--no-ai)
NO_AI=1
shift
;;
--deps-only)
# Install dependencies and exit. Used by the Dockerfile to create a suitable image.
DEPS_ONLY=1
shift
;;
--host)
VITE_OPTS="$VITE_OPTS --host"
UVICORN_HOST="0.0.0.0"
shift
;;
*)
echo "Unknown argument: $key"
exit 1
;;
esac
done
UVICORN_OPTS="$UVICORN_OPTS --host $UVICORN_HOST"
# Create a virtualenv, install dependencies, and run the dev server.
if [ ! -f .venv/bin/activate ]; then
echo Creating a virtualenv and installing dependencies.
$PYTHON -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
# Install fastpbkdf2 if possible. Usually it has to be built and so requires a world
# in which gcc etc are available. If it fails, just warn the user.
pip install fastpbkdf2 || echo "*** WARNING: fastpbkdf2 failed to install. This will make the server slower with encrypted filesystems.***"
# Install AI requirements unless explicitly asked not to.
if [ $NO_AI -eq 0 ]; then
pip install -r rime/plugins/ai_requirements.txt
fi
echo Virtualenv created. To re-create this environment, delete .venv.
else
source .venv/bin/activate
# Check whether the currently installed packages are the same as
# the ones specified in the requirements.txt file
EXIT_STATUS=0
$PYTHON check_dependencies.py || EXIT_STATUS=$?
# Ask user whether to update the packages and proceed with installation when
# the .venv installed packages do not match the ones in the requirements.txt
if [ $EXIT_STATUS -eq 1 ]; then
echo "There is a mismatch between the currently installed packages and requirements.txt"
echo "Do you want to install the packages from requirements.txt with the specified versions? [y/n]"
read -n 1 ANSWER
if [[ $ANSWER == "y" ]]; then
pip install -r requirements.txt
fi
fi
fi
cd frontend
# Always npm install because it doesn't take long.
npm install
# Exit if we only want to install dependencies.
if [ $DEPS_ONLY -eq 1 ]; then
exit 0
fi
# Start Vite in the background. It will be killed when the script exits.
npm run dev -- $VITE_OPTS &
VITE_PID=$!
cd ..
if [ -f frontend/rime_settings.local.yaml ]; then
export RIME_CONFIG=frontend/rime_settings.local.yaml
else
export RIME_CONFIG=frontend/rime_settings.yaml
fi
# Start Uvicorn in the foreground, running the backend.
uvicorn --reload --reload-dir rime --interface asgi3 $UVICORN_OPTS --factory rime:rimeserver_create_app