Search Criteria
Package Details: stepmania 5.1.0.b2.r627.d55acb1ba2-4
Package Actions
Git Clone URL: | https://aur.archlinux.org/stepmania.git (read-only, click to copy) |
---|---|
Package Base: | stepmania |
Description: | Advanced rhythm game. Designed for both home and arcade use. |
Upstream URL: | http://www.stepmania.com/ |
Keywords: | arcade game |
Licenses: | MIT AND CC-BY-NC-4.0 |
Submitter: | Nascher |
Maintainer: | neeshy (snailman153624) |
Last Packager: | neeshy |
Votes: | 29 |
Popularity: | 0.153640 |
First Submitted: | 2015-08-12 13:57 (UTC) |
Last Updated: | 2024-12-16 03:18 (UTC) |
Dependencies (24)
- alsa-lib
- ffmpeg (ffmpeg-nvcodec-11-1-gitAUR, ffmpeg-cudaAUR, ffmpeg-decklinkAUR, ffmpeg-amd-fullAUR, ffmpeg-ffplayoutAUR, ffmpeg-gitAUR, ffmpeg-amd-full-gitAUR, ffmpeg-fullAUR, ffmpeg-full-gitAUR, ffmpeg-libfdk_aacAUR, ffmpeg-headlessAUR, ffmpeg-obsAUR)
- glew (glew-libepoxyAUR, glew-waylandAUR, glew-osmesa-gitAUR, glew-wayland-gitAUR, glew-gitAUR)
- glu (glu-gitAUR)
- gtk3 (gtk3-no_deadkeys_underlineAUR, gtk3-classicAUR, gtk3-classic-xfceAUR, gtk3-patched-filechooser-icon-viewAUR)
- jsoncpp (jsoncpp-cmake-gitAUR, jsoncpp-cmakeAUR, jsoncpp-gitAUR)
- libjpeg (mozjpeg-gitAUR, libjpeg-turbo-gitAUR, mozjpegAUR, libjpeg-turbo)
- libmad
- libogg (libogg-gitAUR)
- libpng (libpng-gitAUR, libpng-apngAUR)
- libpulse (pulseaudio-dummyAUR, libpulse-gitAUR)
- libtomcrypt (libtomcrypt-gitAUR)
- libtommath
- libvorbis (libvorbis-aotuvAUR, libvorbis-aotuv-lancerAUR, libvorbis-gitAUR)
- libx11 (libx11-gitAUR)
- libxext (libxext-gitAUR)
- libxinerama (libxinerama-randr-gitAUR)
- libxrandr (libxrandr-gitAUR)
- libxtst
- mesa (mesa-minimal-gitAUR, mesa-wsl2-gitAUR, mesa-amd-bc250AUR, amdonly-gaming-mesa-gitAUR, mesa-gitAUR, mesa-amber)
- Show 4 more dependencies...
Required by (1)
Sources (6)
- ffmpeg-7.patch
- ffmpeg-remove-asm-requirement.patch
- https://github.com/stepmania/stepmania/archive/d55acb1ba26f1c5b5e3048d6d6c0bd116625216f.tar.gz
- https://github.com/stepmania/stepmania/commit/3fef5ef60b7674d6431f4e1e4ba8c69b0c21c023.patch
- https://github.com/stepmania/stepmania/commit/e0d2a5182dcd855e181fffa086273460c553c7ff.patch
- stepmania.sh
Latest Comments
1 2 3 4 5 6 7 Next › Last »
kqr commented on 2024-12-15 01:59 (UTC)
snailman153624 commented on 2024-12-05 12:25 (UTC)
OK, I incorporated all of my comments below regarding building with FFMpeg 2.1.3 into the PKGBUILD; I'll leave the comments for reference, but the latest snapshot should be all fixed up.
snailman153624 commented on 2024-12-04 05:14 (UTC)
So, to build/link against FFMpeg 2.1.3, create the two patch files from the comments below, e.g.:
Edit the indicated portions of PKGBUILD to something like this (the asm requirement patch is not wrong...it won't do anything impactful in this config anyway):
...likewise, enable building with the bundled FFMpeg:
If you are doing this on your own, you of course have to download/extract the package (don't build it yet), then make the modifications, then perform a build without clean/re-extraction (or it will overwrite your changes).
Also, I'm guessing the above will require you to run the build 2x (I didn't try this from a clean download after I got it working...I ran the build numerous times as I hand-patched files), because the ffmpeg-2.1.3 is not handled as a normal dependency for the package, but rather in a nested CMake file during the actual build process, not during extraction (thus, the ffmpeg patches will have nothing to apply to on the first attempt...as prepare()/patches are run before build()).. This is an area where the Stepmania and AUR build processes overlap/conflict slightly in terms of who's responsible for what. You could either patch the FFMpeg CMake to apply the patches, or perhaps move the download/extraction of ffmpeg-2.1.3 up to the PKGBUILD.
snailman153624 commented on 2024-12-04 04:59 (UTC)
I ran into some issues with Stepmania crashing since the package was updated to use the system FFMpeg. It compiles and runs, but crashes when attempting to play a song that has a video file present (which is when FFMpeg would get invoked at runtime). This is a long standing issue with Stepmania (the volatility of the FFMpeg version dependence), and hence why it can be built against a specific version of FFMpeg (which is also statically linked).
In order to get the original/intended version of FFMpeg (2.1.3) to compile on a modern system, I had to patch several files, as modern compilers are more strict in their detection and enforcement of various things (some of these may be legit bugs in FFMpeg, but it only needs to work for the intended use case here).
For starters, none of the current patches in the PKGBUILD are applicable to an FFMpeg 2.1.3 build, as all of them are [attempted] workarounds to get it to compile with FFMpeg 4+. If you want to keep it robust to both configurations, you could add some #ifdef's in there (ideally in the prepare()), but I just commented them out.
Next, the mathops.h patch that's detailed in one of my comments from 2024-01-27 is still needed.
Additionally, several .c and .h files needed patches, mainly to force some otherwise invalid pointer type conversions. I combined these into a single patch file:
snailman153624 commented on 2024-01-28 05:53 (UTC) (edited on 2024-01-28 05:57 (UTC) by snailman153624)
Here's the mathops.h patch contents:
snailman153624 commented on 2024-01-28 05:46 (UTC) (edited on 2024-01-28 06:03 (UTC) by snailman153624)
I had to patch a few files to make it build, as follows:
1. git to https suggestion below (tweaked) resolved the long pause followed by error (due to fail/timeout of ffmpeg retrieval)...I added the following to prepare() in the PKGBUILD:
2. Error regarding "tm" having incomplete type is due to a missing include to <ctime>...I patched it with sed in prepare() also, but more properly this would be done with a patch file...
3. I got some invalid arg to some asm code in ffmpeg...the version of ffmpeg used is really old. I tried flipping the flag in the PKGBUILD to use my native ffmpeg, but this ran into other compile and link issues (due to API changes in the newer version). After some digging, invalid opcodes were used in the asm for x86 in mathops.h...I found the patch and it matched this header file exactly, resolving this issue. I simply put the relevant portion of the patchfile in a file I created called "mathops.patch" in a subdirectory "my_patches" in the package folder (not in src, as this will get wiped when makepkg extracts), and added it prepare():
My resultant prepare() looks like this (incorporating all of the above):
After all of this, the makepkg -s, followed by makepkg install worked, and stepmania runs! Been using it with Wii/Gamecube DDR mats, coupled with a USB Gamecube->USB adapter I got for $7.
griffin commented on 2022-11-28 21:41 (UTC)
Also getting the ffmpeg git failure error.
whynothugo commented on 2022-10-04 00:00 (UTC)
Builds fine for me in a clean chroot.
Heterology commented on 2022-09-27 06:29 (UTC)
Gah, another error now. I'll run a full system update and see what's going on.
1 2 3 4 5 6 7 Next › Last »