mirror of
				https://github.com/factoriotools/factorio-docker.git
				synced 2025-10-22 21:59:09 +02:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			master
			...
			fix-arm64-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 17ec12cb7f | ||
|  | b8ad6e06ab | 
| @@ -53,10 +53,9 @@ fi | |||||||
| # In rootless mode, we don't need to handle user switching or chown | # In rootless mode, we don't need to handle user switching or chown | ||||||
| # The container runs as the specified user from the start | # The container runs as the specified user from the start | ||||||
| EXEC="" | EXEC="" | ||||||
| if [[ -f /bin/box64 ]]; then | # Setup ARM64 emulation support | ||||||
|   # Use emulator for ARM hosts | # shellcheck disable=SC1091 | ||||||
|   EXEC="/bin/box64" | source "${INSTALLED_DIRECTORY}/setup-exec.sh" | ||||||
| fi |  | ||||||
|  |  | ||||||
| # Update config path | # Update config path | ||||||
| sed -i '/write-data=/c\write-data=\/factorio/' /opt/factorio/config/config.ini | sed -i '/write-data=/c\write-data=\/factorio/' /opt/factorio/config/config.ini | ||||||
|   | |||||||
| @@ -41,10 +41,10 @@ if [[ $NRTMPSAVES -gt 0 ]]; then | |||||||
| fi | fi | ||||||
|  |  | ||||||
| if [[ ${UPDATE_MODS_ON_START:-} == "true" ]]; then | if [[ ${UPDATE_MODS_ON_START:-} == "true" ]]; then | ||||||
|   ${INSTALLED_DIRECTORY}/docker-update-mods.sh |   "${INSTALLED_DIRECTORY}"/docker-update-mods.sh | ||||||
| fi | fi | ||||||
|  |  | ||||||
| ${INSTALLED_DIRECTORY}/docker-dlc.sh | "${INSTALLED_DIRECTORY}"/docker-dlc.sh | ||||||
|  |  | ||||||
| EXEC="" | EXEC="" | ||||||
| if [[ $(id -u) == 0 ]]; then | if [[ $(id -u) == 0 ]]; then | ||||||
| @@ -56,11 +56,10 @@ if [[ $(id -u) == 0 ]]; then | |||||||
|   # Drop to the factorio user |   # Drop to the factorio user | ||||||
|   EXEC="runuser -u factorio -g factorio --" |   EXEC="runuser -u factorio -g factorio --" | ||||||
| fi | fi | ||||||
| if [[ -f /bin/box64 ]]; then |  | ||||||
|   # Use an emulator to run on ARM hosts | # Setup ARM64 emulation support | ||||||
|   # this only gets installed when the target docker platform is linux/arm64 | # shellcheck disable=SC1091 | ||||||
|   EXEC="$EXEC /bin/box64" | source "${INSTALLED_DIRECTORY}/setup-exec.sh" | ||||||
| fi |  | ||||||
|  |  | ||||||
| sed -i '/write-data=/c\write-data=\/factorio/' /opt/factorio/config/config.ini | sed -i '/write-data=/c\write-data=\/factorio/' /opt/factorio/config/config.ini | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| #!/bin/bash | #!/bin/bash | ||||||
| set -eoux pipefail | set -eoux pipefail | ||||||
|  | INSTALLED_DIRECTORY=$(dirname "$(readlink -f "${BASH_SOURCE[0]}")") | ||||||
|  |  | ||||||
| if [[ -z ${1:-} ]]; then | if [[ -z ${1:-} ]]; then | ||||||
|   echo "No argument supplied" |   echo "No argument supplied" | ||||||
| @@ -31,7 +32,12 @@ if [[ ! -f $CONFIG/map-settings.json ]]; then | |||||||
|   cp /opt/factorio/data/map-settings.example.json "$CONFIG/map-settings.json" |   cp /opt/factorio/data/map-settings.example.json "$CONFIG/map-settings.json" | ||||||
| fi | fi | ||||||
|  |  | ||||||
| exec /opt/factorio/bin/x64/factorio \ | # Setup ARM64 emulation support | ||||||
|  | EXEC="" | ||||||
|  | # shellcheck disable=SC1091 | ||||||
|  | source "${INSTALLED_DIRECTORY}/setup-exec.sh" | ||||||
|  |  | ||||||
|  | exec $EXEC /opt/factorio/bin/x64/factorio \ | ||||||
|   --port "$PORT" \ |   --port "$PORT" \ | ||||||
|   --start-server-load-scenario "$SERVER_SCENARIO" \ |   --start-server-load-scenario "$SERVER_SCENARIO" \ | ||||||
|   --preset "$PRESET" \ |   --preset "$PRESET" \ | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| #!/bin/bash | #!/bin/bash | ||||||
| set -eoux pipefail | set -eoux pipefail | ||||||
|  | INSTALLED_DIRECTORY=$(dirname "$(readlink -f "${BASH_SOURCE[0]}")") | ||||||
|  |  | ||||||
| if [[ -z ${1:-} ]]; then | if [[ -z ${1:-} ]]; then | ||||||
|   echo "No argument supplied" |   echo "No argument supplied" | ||||||
| @@ -23,5 +24,10 @@ if [[ ! -f $CONFIG/map-settings.json ]]; then | |||||||
|   cp /opt/factorio/data/map-settings.example.json "$CONFIG/map-settings.json" |   cp /opt/factorio/data/map-settings.example.json "$CONFIG/map-settings.json" | ||||||
| fi | fi | ||||||
|  |  | ||||||
| exec /opt/factorio/bin/x64/factorio \ | # Setup ARM64 emulation support | ||||||
|  | EXEC="" | ||||||
|  | # shellcheck disable=SC1091 | ||||||
|  | source "${INSTALLED_DIRECTORY}/setup-exec.sh" | ||||||
|  |  | ||||||
|  | exec $EXEC /opt/factorio/bin/x64/factorio \ | ||||||
|   --scenario2map "$SERVER_SCENARIO" |   --scenario2map "$SERVER_SCENARIO" | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								docker/files/setup-exec.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								docker/files/setup-exec.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | #!/bin/bash | ||||||
|  | # Setup EXEC variable for running Factorio with ARM64 emulation support | ||||||
|  | # This script handles ARM64 emulation and can be combined with user switching as needed | ||||||
|  |  | ||||||
|  | # If EXEC is not already set, initialize it | ||||||
|  | if [[ -z "${EXEC:-}" ]]; then | ||||||
|  |   EXEC="" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | if [[ -f /bin/box64 ]]; then | ||||||
|  |   # Use an emulator to run on ARM hosts | ||||||
|  |   # this only gets installed when the target docker platform is linux/arm64 | ||||||
|  |   EXEC="$EXEC /bin/box64" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | export EXEC | ||||||
		Reference in New Issue
	
	Block a user