Search Criteria
Package Details: ares-emu-git 141.r67.gb4b026db2-1
Package Actions
Git Clone URL: | https://aur.archlinux.org/ares-emu-git.git (read-only, click to copy) |
---|---|
Package Base: | ares-emu-git |
Description: | Cross-platform, open source, multi-system emulator by Near and Ares team, focusing on accuracy and preservation. (git version) |
Upstream URL: | https://ares-emu.net/ |
Licenses: | ISC |
Conflicts: | ares-emu |
Provides: | ares-emu |
Submitter: | Snowstorm64 |
Maintainer: | Snowstorm64 (SoullessSentinel) |
Last Packager: | Snowstorm64 |
Votes: | 4 |
Popularity: | 0.165525 |
First Submitted: | 2021-07-07 14:26 (UTC) |
Last Updated: | 2025-01-11 18:30 (UTC) |
Dependencies (27)
- alsa-lib
- cairo (cairo-gitAUR)
- gcc-libs (gcc-libs-gitAUR, gccrs-libs-gitAUR, gcc11-libsAUR, gcc-libs-snapshotAUR)
- gdk-pixbuf2 (gdk-pixbuf2-gitAUR)
- glib2 (glib2-gitAUR, glib2-selinuxAUR, glib2-patched-thumbnailerAUR)
- glibc (glibc-gitAUR, glibc-linux4AUR, glibc-eacAUR, glibc-eac-binAUR)
- gtk3 (gtk3-no_deadkeys_underlineAUR, gtk3-classicAUR, gtk3-classic-xfceAUR, gtk3-patched-filechooser-icon-viewAUR)
- hicolor-icon-theme (hicolor-icon-theme-gitAUR)
- libao (libao-gitAUR)
- libgl (libglvnd-gitAUR, amdgpu-pro-oglp-legacyAUR, amdgpu-pro-oglpAUR, nvidia-340xx-utilsAUR, libglvnd)
- libpulse (pulseaudio-dummyAUR, libpulse-gitAUR)
- librashaderAUR (librashaderAUR)
- libretro-shaders (libretro-shaders-all-gitAUR, libretro-shaders-slang-gitAUR, libretro-shaders-slang)
- libudev.so (systemd-chromiumos-libsAUR, libeudevAUR, systemd-libs-fmlAUR, lib32-systemd-gitAUR, systemd-libs-selinuxAUR, systemd-libs-gitAUR, lib32-systemd, systemd-libs)
- libx11 (libx11-gitAUR)
- libxrandr (libxrandr-gitAUR)
- openal (openal-gitAUR)
- pango (pango-gitAUR)
- sdl2 (sdl2-compat-gitAUR, sdl2-gitAUR)
- vulkan-driver (nvidia-410xx-utilsAUR, nvidia-440xx-utilsAUR, nvidia-430xx-utilsAUR, swiftshader-gitAUR, amdvlk-debugAUR, nvidia-vulkan-utilsAUR, amdvlk-2023q3.3AUR, amdvlk-2021q2.5AUR, amdvlk-gitAUR, vulkan-nouveau-gitAUR, mesa-minimal-gitAUR, vulkan-amdgpu-pro-legacyAUR, amdvlk-binAUR, mesa-wsl2-gitAUR, nvidia-535xx-utilsAUR, nvidia-470xx-utilsAUR, vulkan-radeon-amd-bc250AUR, nvidia-390xx-utilsAUR, nvidia-utils-teslaAUR, nvidia-utils-betaAUR, vulkan-amdgpu-proAUR, nvidia-510xx-utilsAUR, nvidia-525xx-utilsAUR, amdonly-gaming-vulkan-radeon-gitAUR, mesa-gitAUR, nvidia-550xx-utilsAUR, amdvlk, nvidia-utils, vulkan-intel, vulkan-nouveau, vulkan-radeon, vulkan-swrast, vulkan-virtio)
- vulkan-icd-loader (vulkan-icd-loader-gitAUR)
- zlib (zlib-ng-compat-gitAUR, zlib-gitAUR, zlib-ng-compat)
- cmake (cmake-gitAUR) (make)
- git (git-gitAUR, git-glAUR) (make)
- mesa (mesa-minimal-gitAUR, mesa-wsl2-gitAUR, mesa-amd-bc250AUR, amdonly-gaming-mesa-gitAUR, mesa-gitAUR, mesa-amber) (make)
- ninja (ninja-kitwareAUR, ninja-memAUR, ninja-fuchsia-gitAUR, ninja-gitAUR, ninja-jobserverAUR) (make)
- pkgconf (pkgconf-gitAUR) (make)
Latest Comments
1 2 3 Next › Last »
Snowstorm64 commented on 2025-01-03 17:11 (UTC) (edited on 2025-01-03 17:13 (UTC) by Snowstorm64)
Hi everyone, thanks for your response. However, I would like to make a few things clear:
While it's true that my intention is to stay aligned to the upstream but, now that the they adopted CMake, I couldn't see the reason anymore to not allow users some flexibility on how they build the package. Unfortunately it appears now that this isn't always possible, and I won't try to accomodate everyone at any cost.
The 'complicated additional options' has nothing to do with CMake's build type, but rather they were a workaround to an issue I have had with how CMake typically handles
CFLAGS
/CXXFLAGS
(they are only passed and stored once, at the configuration time). In any case I have already said I'll remove them soon, along withMAKEFLAGS
andccache
option, so that's the end of this discussion.I didn't see any issues with
RelWithDebInfo
which sets-O2
and not-O3
, this is what it counts. However I'll change it toNone
soon as recommended, but I should point out that it won't make much difference, as the aforementioned flag was already overrideable by CFLAGS/CXXFLAGS before. And then there's the fact that even withNone
it will still append a lot of other flags to the compiler, and these ones aren't overrideable per upstream's decision.Before anyone asks about building with gcc, there are some known issues that need to be resolved before I can lift off clang/lld requirements though they are the upstream project's recommended way.
xiota commented on 2025-01-02 15:35 (UTC) (edited on 2025-01-02 15:41 (UTC) by xiota)
TLDR: Set whatever build type you want, but get rid of the extraneous options.
Using None is not required, but recommended. That is why I say one should set it that way. The reason, described in the guideline, is that upstream projects generally modify build flags for the other build types, which can cause problems when users (devtools) set their own flags. The problems the maintainer appears to be trying to work around would likely be solved by setting build type to None, as recommended by the guidelines.
However, the maintainer may cite upstream intention as a reason to not use None. In that case, the extraneous options should still not be used because they override upstream intention.
FabioLolix commented on 2025-01-02 15:25 (UTC)
https://wiki.archlinux.org/title/CMake_package_guidelines
Snowstorm64 commented on 2025-01-02 15:22 (UTC) (edited on 2025-01-02 15:22 (UTC) by Snowstorm64)
Hi xiota, I have read about the CMake package guidelines. It seems that nowhere it's written that one must set
-D CMAKE_BUILD_TYPE=None
regardless, just that its use is recommended to avoid that unwanted -O3 optimization flag that would be set automatically withCMAKE_BUILD_TYPE=Release
. In this case, though, it's the build typeRelWithDebInfo
that is being used here and that it sets -O2 not -O3, this is what the upstream uses by default anyways. Don't you agree?However, I will simplify the PKGBUILD as per request, removing the options for
CFLAGS
and company (despite the reason stated before for putting them in first instance). I'll removeMAKEFLAGS
too, looks like it's impossible to make everyone happy...This applies the same toccache
too, at this point if one doesn't want to useccache
then this should be uninstalled, in any case it shouldn't be a problem for CMake.xiota commented on 2025-01-01 22:04 (UTC)
Since there appears to be confusion about appropriate cmake flags, see CMake package guidelines.
Practically, only the following, plus app specific flags, are needed in most cases:
CMake uses environment variables automatically. So redundant to set cmake-specific flags for
CC
,CXX
,CFLAGS
,CXXFLAGS
,LDFLAGS
, etc. Only change the ones that are really need. Also, don't try to extract specific flags fromMAKEFLAGS
, and don't try to changeccache
settings. They should "just work".CMAKE_BUILD_TYPE
should be set toNone
whenever possible. Not doing so may be the cause of whatever issues the maintainer is trying to work around.Snowstorm64 commented on 2025-01-01 21:19 (UTC)
Thank you, I have updated the PKGBUILD accordingly. It should be okay now. Should CFLAGS and other flags start to give issues, I'll take care of them too.
patlefort commented on 2025-01-01 14:09 (UTC) (edited on 2025-01-01 14:20 (UTC) by patlefort)
Ninja doesn't support all the possible MAKEFLAGS. For example, it will cause problem if I use gnu make job server that will fill MAKEFLAGS with stuff that ninja doesn't understand.
As for the flags, it doesn't hurt, however note that only full clean build is supported.
For ccache, DENABLE_CCACHE=OFF will turn off ccache use in their cmake files but will not prevent its use from makepkg.conf ccache option. That option simply add
/usr/lib/ccache/bin
to the PATH so any invocation of clang or gcc will use ccache transparently.EDIT: Removed part about NINJAFLAGS, it's not standard. You could still replace MAKEFLAGS with it though or maybe try parsing MAKEFLAGS for a -j option.
Snowstorm64 commented on 2025-01-01 13:19 (UTC)
Hi patlefort, thanks for your suggestions, though I have some questions first as I genuinely just want to understand:
-MAKEFLAGS, can you describe these issues with ninja, that I am not aware of? It has worked great for me, and I put it as a form of courtesy to whose people that don't appreciate the fact that ninja uses every core of the processor. The variable MAKEFLAGS gives them some form of control on the number of core to be used for building process.
-DCMAKE_C_FLAGS, DCMAKE_CXX_FLAGS and DCMAKE_EXE_LINKER_FLAGS, I agree that these variables are already inherited, though I have had some issues when rebuilding the package, specifically when I change some flags in CFLAGS in makepkg.conf for testing purposes but CMake for some reasons doesn't detect these changes. These CMake parameters apparently forces them, so I left them in place. What's the harm with leaving them in PKGBUILD if they don't cause issues?
-DENABLE_CCACHE=OFF, you're right about the forced use of ccache. I have looked at it, I have forgot that there's a variable controlling the use of ccache in makepkg.conf, so I'll remove ccache from makedepend. Though, isn't -DENABLE_CCACHE=OFF also kinda doing the same thing, but in the opposite way? Isn't it better to leave the choice to users?
patlefort commented on 2025-01-01 07:36 (UTC)
Patch for this package for proposed changes: https://pastebin.com/gjhV4f0L
I also added -DENABLE_CCACHE=OFF because we don't want to force use of ccache in pkgbuilds.
patlefort commented on 2024-12-31 23:46 (UTC)
Can you please remove $MAKEFLAGS statement? It's not useful and it even cause issues when ninja is used. Also, DCMAKE_C_FLAGS, DCMAKE_CXX_FLAGS and DCMAKE_EXE_LINKER_FLAGS will already inherit the env. vars. you are passing to them.
1 2 3 Next › Last »