gimx: unstable-2021-08-31 -> 8.0 (#336754)

Co-authored-by: Sandro <sandro.jaeckel@gmail.com>

bb2020 cea14594 b3bbb652

Changed files
+42 -169
pkgs
+2 -2
pkgs/games/gimx/conf.patch
···
snprintf(file_path, sizeof(file_path), "%s%s%s%s", gimx_params.homedir, GIMX_DIR, CONFIG_DIR, file);
-
-
+ if(getenv("GIMXCONF")) { snprintf(file_path, sizeof(file_path), "%s", file); }
+
+ snprintf(file_path, sizeof(file_path), "%s", file);
if(read_file(file_path) == -1)
{
gerror("read_file failed\n");
···
snprintf(file_path, sizeof(file_path), "%s%s%s%s", gimx_params.homedir, GIMX_DIR, CONFIG_DIR, gimx_params.config_file);
-
-
+ if(getenv("GIMXCONF")) { snprintf(file_path, sizeof(file_path), "%s", gimx_params.config_file); }
+
+ snprintf(file_path, sizeof(file_path), "%s", gimx_params.config_file);
FILE * fp = gfile_fopen(file_path, "r");
if (fp == NULL)
{
-104
pkgs/games/gimx/custom/Dualshock4.xml
···
-
<?xml version="1.0" encoding="UTF-8"?>
-
<root>
-
<controller id="1" dpi="0" type="DS4">
-
<configuration id="1">
-
<trigger type="" id="" name="" button_id="" switch_back="no" delay="0"/>
-
<mouse_options_list/>
-
<intensity_list/>
-
<button_map>
-
<button id="abs_axis_10" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="3"/>
-
</button>
-
<button id="abs_axis_9" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="0"/>
-
</button>
-
<button id="abs_axis_8" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="1"/>
-
</button>
-
<button id="abs_axis_7" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="2"/>
-
</button>
-
<button id="abs_axis_11" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="4"/>
-
</button>
-
<button id="abs_axis_12" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="5"/>
-
</button>
-
<button id="abs_axis_0" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="8"/>
-
</button>
-
<button id="abs_axis_1" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="9"/>
-
</button>
-
<button id="abs_axis_15" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="11"/>
-
</button>
-
<button id="abs_axis_16" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="12"/>
-
</button>
-
<button id="abs_axis_2" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="10"/>
-
</button>
-
<button id="abs_axis_3" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="13"/>
-
</button>
-
<button id="abs_axis_4" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="14"/>
-
</button>
-
<button id="abs_axis_5" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="15"/>
-
</button>
-
<button id="abs_axis_6" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="button" id="16"/>
-
</button>
-
</button_map>
-
<axis_map>
-
<axis id="rel_axis_0" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="axis" id="0" dead_zone="0" multiplier="0.004" exponent="1.00" shape=""/>
-
</axis>
-
<axis id="rel_axis_1" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="axis" id="1" dead_zone="0" multiplier="0.004" exponent="1.00" shape=""/>
-
</axis>
-
<axis id="rel_axis_2" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="axis" id="3" dead_zone="0" multiplier="0.004" exponent="1.00" shape=""/>
-
</axis>
-
<axis id="rel_axis_3" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="axis" id="4" dead_zone="0" multiplier="0.004" exponent="1.00" shape=""/>
-
</axis>
-
<axis id="abs_axis_13" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="axis" id="2" dead_zone="0" multiplier="0.008" exponent="1.00" shape=""/>
-
</axis>
-
<axis id="abs_axis_14" label="">
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<event type="axis" id="5" dead_zone="0" multiplier="0.008" exponent="1.00" shape=""/>
-
</axis>
-
</axis_map>
-
<joystick_corrections_list/>
-
<force_feedback>
-
<device type="joystick" id="0" name="Sony Computer Entertainment Wireless Controller"/>
-
<inversion enable="no"/>
-
<gain rumble="0" constant="0" spring="0" damper="0"/>
-
</force_feedback>
-
</configuration>
-
</controller>
-
</root>
+14 -63
pkgs/games/gimx/default.nix
···
-
{ stdenv, lib, fetchFromGitHub, fetchpatch
-
, makeWrapper, curl, libusb1, xorg, libxml2
-
, ncurses5, bluez, libmhash, gimxPdpGamepad ? false }:
+
{ stdenv, lib, fetchFromGitHub, makeWrapper, curl, libusb1, bluez, libxml2, ncurses5, libmhash, xorg }:
let
gimx-config = fetchFromGitHub {
owner = "matlo";
repo = "GIMX-configurations";
rev = "c20300f24d32651d369e2b27614b62f4b856e4a0";
-
sha256 = "02wcjk8da188x7y0jf3p0arjdh9zbb0lla3fxdb28b1xyybfvx5p";
+
hash = "sha256-t/Ttlvc9LCRW624oSsFaP8EmswJ3OAn86QgF1dCUjAs=";
};
in stdenv.mkDerivation rec {
pname = "gimx";
-
version = "unstable-2021-08-31";
+
version = "8.0";
src = fetchFromGitHub {
owner = "matlo";
repo = "GIMX";
-
rev = "58d2098dce75ed4c90ae649460d3a7a150f4ef0a";
+
rev = "v${version}";
fetchSubmodules = true;
-
sha256 = "05kdv2qqr311c2p76hdlgvrq7b04vcpps5c80zn8b8l7p831ilgz";
+
hash = "sha256-BcFLdQgEAi6Sxyb5/P9YAIkmeXNZXrKcOa/6g817xQg=";
};
-
patches = [
-
./conf.patch
-
-
# gcc-13 build fixes:
-
# https://github.com/matlo/GIMX/pull/705
-
(fetchpatch {
-
name = "gcc-13-headers.patch";
-
url = "https://github.com/matlo/GIMX/commit/4525dff4d9af672116d8c6c182707f2ad6295b2d.patch";
-
hash = "sha256-LkswnFsxqADooa09yO7Yf0AbxTrGfjBObyv/6FQJvRs=";
-
})
-
(fetchpatch {
-
name = "gcc-13-protos.patch";
-
url = "https://github.com/matlo/GIMX/commit/f11855fcb8bd9d0cb9c94871b4111ddfd5b610df.patch";
-
hash = "sha256-JL67UUsEyPcOuaimJtMviiGLGghuq9665Lg1QuiaWUU=";
-
})
-
];
+
env.NIX_CFLAGS_COMPILE = "-Wno-error";
+
patches = [ ./conf.patch ./gcc14.patch ];
nativeBuildInputs = [ makeWrapper ];
-
buildInputs = [
-
curl libusb1 bluez libxml2 ncurses5 libmhash
-
xorg.libX11 xorg.libXi xorg.libXext
-
];
-
-
postPatch = lib.optionals gimxPdpGamepad ''
-
substituteInPlace ./shared/gimxcontroller/include/x360.h \
-
--replace "0x045e" "0x0e6f" --replace "0x028e" "0x0213"
-
substituteInPlace ./loader/firmware/EMU360.hex \
-
--replace "1B210001" "1B211001" \
-
--replace "09210001" "09211001" \
-
--replace "5E048E021001" "6F0E13020001"
-
'';
-
+
buildInputs = [ curl libusb1 bluez libxml2 ncurses5 libmhash xorg.libX11 xorg.libXi ];
makeFlags = [ "build-core" ];
-
env.NIX_CFLAGS_COMPILE = toString [
-
# Needed with GCC 12
-
"-Wno-error=address"
-
"-Wno-error=deprecated-declarations"
-
"-Wno-error=use-after-free"
-
];
-
installPhase = ''
runHook preInstall
mkdir -p $out
-
substituteInPlace ./core/Makefile --replace "chmod ug+s" "echo"
-
+
substituteInPlace ./core/Makefile --replace-fail "chmod ug+s" "echo"
export DESTDIR="$out"
make install-shared install-core
mv $out/usr/lib $out/lib
mv $out/usr/bin $out/bin
-
rmdir $out/usr
-
-
runHook postInstall
-
'';
+
cp -r ${gimx-config}/Linux $out/share
-
postInstall = ''
-
mkdir -p $out/share
-
cp -r ./loader/firmware $out/share/firmware
-
cp -r ${gimx-config}/Linux $out/share/config
-
cp -r ${./custom} $out/share/custom
+
makeWrapper $out/bin/gimx $out/bin/gimx-ds4 \
+
--add-flags "--nograb" --add-flags "-p /dev/ttyUSB0" \
+
--add-flags "-c $out/share/Dualshock4.xml"
-
makeWrapper $out/bin/gimx $out/bin/gimx-dualshock4 \
-
--set GIMXCONF 1 --add-flags "--nograb" --add-flags "-p /dev/ttyUSB0" \
-
--add-flags "-c $out/share/custom/Dualshock4.xml"
-
-
makeWrapper $out/bin/gimx $out/bin/gimx-xboxonepad \
-
--set GIMXCONF 1 --add-flags "--nograb" --add-flags "-p /dev/ttyUSB0" \
-
--add-flags "-c $out/share/config/XOnePadUsb.xml"
+
runHook postInstall
'';
meta = with lib; {
···
description = "Game Input Multiplexer";
license = licenses.gpl3Only;
platforms = platforms.linux;
-
maintainers = with maintainers; [ bb2020 ];
};
}
+26
pkgs/games/gimx/gcc14.patch
···
+
diff --git a/core/config_reader.c b/core/config_reader.c
+
index 451fc48..737d27c 100644
+
--- a/core/config_reader.c
+
+++ b/core/config_reader.c
+
@@ -17,7 +17,7 @@
+
#include "../directories.h"
+
#include "macros.h"
+
#include <errno.h>
+
-
+
+#include <stdlib.h>
+
/*
+
* These variables are used to read the configuration.
+
*/
+
diff --git a/core/gimx.c b/core/gimx.c
+
index 700cae9..693f72f 100755
+
--- a/core/gimx.c
+
+++ b/core/gimx.c
+
@@ -8,7 +8,7 @@
+
#include <errno.h> //to print errors
+
#include <string.h> //to print errors
+
#include <limits.h> //PATH_MAX
+
-
+
+#include <stdlib.h>
+
#ifndef WIN32
+
#include <termios.h> //to disable/enable echo
+
#include <unistd.h>