Merge pull request #295652 from TomaSajt/portablemc
portablemc: init at 4.3.0
This commit is contained in:
commit
5c3d3708e1
2 changed files with 144 additions and 0 deletions
97
pkgs/by-name/po/portablemc/package.nix
Normal file
97
pkgs/by-name/po/portablemc/package.nix
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
{
|
||||||
|
lib,
|
||||||
|
stdenv,
|
||||||
|
python3Packages,
|
||||||
|
fetchFromGitHub,
|
||||||
|
installShellFiles,
|
||||||
|
jre,
|
||||||
|
|
||||||
|
libX11,
|
||||||
|
libXext,
|
||||||
|
libXcursor,
|
||||||
|
libXrandr,
|
||||||
|
libXxf86vm,
|
||||||
|
libpulseaudio,
|
||||||
|
libGL,
|
||||||
|
glfw,
|
||||||
|
openal,
|
||||||
|
udev,
|
||||||
|
|
||||||
|
textToSpeechSupport ? stdenv.isLinux,
|
||||||
|
flite,
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
# Copied from the `prismlauncher` package
|
||||||
|
runtimeLibs = [
|
||||||
|
libX11
|
||||||
|
libXext
|
||||||
|
libXcursor
|
||||||
|
libXrandr
|
||||||
|
libXxf86vm
|
||||||
|
|
||||||
|
# lwjgl
|
||||||
|
libpulseaudio
|
||||||
|
libGL
|
||||||
|
glfw
|
||||||
|
openal
|
||||||
|
stdenv.cc.cc.lib
|
||||||
|
|
||||||
|
# oshi
|
||||||
|
udev
|
||||||
|
] ++ lib.optional textToSpeechSupport flite;
|
||||||
|
in
|
||||||
|
python3Packages.buildPythonApplication rec {
|
||||||
|
pname = "portablemc";
|
||||||
|
version = "4.3.0";
|
||||||
|
pyproject = true;
|
||||||
|
|
||||||
|
disabled = python3Packages.pythonOlder "3.8";
|
||||||
|
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "mindstorm38";
|
||||||
|
repo = "portablemc";
|
||||||
|
rev = "v${version}";
|
||||||
|
hash = "sha256-jCv4ncXUWbkWlBZr3P1hNeVpdQzY9HtrFz+pmKknL0I=";
|
||||||
|
};
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
# Use the jre package provided by nixpkgs by default
|
||||||
|
./use-builtin-java.patch
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeBuildInputs = [ installShellFiles ];
|
||||||
|
|
||||||
|
build-system = [ python3Packages.poetry-core ];
|
||||||
|
|
||||||
|
dependencies = [ python3Packages.certifi ];
|
||||||
|
|
||||||
|
# Note: Tests use networking, so we don't run them
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
installShellCompletion --cmd portablemc \
|
||||||
|
--bash <($out/bin/portablemc show completion bash) \
|
||||||
|
--zsh <($out/bin/portablemc show completion zsh)
|
||||||
|
'';
|
||||||
|
|
||||||
|
preFixup = ''
|
||||||
|
makeWrapperArgs+=(
|
||||||
|
--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath runtimeLibs}
|
||||||
|
--prefix PATH : ${lib.makeBinPath [ jre ]}
|
||||||
|
)
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
homepage = "https://github.com/mindstorm38/portablemc";
|
||||||
|
description = "A fast, reliable and cross-platform command-line Minecraft launcher and API for developers";
|
||||||
|
longDescription = ''
|
||||||
|
A fast, reliable and cross-platform command-line Minecraft launcher and API for developers.
|
||||||
|
Including fast and easy installation of common mod loaders such as Fabric, Forge, NeoForge and Quilt.
|
||||||
|
This launcher is compatible with the standard Minecraft directories.
|
||||||
|
'';
|
||||||
|
changelog = "https://github.com/mindstorm38/portablemc/releases/tag/${src.rev}";
|
||||||
|
license = lib.licenses.gpl3Only;
|
||||||
|
mainProgram = "portablemc";
|
||||||
|
maintainers = with lib.maintainers; [ tomasajt ];
|
||||||
|
};
|
||||||
|
}
|
47
pkgs/by-name/po/portablemc/use-builtin-java.patch
Normal file
47
pkgs/by-name/po/portablemc/use-builtin-java.patch
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
diff --git a/portablemc/standard.py b/portablemc/standard.py
|
||||||
|
index f59c55d..0f017e1 100644
|
||||||
|
--- a/portablemc/standard.py
|
||||||
|
+++ b/portablemc/standard.py
|
||||||
|
@@ -843,6 +843,8 @@ class Version:
|
||||||
|
if jvm_major_version is not None and not isinstance(jvm_major_version, int):
|
||||||
|
raise ValueError("metadata: /javaVersion/majorVersion must be an integer")
|
||||||
|
|
||||||
|
+ return self._resolve_builtin_jvm(watcher, JvmNotFoundError.UNSUPPORTED_ARCH, jvm_major_version)
|
||||||
|
+
|
||||||
|
if platform.system() == "Linux" and platform.libc_ver()[0] != "glibc":
|
||||||
|
return self._resolve_builtin_jvm(watcher, JvmNotFoundError.UNSUPPORTED_LIBC, jvm_major_version)
|
||||||
|
|
||||||
|
@@ -926,31 +928,10 @@ class Version:
|
||||||
|
builtin_path = shutil.which(jvm_bin_filename)
|
||||||
|
if builtin_path is None:
|
||||||
|
raise JvmNotFoundError(reason)
|
||||||
|
-
|
||||||
|
- try:
|
||||||
|
-
|
||||||
|
- # Get version of the JVM.
|
||||||
|
- process = Popen([builtin_path, "-version"], bufsize=1, stdout=PIPE, stderr=STDOUT, universal_newlines=True)
|
||||||
|
- stdout, _stderr = process.communicate(timeout=1)
|
||||||
|
-
|
||||||
|
- version_start = stdout.index(f"1.{major_version}" if major_version <= 8 else str(major_version))
|
||||||
|
- version = None
|
||||||
|
-
|
||||||
|
- # Parse version by getting all character that are numeric or '.'.
|
||||||
|
- for i, ch in enumerate(stdout[version_start:]):
|
||||||
|
- if not ch.isnumeric() and ch not in (".", "_"):
|
||||||
|
- version = stdout[version_start:i]
|
||||||
|
- break
|
||||||
|
-
|
||||||
|
- if version is None:
|
||||||
|
- raise ValueError()
|
||||||
|
-
|
||||||
|
- except (TimeoutExpired, ValueError):
|
||||||
|
- raise JvmNotFoundError(JvmNotFoundError.BUILTIN_INVALID_VERSION)
|
||||||
|
|
||||||
|
self._jvm_path = Path(builtin_path)
|
||||||
|
- self._jvm_version = version
|
||||||
|
- watcher.handle(JvmLoadedEvent(version, JvmLoadedEvent.BUILTIN))
|
||||||
|
+ self._jvm_version = "nixpkgs"
|
||||||
|
+ watcher.handle(JvmLoadedEvent("nixpkgs", JvmLoadedEvent.BUILTIN))
|
||||||
|
|
||||||
|
def _download(self, watcher: Watcher) -> None:
|
||||||
|
|
Loading…
Reference in a new issue