Merge pull request #145391 from bb2020/gimx
This commit is contained in:
commit
5bea0fab63
6 changed files with 150 additions and 59 deletions
26
pkgs/games/gimx/conf.patch
Normal file
26
pkgs/games/gimx/conf.patch
Normal file
|
@ -0,0 +1,26 @@
|
|||
diff --git a/core/config_reader.c b/core/config_reader.c
|
||||
index 451fc48..ed45f4d 100644
|
||||
--- a/core/config_reader.c
|
||||
+++ b/core/config_reader.c
|
||||
@@ -1355,7 +1355,7 @@ int read_config_file(const char* file)
|
||||
char file_path[PATH_MAX];
|
||||
|
||||
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); }
|
||||
if(read_file(file_path) == -1)
|
||||
{
|
||||
gerror("read_file failed\n");
|
||||
diff --git a/core/gimx.c b/core/gimx.c
|
||||
index 700cae9..9143d8b 100755
|
||||
--- a/core/gimx.c
|
||||
+++ b/core/gimx.c
|
||||
@@ -192,7 +192,7 @@ void show_config()
|
||||
char file_path[PATH_MAX];
|
||||
|
||||
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); }
|
||||
FILE * fp = gfile_fopen(file_path, "r");
|
||||
if (fp == NULL)
|
||||
{
|
104
pkgs/games/gimx/custom/Dualshock4.xml
Normal file
104
pkgs/games/gimx/custom/Dualshock4.xml
Normal file
|
@ -0,0 +1,104 @@
|
|||
<?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>
|
|
@ -1,5 +1,5 @@
|
|||
{ stdenv, lib, fetchFromGitHub, makeWrapper, curl, libusb1, xorg, libxml2
|
||||
, ncurses5, bluez, libmhash, gimxAuth ? "" }:
|
||||
, ncurses5, bluez, libmhash, gimxPDP ? false }:
|
||||
|
||||
let
|
||||
gimx-config = fetchFromGitHub {
|
||||
|
@ -21,15 +21,21 @@ in stdenv.mkDerivation rec {
|
|||
sha256 = "0265gg6q7ymg76fb4pjrfdwjd280b3zzry96qy92w0h411slph85";
|
||||
};
|
||||
|
||||
patches = [ ./conf.patch ];
|
||||
nativeBuildInputs = [ makeWrapper ];
|
||||
buildInputs = [
|
||||
curl libusb1 bluez libxml2 ncurses5 libmhash
|
||||
xorg.libX11 xorg.libXi xorg.libXext
|
||||
];
|
||||
|
||||
patches = [ ./env.patch ];
|
||||
prePatch = (if gimxAuth == "afterglow" then (import ./variant.nix).afterglow
|
||||
else "");
|
||||
postPatch = lib.optionals gimxPDP ''
|
||||
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"
|
||||
'';
|
||||
|
||||
makeFlags = "build-core";
|
||||
installPhase = ''
|
||||
|
@ -51,19 +57,19 @@ in stdenv.mkDerivation rec {
|
|||
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-with-confs \
|
||||
--set GIMXCONF $out/share/config
|
||||
makeWrapper $out/bin/gimx $out/bin/gimx-dualshock4 \
|
||||
--set GIMXCONF 1 --add-flags "--nograb" --add-flags "-p /dev/ttyUSB0" \
|
||||
--add-flags "-c $out/share/config/Dualshock4.xml"
|
||||
|
||||
makeWrapper $out/bin/gimx $out/bin/gimx-test-ds4 \
|
||||
--set GIMXCONF $out/share/config \
|
||||
--add-flags "--nograb" --add-flags "--curses" \
|
||||
--add-flags "-p /dev/ttyUSB0" --add-flags "-c Dualshock4.xml"
|
||||
makeWrapper $out/bin/gimx $out/bin/gimx-dualshock4-noff \
|
||||
--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-test-xone \
|
||||
--set GIMXCONF $out/share/config \
|
||||
--add-flags "--nograb" --add-flags "--curses" \
|
||||
--add-flags "-p /dev/ttyUSB0" --add-flags "-c XOnePadUsb.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"
|
||||
'';
|
||||
|
||||
meta = with lib; {
|
||||
|
|
|
@ -1,30 +0,0 @@
|
|||
--- a/core/config_reader.c
|
||||
+++ b/core/config_reader.c
|
||||
@@ -1353,8 +1353,10 @@ static int read_file(char* file_path)
|
||||
int read_config_file(const char* file)
|
||||
{
|
||||
char file_path[PATH_MAX];
|
||||
-
|
||||
- snprintf(file_path, sizeof(file_path), "%s%s%s%s", gimx_params.homedir, GIMX_DIR, CONFIG_DIR, file);
|
||||
+ char* e = getenv("GIMXCONF"); if (e) { snprintf(file_path, sizeof(file_path), "%s/%s", e, file); }
|
||||
+ else {
|
||||
+ snprintf(file_path, sizeof(file_path), "%s%s%s%s", gimx_params.homedir, GIMX_DIR, CONFIG_DIR, file);
|
||||
+ }
|
||||
|
||||
if(read_file(file_path) == -1)
|
||||
{
|
||||
--- a/core/gimx.c
|
||||
+++ b/core/gimx.c
|
||||
@@ -190,8 +190,10 @@ void show_config()
|
||||
}
|
||||
|
||||
char file_path[PATH_MAX];
|
||||
-
|
||||
- snprintf(file_path, sizeof(file_path), "%s%s%s%s", gimx_params.homedir, GIMX_DIR, CONFIG_DIR, gimx_params.config_file);
|
||||
+ char* e = getenv("GIMXCONF"); if (e) { snprintf(file_path, sizeof(file_path), "%s/%s", e, gimx_params.config_file); }
|
||||
+ else {
|
||||
+ snprintf(file_path, sizeof(file_path), "%s%s%s%s", gimx_params.homedir, GIMX_DIR, CONFIG_DIR, gimx_params.config_file);
|
||||
+ }
|
||||
|
||||
FILE * fp = gfile_fopen(file_path, "r");
|
||||
if (fp == NULL)
|
|
@ -1,14 +0,0 @@
|
|||
{
|
||||
afterglow = ''
|
||||
substituteInPlace ./shared/gimxcontroller/include/x360.h \
|
||||
--replace "0x045e" "0x0e6f" --replace "0x028e" "0x0213"
|
||||
|
||||
HEX="./loader/firmware/EMU360.hex"
|
||||
sed -i '34s|1B2100|1B2110|' "$HEX"
|
||||
sed -i '38s|092100|092110|' "$HEX"
|
||||
sed -i '40s|5E048E021001|6F0E13020001|' "$HEX"
|
||||
sed -i '34s|1C\r|0C\r|' "$HEX"
|
||||
sed -i '38s|FE\r|EE\r|' "$HEX"
|
||||
sed -i '40s|6D\r|DD\r|' "$HEX"
|
||||
'';
|
||||
}
|
|
@ -30176,7 +30176,6 @@ with pkgs;
|
|||
gemrb = callPackage ../games/gemrb { };
|
||||
|
||||
gimx = callPackage ../games/gimx {};
|
||||
gimx-afterglow = lowPrio (gimx.override { gimxAuth = "afterglow"; });
|
||||
|
||||
gl117 = callPackage ../games/gl-117 {};
|
||||
|
||||
|
|
Loading…
Reference in a new issue