Skip to content

Commit

Permalink
[PORT] Updates Node bootstrapping to v20 (#2360)
Browse files Browse the repository at this point in the history
* Creates a node compatibility mode (#82334)

## About The Pull Request
By default this will install node v20 LTS, but if a user is detected to
be using win 7 it's node v14

This lets us run higher node versions (with presumably more stable and
performant content) while allowing win 7 users to play

I should note that this is making clean tgui builds run at ~6.7sec which
is about a 6.9% speed increase (nice) from the previous #80310
## Why It's Good For The Game
Better tools
## Changelog
N/A nothing player facing

* Compiling the servers works again (#82420)

"Compat" node version didn't work at all

* Reimplements node compatibility mode (#83141)

## About The Pull Request
Puts a switch inside our build tools that will download the appropriate
node version based on your OS.

#82334

## Why It's Good For The Game
Closes #83076
Allows players to play the game

* Node Bootstrap: Cast OS version to int so compat code works (#83190)

This wasn't working for me because `OSMajor` was set to a string, not a
number, so it failed the if check.

Making this change made it work

---------

Co-authored-by: Jeremiah <[email protected]>
Co-authored-by: Zephyr <[email protected]>
Co-authored-by: Kyle Spier-Swenson <[email protected]>
  • Loading branch information
4 people authored Jun 26, 2024
1 parent 960f561 commit e1e86c4
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 7 deletions.
5 changes: 3 additions & 2 deletions dependencies.sh
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,9 @@ export BYOND_MINOR=1637
export RUST_G_VERSION=3.1.0

#node version
export NODE_VERSION=14
export NODE_VERSION_PRECISE=14.16.1
export NODE_VERSION_LTS=20.13.0
# compatiblility mode MUST work with windows 7
export NODE_VERSION_COMPAT=20.2.0

# SpacemanDMM git tag
export SPACEMAN_DMM_VERSION=suite-1.8
Expand Down
1 change: 1 addition & 0 deletions tgui/.prettierignore
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
/yarn.lock
/.pnp.*

.swcrc
/docs
/public
/packages/tgui-polyfill
Expand Down
4 changes: 2 additions & 2 deletions tools/bootstrap/node
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,9 @@ if [ "$TG_BOOTSTRAP_CACHE" ]; then
fi
OldPWD="$PWD"
cd "$Bootstrap/../.."
. ./dependencies.sh # sets NODE_VERSION_PRECISE
. ./dependencies.sh # sets NODE_VERSION_LTS
cd "$OldPWD"
NodeVersion="$NODE_VERSION_PRECISE"
NodeVersion="$NODE_VERSION_LTS"
NodeFullVersion="node-v$NodeVersion-win-x64"
NodeDir="$Cache/$NodeFullVersion"
NodeExe="$NodeDir/node.exe"
Expand Down
14 changes: 13 additions & 1 deletion tools/bootstrap/node_.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,19 @@ $Cache = "$BaseDir\.cache"
if ($Env:TG_BOOTSTRAP_CACHE) {
$Cache = $Env:TG_BOOTSTRAP_CACHE
}
$NodeVersion = Extract-Variable -Path "$BaseDir\..\..\dependencies.sh" -Key "NODE_VERSION_PRECISE"

# Get OS version
[int]$OSMajor = (Get-WmiObject -Class Win32_OperatingSystem).Version.Split(".")[0]

# Set Node version based on OS version
if ($OSMajor -lt 10) {
# Anything under Windows 10
$NodeVersion = Extract-Variable -Path "$BaseDir\..\..\dependencies.sh" -Key "NODE_VERSION_COMPAT"
}
else {
$NodeVersion = Extract-Variable -Path "$BaseDir\..\..\dependencies.sh" -Key "NODE_VERSION_LTS"
}

$NodeSource = "https://nodejs.org/download/release/v$NodeVersion/win-x64/node.exe"
$NodeTargetDir = "$Cache\node-v$NodeVersion-x64"
$NodeTarget = "$NodeTargetDir\node.exe"
Expand Down
4 changes: 2 additions & 2 deletions tools/ci/install_node.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,6 @@ source dependencies.sh

if [[ -e ~/.nvm/nvm.sh ]]; then
source ~/.nvm/nvm.sh
nvm install $NODE_VERSION
nvm use $NODE_VERSION
nvm install $NODE_VERSION_COMPAT
nvm use $NODE_VERSION_COMPAT
fi

0 comments on commit e1e86c4

Please sign in to comment.