-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathINSTALL.sh
executable file
·629 lines (547 loc) · 23.3 KB
/
INSTALL.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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
#!/bin/bash -vex
# Run this file with source ./INSTALL.md
# ```
#
# ## ANSI escape codes for colors
# These codes are used to colorize output in the terminal for better readability.
YELLOW='\033[1;33m'
BLUE='\033[1;36m' # Lighter shade of blue
RED='\033[0;31m'
GREEN='\033[1;32m' # Lighter shade of green
BOLD='\033[1m'
NC='\033[0m' # No Color
# ## Ensure the script is being sourced, not executed
# The script must be sourced so that it can set environment variables and return properly.
IS_SOURCED=$( [[ "${BASH_SOURCE[0]}" != "${0}" ]] && echo 1 || echo 0)
# If the script is executed (not sourced), display an error and exit.
if [ "$IS_SOURCED" -eq "0" ]; then
echo -e "${RED}This script must be sourced, not executed. Use 'source $0 $@'${NC}."
exit 1 # Exit is appropriate here since it's not sourced.
fi
# ## Display help if "--help" is in the arguments
# If "--help" is passed as an argument, display usage information and exit.
if [[ "$@" =~ "--help" ]]; then
echo -e "${BOLD}Usage:${NC} source $0 [OPTIONS]"
echo ""
echo -e "${BOLD}Options:${NC}"
echo -e " ${YELLOW}--help${NC} Show this help message and exit."
echo -e " ${YELLOW}--force${NC} Force rebuilding of SWI-Prolog."
echo -e " ${YELLOW}--swi=src|ppa|skip${NC} Choose the installation method for SWI-Prolog:"
echo -e " ${BLUE}'src'${NC} - Install from source."
echo -e " ${BLUE}'ppa'${NC} - Install from PPA (default)."
echo -e " ${BLUE}'skip'${NC} - Skip SWI-Prolog installation."
echo -e " ${YELLOW}--easy[=y|n]${NC} Enable or disable easy installation mode."
echo -e " '--easy' implies '--easy=y'."
echo -e " ${YELLOW}--steps${NC} Enable step-by-step installation."
echo -e " ${YELLOW}--allow-system-modifications${NC} Allow modifying system files and settings."
echo -e " ${YELLOW}--break-system-packages${NC} Use PIP (Python) Flag: --break-system-packages"
return 0 # Return instead of exit since the script is sourced.
fi
# ## Export environment variables
# Set necessary environment variables for the rest of the script to use.
export RPWD=$PWD # Save the original working directory.
export MeTTa=$(realpath "${BASH_SOURCE[0]}") # Get the real path of the current script.
export METTALOG_DIR=$(dirname "$MeTTa") # Get the directory where the script is located.
# Change to the script's directory, or return an error if the directory change fails.
cd "$METTALOG_DIR" || { echo "Failed to navigate to $METTALOG_DIR"; return 1; }
# Optionally ignore changes to `.bash_history`.
if [ -f .bash_history ]; then
(cd $METTALOG_DIR ; git update-index --assume-unchanged .bash_history) || true
fi
# ## Default values for variables
# These default values are set unless the user overrides them through command-line arguments.
FORCE_REINSTALL_SWI=0
SWI_INSTALL="src"
EASY_INSTALL="?"
INSTALL_TYPE="non_docker"
# ## Detect environment (GitHub Actions, Jenkins, Docker, etc.)
# Automatically detect if the script is being run in a specific environment (GitHub Actions, Jenkins, Docker).
if [ -n "$GITHUB_ACTIONS" ]; then
echo -e "${BLUE}GitHub Actions environment detected${NC}."
INSTALL_TYPE="github_vm"
export PIP_BREAK_SYSTEM_PACKAGES=1
export ALLOW_MODIFY_SYSTEM=1
SWI_INSTALL="ppa"
EASY_INSTALL="Y"
elif [ ! -z "$JENKINS_URL" ]; then
echo -e "${BLUE}Jenkins environment detected${NC}."
INSTALL_TYPE="jenkins_ci"
#export PIP_BREAK_SYSTEM_PACKAGES=1
#export ALLOW_MODIFY_SYSTEM=1
SWI_INSTALL="ppa"
EASY_INSTALL="Y"
elif [ -f /.dockerenv ] || grep -qa docker /proc/1/cgroup; then
echo -e "${BLUE}Docker environment detected${NC}."
INSTALL_TYPE="docker_vm"
export PIP_BREAK_SYSTEM_PACKAGES=1
export ALLOW_MODIFY_SYSTEM=1
SWI_INSTALL="src"
EASY_INSTALL="Y"
else
echo -e "${BLUE}User's Devel Machine${NC}."
INSTALL_TYPE="non_docker"
SWI_INSTALL="src"
EASY_INSTALL="Y"
fi
# ## Parse command-line arguments
# Parse and process any command-line arguments passed to the script.
for arg in "$@"; do
case $arg in
--swi=*) SWI_INSTALL="${arg#*=}" ;;
--force) FORCE_REINSTALL_SWI=1 ; UPDATE_SYSTEM=1 ;;
--steps) EASY_INSTALL="N" ;;
--easy) EASY_INSTALL="Y" ;;
--easy=*)
easy_value=$(echo "${arg#*=}" | tr '[:upper:]' '[:lower:]')
[[ "$easy_value" =~ ^(y|n)$ ]] && EASY_INSTALL="${easy_value^^}" || {
echo -e "${RED}Invalid value for --easy. Use y|n.${NC}"; return 1
}
;;
--allow-system-modifications)
export ALLOW_MODIFY_SYSTEM=1
UPDATE_SYSTEM=1
echo -e "${GREEN}System modifications allowed${NC}"
;;
--break-system-packages)
export PIP_BREAK_SYSTEM_PACKAGES=1
echo -e "${GREEN}Breaking system packages allowed${NC}"
;;
*) echo -e "${RED}Unknown argument:${NC} $arg" ;;
esac
done
# ## Prompt functions
# Function to prompt for user confirmation with 'N' as the default
confirm_with_default() {
echo -e -n "$2"
while true; do
if [ "$1" == "N" ]; then
read -s -p " (y/N): " -n 1 yn
else
read -s -p " (${1}/n): " -n 1 yn
fi
if [ -z "$yn" ]; then
yn="$1"
fi
case $yn in
[Yy]* ) echo "Y" && return 0;;
[Nn]* ) echo "N" && return 1;;
* ) echo -e "${YELLOW}Please answer yes or no${NC}.";;
esac
done
}
prompt_for_input() {
# Function to prompt for input with a default value to be used later
read -e -i "$2" -p "$1" value
echo -e "${value:-$2}"
}
# ## Version comparison
# Function to compare versions
version_ge() {
# Compare $1 with $2; if $1 >= $2, return 0 (true), else return 1 (false)
printf '%s\n%s' "$2" "$1" | sort -VC
return $?
}
# ## SWI-Prolog dependencies
# List of required system dependencies for SWI-Prolog development, including various Java development tools and build systems.
SWI_DEV_DEPS="build-essential autoconf git cmake libpython3-dev libgmp-dev libssl-dev unixodbc-dev libffi-dev \
libreadline-dev zlib1g-dev libarchive-dev libossp-uuid-dev libxext-dev libice-dev libjpeg-dev \
libxinerama-dev libxft-dev libxpm-dev libunwind-dev libxt-dev pkg-config libdb-dev libpcre3 libpcre3-dev \
libpcre2-dev libpcrecpp0v5 libpcre16-3 libpcre32-3 libpcrecpp0v5 libqt5widgets5 qtbase5-dev \
libgoogle-perftools-dev"
# Required for JPL
SWI_DEV_DEPS+=" junit junit4 libhamcrest-java default-jdk default-jdk-headless"
# Required for VENV
SWI_DEV_DEPS+=" python3-venv"
# Required for EDITLINE
SWI_DEV_DEPS+=" libedit-dev"
# Required to Fix "Could NOT find LibYAML (missing: LIBYAML_INCLUDE_DIR YAML_LIBRARY)"
SWI_DEV_DEPS+=" libyaml-dev"
# Function to check if a package is installed
is_package_installed() {
dpkg-query -W -f='${Status}' "$1" 2>/dev/null | grep -q "install ok installed"
}
# ## Install SWI-Prolog dependencies
# Function to ensure required system dependencies are installed.
install_swi_devel_deps() {
local missing_packages=()
echo -e "${BLUE}Checking required system dependencies...${NC}"
# Loop through each package in SWI_DEV_DEPS to check if it's installed
for package in $SWI_DEV_DEPS; do
if ! is_package_installed "$package"; then
missing_packages+=("$package")
fi
done
if [ ${#missing_packages[@]} -eq 0 ]; then
echo -e "${GREEN}All development dependencies are already installed.${NC}"
return 0
else
echo -e "${YELLOW}The following packages are missing:${NC}"
echo "${missing_packages[@]}"
fi
if [ "$UPDATE_SYSTEM" -eq 1 ]; then
echo -e "${BLUE}Installing missing dependencies...${NC}"
sudo apt-get update
sudo apt-get install -y "${missing_packages[@]}" && {
echo -e "${GREEN}All missing build dependencies installed successfully${NC}."
return 0
} || {
echo -e "${RED}Failed to install one or more dependencies.${NC}"
return 1 # Fail and return on error.
}
else
echo -e "${RED}System modifications are not allowed. The following missing dependencies were found but cannot be installed:${NC}"
for pkg in "${missing_packages[@]}"; do
echo -e "${RED}$pkg${NC}"
done
return 1 # Fail and return because system updates aren't allowed.
fi
}
# ## Install SWI-Prolog based on user's choice
# This section will trigger SWI-Prolog installation based on the chosen method (source, PPA, or skip).
install_swi() {
if [ "$SWI_INSTALL" = "src" ]; then
( install_swi_from_src )
elif [ "$SWI_INSTALL" = "ppa" ]; then
install_swi_from_ppa
elif [ "$SWI_INSTALL" = "upgrade" ]; then
install_swi_from_ppa_UP
else
echo "Skipping SWI-Prolog installation. SWI_INSTALL is set to $SWI_INSTALL."
fi
}
install_swi_from_ppa_UP() {
echo -e "${BLUE}Installing SWI-Prolog Devel PPA UPGRADING..${NC}."
if false && confirm_with_default "N" "Blank out APT SOURCES"; then
echo -e "${BLUE}Blanking out APT SOURCES.${NC}."
echo " " > /etc/apt/sources.list
fi
sudo apt install -y apt-utils software-properties-common
sudo apt-add-repository -y ppa:swi-prolog/devel
sudo apt-get update
echo -e "${BLUE}Remove existing installation if any before reinstalling/upgrading..${NC}."
sudo apt-get remove -y swi-prolog??*
sudo apt-get install -y swi-prolog
}
install_swi_from_ppa() {
install_swi_devel_deps
echo -e "${BLUE}Installing SWI-Prolog Devel PPA..${NC}."
sudo add-apt-repository ppa:swi-prolog/devel -y
sudo apt update
echo -e "${BLUE}Installing SWI-Prolog Itself..${NC}."
sudo apt install -y swi-prolog
}
# SWI-Prolog from source
install_swi_from_src() {
echo -e "${BLUE}Installing SWI-Prolog from SRC..${NC}."
if [ -n "$SWI_INSTALL_VERSION" ]; then
rm -rf swipl-devel
fi
install_swi_devel_deps || return 1
# Check if the SWI-Prolog source code directory exists
if [ -d "swipl-devel" ]; then
echo -e "${BLUE}SWI-Prolog source code directory exists. Pulling updates..${NC}."
cd swipl-devel && git pull && cd ..
else
echo -e "${BLUE}Cloning SWI-Prolog source code..${NC}."
git clone https://github.com/SWI-Prolog/swipl-devel.git
fi
if [ -n "$SWI_INSTALL_VERSION" ]; then
echo -e "${BLUE}Using ${SWI_INSTALL_VERSION} version of SWI-Prolog..${NC}."
cd swipl-devel && git checkout "$SWI_INSTALL_VERSION"
fi
# Update submodules
echo -e "${BLUE}Updating submodules..${NC}."
if [ -n "$SWI_INSTALL_VERSION" ]; then
echo -e "${BLUE}Special submodule update for ${SWI_INSTALL_VERSION} version of SWI-Prolog..${NC}."
git -C . submodule update --init packages/ltx2htm packages/pldoc packages/nlp packages/archive packages/clib packages/http packages/sgml packages/ssl packages/zlib
fi
cd swipl-devel && git submodule update --init && {
echo -e "${GREEN}Submodules updated successfully${NC}."
} || {
echo -e "${RED}Failed to update submodules. Exiting${NC}."
return 1
}
# Configure and build
echo -e "${BLUE}Configuring and building SWI-Prolog..${NC}."
if [ -n "$SWI_INSTALL_VERSION" ]; then
echo -e "${BLUE}Unsetting LD_PRELOAD to avoid interference during the build..${NC}."
unset LD_PRELOAD
fi
mkdir -p build && cd build
cmake .. && make && {
echo -e "${GREEN}SWI-Prolog configured and built successfully${NC}."
} || {
echo -e "${RED}Failed during SWI-Prolog build process. Exiting${NC}."
return 1
}
sudo make install && {
echo -e "${GREEN}SWI-Prolog installed successfully${NC}."
} || {
echo -e "${RED}Failed to install SWI-Prolog. Exiting${NC}."
return 1
}
}
function swipl_version () {
if ! command -v swipl &> /dev/null; then
echo "0.0"
else
echo $(swipl --version | awk '{print $3}')
fi
}
# Function to install or update SWI-Prolog
install_or_update_swipl() {
echo -e "${BLUE}Starting SWI-Prolog installation or update${NC}."
swi_prolog_version=$(swipl_version)
required_version="9.3.9"
if [ "$FORCE_REINSTALL_SWI" -eq 1 ]; then
echo -e "${YELLOW}Forcing rebuild of SWI-Prolog as --force was passed.${NC}"
install_swi || return 1
elif version_ge "$swi_prolog_version" "$required_version"; then
echo -e "${GREEN}SWI-Prolog version $swi_prolog_version is installed and meets the required version $required_version or higher${NC}."
else
echo -e "${YELLOW}Attempting to update SWI-Prolog..${NC}"
install_swi || return 1
swi_prolog_version=$(swipl_version)
if version_ge "$swi_prolog_version" "$required_version"; then
echo -e "${GREEN}SWI-Prolog upgraded to $swi_prolog_version, which meets the required version $required_version or higher${NC}."
else
echo -e "${RED}Failed to upgrade SWI-Prolog to version $required_version or higher.${NC}"
return 1
fi
fi
}
# Ask the user if EASY_INSTALL is still '?'
if [ "$EASY_INSTALL" == "?" ]; then
if confirm_with_default "Y" "Would you like to use easy installation mode?"; then
EASY_INSTALL="Y"
else
EASY_INSTALL="N"
fi
fi
if [[ ! -n "$UPDATE_SYSTEM" ]]; then
if [ -n "$ALLOW_MODIFY_SYSTEM" ] && [ "$ALLOW_MODIFY_SYSTEM" -eq 1 ]; then
UPDATE_SYSTEM=1
else
UPDATE_SYSTEM=0
fi
fi
# Define a function to print variables in bold and colorful format
print_var() {
local var_name=$1
local var_value=${!var_name:-"${RED} <Not Set> ${NC}"}
echo -e "${YELLOW}${var_name}${NC}=${BOLD}${BLUE}${var_value}${NC}"
}
# List of variables to print
vars_to_print=("INSTALL_TYPE" "FORCE_REINSTALL_SWI" "SWI_INSTALL" "EASY_INSTALL"
"PIP_BREAK_SYSTEM_PACKAGES"
"ALLOW_MODIFY_SYSTEM"
"UPDATE_SYSTEM"
"RPWD" "MeTTa" "METTALOG_DIR" "SWI_INSTALL_VERSION")
# Iterate over the list and print each variable
for var in "${vars_to_print[@]}"; do
print_var $var
done
echo -e "${BLUE}Starting the installation process.${NC}."
# ## Ensure pip and python3-venv are installed and upgraded
# This function ensures that python3-venv and pip are installed and ready for use.
ensure_venv_and_pip() {
# Check if Python is installed
if ! command -v python3 &> /dev/null; then
echo -e "${RED}Python3 is not installed. Please install Python3 to continue${NC}."
return 1 # Return because Python3 is required.
fi
# Check if python3-venv package is installed using dpkg
if ! dpkg-query -W -f='${Status}' python3-venv 2>/dev/null | grep -q "install ok installed"; then
echo -e "${YELLOW}Python venv package is not installed. Installing python3-venv...${NC}"
# Only allow system modifications if UPDATE_SYSTEM is set to 1
if [ "$UPDATE_SYSTEM" -eq 1 ]; then
sudo apt-get update
sudo apt-get install -y python3-venv
if [ $? -ne 0 ]; then
echo -e "${RED}Failed to install Python venv. Exiting${NC}."
return 1
else
echo -e "${GREEN}Python venv module installed successfully${NC}."
fi
else
echo -e "${RED}System modifications are not allowed. Cannot install python3-venv. Exiting${NC}."
return 1
fi
else
echo -e "${GREEN}python3-venv package is already installed${NC}."
fi
# Check if pip is installed
if ! command -v pip3 &> /dev/null; then
echo -e "${YELLOW}pip is not installed. Installing pip...${NC}"
# Only allow system modifications if UPDATE_SYSTEM is set to 1
if [ "$UPDATE_SYSTEM" -eq 1 ]; then
sudo apt-get update
sudo apt-get install -y python3-pip
if [ $? -ne 0 ]; then
echo -e "${RED}Failed to install pip. Exiting${NC}."
return 1
fi
else
echo -e "${RED}System modifications are not allowed. Cannot install pip. Exiting${NC}."
return 1
fi
else
echo -e "${GREEN}pip is already installed${NC}."
fi
return 0
}
# ## Ensure SWI-Prolog is installed and meets the required version
if ! command -v swipl &> /dev/null || ! swipl -g "use_module(library(janus)), halt(0)." -t "halt(1)" 2>/dev/null; then
if confirm_with_default "Y" "SWI-Prolog is not installed with Janus support. Would you like to install it?"; then
install_swi || return 1
else
echo -e "${RED}SWI-Prolog installation aborted. Exiting script${NC}."
return 1 # Return because the script is sourced.
fi
else
swi_prolog_version=$(swipl_version)
required_version="9.3.9"
if version_ge $swi_prolog_version $required_version; then
echo -e "${GREEN}SWI-Prolog version $swi_prolog_version is installed and meets the required version $required_version or higher${NC}."
if [ "$FORCE_REINSTALL_SWI" -eq 1 ]; then
echo -e "${YELLOW}Forcing update SWI-Prolog..${NC}."
install_or_update_swipl || return 1
swi_prolog_version=$(swipl_version)
if version_ge $swi_prolog_version $required_version; then
echo -e "${GREEN}SWI-Prolog upgraded to $swi_prolog_version, which meets the required version $required_version or higher${NC}."
else
echo -e "${YELLOW}Failed to upgrade SWI-Prolog to version $required_version or higher. Janus may not work without this version${NC}."
fi
fi
else
if confirm_with_default "Y" "SWI-Prolog is not version $required_version or higher. Would you like to update it?"; then
echo -e "${YELLOW}Attempting to update SWI-Prolog..${NC}."
install_or_update_swipl || return 1
swi_prolog_version=$(swipl_version)
if version_ge $swi_prolog_version $required_version; then
echo -e "${GREEN}SWI-Prolog upgraded to $swi_prolog_version, which meets the required version $required_version or higher${NC}."
else
echo -e "${YELLOW}Failed to upgrade SWI-Prolog to version $required_version or higher. Janus may not work without this version${NC}."
fi
fi
fi
fi
# Assuming SWI-Prolog X.X.X is installed successfully
# Install Janus Python support for SWI-Prolog
echo -e "${BLUE}Checking if Janus Python support is installed now..${NC}."
if ! swipl -g "use_module(library(janus)), halt(0)." -t "halt(1)" 2>/dev/null; then
# Janus not installed, prompt the user
if [ "${EASY_INSTALL}" == "Y" ] || confirm_with_default "Y" "Would you like to install Python (Janus) support?"; then
echo -e "${BLUE}Installing Janus for SWI-Prolog..${NC}."
ensure_venv_and_pip || return 1
pip install git+https://github.com/SWI-Prolog/packages-swipy.git
if [ $? -ne 0 ]; then
echo -e "${RED}Failed to install Janus. Exiting script${NC}."
return 1
else
echo -e "${GREEN}Janus installed successfully${NC}."
fi
else
echo -e "${YELLOW}Skipping Janus Python support installation${NC}."
fi
else
echo -e "${GREEN}Janus Python support is already installed${NC}."
fi
# Ensure venv and pip are installed, and exit if this fails
ensure_venv_and_pip || return 1
# Remove faulty virtual environment if it exists
if [ -d "$METTALOG_DIR/venv" ] && [ ! -f "$METTALOG_DIR/venv/bin/activate" ]; then
echo -e "${YELLOW}Detected a faulty virtual environment without an activate script, removing it...${NC}"
rm -rf "$METTALOG_DIR/venv"
fi
source ./scripts/ensure_venv
# Install PySWIP for Python-SWI-Prolog interface
echo -e "${BLUE}Checking if PySWIP is already installed..${NC}."
if false && ! python3 -c "import pyswip" &> /dev/null; then
if [ "${EASY_INSTALL}" == "Y" ] || confirm_with_default "Y" "Would you like to install PySWIP?"; then
echo -e "${BLUE}Installing PySWIP..${NC}."
ensure_venv_and_pip || return 1
pip install git+https://github.com/logicmoo/pyswip.git || return 1
echo -e "${GREEN}PySWIP installation complete${NC}."
else
echo -e "${YELLOW}Skipping PySWIP installation${NC}."
fi
else
echo -e "${GREEN}PySWIP is already installed${NC}."
fi
# Optional installation of predicate_streams and logicmoo_utils
if false && ! swipl -g "use_module(library(predicate_streams)), halt(0)." -t "halt(1)" 2>/dev/null; then
echo -e "${BLUE}Installing predicate_streams..${NC}."
echo -e "${YELLOW}${BOLD}If asked, say yes to everything and/or accept the defaults..${NC}."
(
if [ -d "reqs/predicate_streams" ]; then
echo -e "${BLUE}predicate_streams directory exists. Pulling updates..${NC}."
(cd reqs/predicate_streams && git pull)
else
mkdir -p reqs/ && cd reqs
git clone https://github.com/logicmoo/predicate_streams
cd ..
fi
) || swipl -g "pack_install(predicate_streams,[interactive(false)])" -t halt
else
echo -e "${GREEN}Pack predicate_streams is already installed${NC}."
fi
# Optional installation of logicmoo_utils
if false && ! swipl -g "use_module(library(logicmoo_utils)), halt(0)." -t "halt(1)" 2>/dev/null; then
echo -e "${BLUE}Installing logicmoo_utils..${NC}."
echo -e "${YELLOW}${BOLD}If asked, say yes to everything and/or accept the defaults..${NC}."
(
if [ -d "reqs/logicmoo_utils" ]; then
echo -e "${BLUE}logicmoo_utils directory exists. Pulling updates..${NC}."
(cd reqs/logicmoo_utils && git pull)
else
mkdir -p reqs/ && cd reqs
git clone https://github.com/TeamSPoon/logicmoo_utils
cd ..
fi
) || swipl -g "pack_install(logicmoo_utils,[interactive(false)])" -t halt
else
echo -e "${GREEN}Pack logicmoo_utils is already installed${NC}."
fi
# Environment file setup for MeTTaLog
env_file="${METTALOG_DIR}/scripts/envvars_mettalog.sh"
# Function to check if metalog is in the user's PATH and update environment variables
# Ensure MeTTaLog is sourced in .bashrc
check_metalog_in_path() {
# Add sourcing line to .bashrc if it's not already there
if ! grep -q "$env_file" "${HOME}/.bashrc"; then
echo ""
echo -e "${BLUE}MeTTaLog is not in your .bashrc${NC}."
echo "" >> "${HOME}/.bashrc"
echo "# Source MeTTaLog environment" >> "${HOME}/.bashrc"
echo "source \"$env_file\"" >> "${HOME}/.bashrc"
echo -e "${GREEN}MeTTaLog added to .bashrc${NC}."
else
echo -e "${GREEN}MeTTaLog was already in your .bashrc${NC}."
fi
source "$env_file"
print_var "METTALOG_DIR"
print_var "PYTHONPATH"
print_var "PATH"
}
# Call the function to check and update PATH
check_metalog_in_path
if [ -f ./scripts/lsp_server_prolog_install.sh ]; then
# Ensure the script is executable
chmod +x ./scripts/lsp_server_prolog_install.sh
# Call the lsp_server_prolog_install.sh script
( ./scripts/lsp_server_prolog_install.sh || /bin/true )
fi
echo -e "${GREEN}SWIPL executable is: ${NC}$(which swipl)"
echo -e "${GREEN}Installation and setup complete${NC}!"
# Optionally display README.md
if false && confirm_with_default "N" "Show README.md"; then
echo -en "${GREEN}"
cat README.md
echo -en "${NC}"
fi
# ## Final output and clean-up
# After the installation, return to the original working directory and print a success message.
cd "$RPWD" # Return to the original directory.
# End of the script
# ```