summaryrefslogtreecommitdiff
path: root/.ci/scripts (follow)
Commit message (Collapse)AuthorAgeFilesLines
* ci: android: Use signing key if availableGravatar Charles Lombardo2023-10-312-12/+9
| | | | Lets gradle handle apk signing when available
* Merge pull request #11689 from liamwhite/breakpadGravatar liamwhite2023-10-293-1/+2
|\ | | | | qt: implement automatic crash dump support
| * qt: implement automatic crash dump supportGravatar Liam2023-10-083-1/+2
| |
* | ci/linux: Fix find parameter orderGravatar toast29032023-10-101-1/+1
| | | | | | Co-authored-by: liamwhite <liamwhite@users.noreply.github.com>
* | ci/linux: Upload separated debug symbolsGravatar lat9nq2023-10-103-2/+20
|/ | | | | | | | | Creates a new archive with a debug suffix that contains the debug symbols from compiling yuzu for mainline. The yuzu executable also gets a GNU debug link to the symbols file. ci/linux: Compile with debug symbols and upload separately Currently only uploads for yuzu but yuzu-cmd or other future executables can be added to the for-loop's parameters.
* Merge pull request #11042 from lat9nq/wayland-appimageGravatar liamwhite2023-07-221-1/+1
|\ | | | | ci/linux: Target deploy script from appimage path
| * ci/linux: Target deploy script from appimage pathGravatar lat9nq2023-07-061-1/+1
| | | | | | | | | | Includes AppImage changes so that the needed Qt Wayland libraries are included.
* | ci/mingw: Remove pefile installation stepGravatar lat9nq2023-07-091-1/+0
| | | | | | | | | | This is unnecessary here: pefile is already installed on the container. This step also causes issues in coming changes to the container.
* | general: Update VulkanSDK and Vulkan-HeadersGravatar Morph2023-07-071-1/+1
| | | | | | | | Latest as of this commit
* | ci: Download and install Vulkan SDK directly from LunarGGravatar Morph2023-07-071-0/+33
|/
* android: Various fixes for CI.Gravatar bunnei2023-06-032-0/+6
|
* CI: add Android build systemsGravatar liushuyu2023-06-032-0/+36
|
* Fixup upload.ps1 for GHAGravatar Danila Malyutin2023-05-141-1/+5
| | | No extra folders are created with ninja generator after previous CMake fixes.
* Re-enable LTO for LinuxGravatar Matías Locatti2023-03-301-0/+1
| | | | | | Using the tested method of only enabling it for core and video_core. Clang is skipped, because Clang.
* general: fix spelling mistakesGravatar Liam2023-03-121-1/+1
|
* apply-patches-by-label: Remove unused variables and importsGravatar Morph2023-01-291-5/+2
|
* apply-patches-by-label: Use python f-stringsGravatar Morph2023-01-291-5/+5
|
* ci: Abort on failure to query Github's APIGravatar Morph2023-01-291-1/+2
| | | | | This raises an exception if the GET request to Github's API returns anything other than 200 OK, ensuring we always have successful merges of tagged PRs. Also, reduces the number of queried pages from 29 to 9 to reduce the number of requests.
* Move to Clang Format 15Gravatar Levi Behunin2023-01-291-1/+1
| | | | | | Depends on https://github.com/yuzu-emu/build-environments/pull/69 clang-15 primary run
* ci: Allow setting clang-format binaryGravatar Colin Kinloch2022-12-301-1/+1
|
* Enable compiler optimizations and enforce x86-64-v2 on GCC/Clang (#9442)Gravatar Matías Locatti2022-12-172-0/+2
| | | | | | | | | | | | | | | | | * Testing LTO (#4) * Testing LTO * clang * linux * Added the rest of Blinkhawk's optimizations * Unlikely asserts * Removing LTO from Linux builds - GCC * Removing LTO from Linux builds - Clang
* ci/clang: Enable bundled FFmpegGravatar lat9nq2022-12-011-0/+1
| | | | | Explicitly use the bundled FFmpeg version, since we were auto-choosing it before.
* Set TX_TOKEN for transifex clientGravatar Kyle Kienapfel2022-10-161-8/+0
| | | | | | | | | I did some tests on my own fork, and we're writing to ~/.transifexrc but the client can't seem to read that file. maybe issue with $HOME or something. Workaround is to set TX_TOKEN environment variable and now the pesky ~/.transifexrc file is not needed.
* Translations: new transifex clientGravatar Kyle Kienapfel2022-10-141-6/+2
| | | | | | | | | Currently we're using the python client which uses an API that they state will sunset Nov 30, 2022. `tx push -s` actually appears to work properly, some of the other commands require tweaking, like instead of suggesting `tx pull -a` in dist/languages we need to suggest `tx pull -t -a`
* ci/windows: Revert to using GCC for MinGW buildsGravatar lat9nq2022-10-091-5/+1
| | | | | | | | | Using MinGW in the future may not be ideal as it does not work very well with crash dumps (#8682). Switch back to GCC on MinGW. This also gives CI a way to check GCC 12 (as of writing, or whatever version of mingw-gcc Arch happens to be shipping on a given week).
* Migrate deploy-linux.sh from lat9nq's repo.Gravatar bunnei2022-10-011-1/+1
|
* ci/linux: Drop linuxdeploy usageGravatar lat9nq2022-09-261-5/+3
| | | | | | | | Recent versions of Docker appear to cause the Qt linuxdeploy plugin to throw a boost file copy error. This switches from linuxdeploy to a script of mine I've been working on for a while.
* ci/linux: Use AppRun.sh to start AppImageGravatar lat9nq2022-09-201-3/+3
| | | | | | | | | | The current AppRun is more difficult to update. This script still uses the old version of AppImageKit-checkrt, but now we use the shell script version so we can set our own environment variables as the application starts up. This specific version searches for and sets the correct root CA file to prevent SSL errors in yuzu.
* Merge pull request #8682 from lat9nq/dumpyGravatar Morph2022-09-162-2/+3
|\ | | | | yuzu qt: Add option to create Windows crash dumps
| * ci/windows: Upload debugging symbolsGravatar lat9nq2022-09-041-2/+2
| |
| * ci,workflows: Enable crash dumps on MSVC buildsGravatar lat9nq2022-09-041-0/+1
| | | | | | | | ci/windows: Enable crash dumps on MinGW builds
* | Merge pull request #6667 from lat9nq/ea-appimageGravatar Morph2022-09-161-6/+19
|\ \ | |/ |/| ci,linux: Support Patreon releases
| * ci/linux: EA AppImage adjustmentsGravatar lat9nq2022-07-311-1/+8
| | | | | | | | | | | | Prevent AppImageLauncher from trying to integrate our AppImage on end user systems. Don't include the basic yuzu executable with EA or Mainline.
| * ci,linux: Support Patreon releasesGravatar lat9nq2022-07-311-5/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The Early Access AppImage needs to be accessible through liftinstall, so a couple modifications need to made: The DIR_NAME needs to not include the revision info. The EA AppImage name cannot contain revision info. The EA AppImage has to be packaged with the rest of the yuzu package, which means both binaries and the source are bundled with it now in an archive. In addition, fix the source archive so yuzu can actually be built from it. upload: Copy AppImage to both mainline and EA release package
* | post-upload: Upload Linux source to artifacts dirGravatar lat9nq2022-08-091-0/+1
| | | | | | | | | | The source from the Linux build is desireable as it has permissions and line endings set correctly.
* | ci: Graft source when archivingGravatar lat9nq2022-08-092-8/+5
|/ | | | | | | Instead of including yuzu and all the sources it uses directly, include only what specifically belongs to yuzu. Submodules can be downloaded separately later using git since a shallow clone includes minimally all the repository information needed for it.
* Merge pull request #8642 from lat9nq/appimg-more-controlGravatar liamwhite2022-07-281-0/+3
|\ | | | | ci/linux: Exclude libwayland-client from AppImage
| * ci/linux: Delete libwayland-client from AppDirGravatar lat9nq2022-07-261-0/+3
| | | | | | | | | | This library causes issues in Vulkan driver detection. libQt5MultimediaGstTools's dependencies seem to be the issue.
* | Merge pull request #8641 from Docteh/vcpkg_dllGravatar liamwhite2022-07-271-3/+4
|\ \ | | | | | | build: Ship vcpkg dlls with MSVC pr-verify builds
| * | build: Ship vcpkg dlls with MSVC pr-verify buildsGravatar Kyle Kienapfel2022-07-261-3/+4
| |/ | | | | | | | | | | | | | | | | With our recent switchover from conan to vcpkg, we're shipping a few more dll files, these need to be in the full zip. cp .\build\bin\*.dll .\artifacts\ also tacking on the fix where we're shipping scm_rev.cpp accidentally
* / chore: make yuzu REUSE compliantGravatar Andrea Pappacoda2022-07-2721-3/+66
|/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | [REUSE] is a specification that aims at making file copyright information consistent, so that it can be both human and machine readable. It basically requires that all files have a header containing copyright and licensing information. When this isn't possible, like when dealing with binary assets, generated files or embedded third-party dependencies, it is permitted to insert copyright information in the `.reuse/dep5` file. Oh, and it also requires that all the licenses used in the project are present in the `LICENSES` folder, that's why the diff is so huge. This can be done automatically with `reuse download --all`. The `reuse` tool also contains a handy subcommand that analyzes the project and tells whether or not the project is (still) compliant, `reuse lint`. Following REUSE has a few advantages over the current approach: - Copyright information is easy to access for users / downstream - Files like `dist/license.md` do not need to exist anymore, as `.reuse/dep5` is used instead - `reuse lint` makes it easy to ensure that copyright information of files like binary assets / images is always accurate and up to date To add copyright information of files that didn't have it I looked up who committed what and when, for each file. As yuzu contributors do not have to sign a CLA or similar I couldn't assume that copyright ownership was of the "yuzu Emulator Project", so I used the name and/or email of the commit author instead. [REUSE]: https://reuse.software Follow-up to 01cf05bc75b1e47beb08937439f3ed9339e7b254
* Merge pull request #8629 from Docteh/test_transifexGravatar liamwhite2022-07-231-1/+4
|\ | | | | ci,transifex: enable vcpkg on transifex step
| * ci,transifex: enable vcpkg on transifex stepGravatar Kyle Kienapfel2022-07-231-1/+4
| | | | | | | | | | | | | | | | | | The slim docker container that runs transifex needs a few packages added in, curl zip unzip I've tested everything except actually pushing to transifex, but it's not November 2022 yet so we're fine for now. Or we're actually using the newer client and all is well.
* | Merge pull request #8625 from Docteh/ado_titlebarGravatar liamwhite2022-07-231-1/+6
|\ \ | | | | | | ci: pass environment variables to linux docker (AppImage)
| * | ci: pass environment variables to linux docker (AppImage)Gravatar Kyle K2022-07-221-1/+6
| |/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Variables in question: AZURECIREPO TITLEBARFORMATIDLE TITLEBARFORMATRUNNING DISPLAYVERSION CMakeModules/GenerateSCMRev.cmake has some logic that looks at BUILD_REPOSITORY variable inside CMake src/common/CMakeLists.txt has some logic that takes some items from environment variables and sets variables inside CMake This is the whole section at the moment. if (DEFINED ENV{AZURECIREPO}) set(BUILD_REPOSITORY $ENV{AZURECIREPO}) endif() if (DEFINED ENV{TITLEBARFORMATIDLE}) set(TITLE_BAR_FORMAT_IDLE $ENV{TITLEBARFORMATIDLE}) endif () if (DEFINED ENV{TITLEBARFORMATRUNNING}) set(TITLE_BAR_FORMAT_RUNNING $ENV{TITLEBARFORMATRUNNING}) endif () if (DEFINED ENV{DISPLAYVERSION}) set(DISPLAY_VERSION $ENV{DISPLAYVERSION}) endif ()
* | Merge pull request #8596 from Docteh/fix_ghaGravatar liamwhite2022-07-231-0/+47
|\ \ | | | | | | package MSVC CI Builds differently, and include yuzu.exe
| * | package MSVC CI Builds differently, and include yuzu.exeGravatar Kyle Kienapfel2022-07-231-0/+47
| |/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is related to 8486 Ninja places the exe files into .\build\bin while MSBuild may place them into .\build\bin\Release upload.ps1 was originally written for use with Azure Dev Ops to cough up about 5 files and the script appears to be used for both CI and mainline builds GHA (GitHub Actions) makes available a single zip of the items uploaded by each Upload action (artifacts directory), so we want to work with that. I'm doing changes to upload.ps1 to accomplish this. The changes to the verify.yml are as follows -DGIT_BRANCH=pr-verify changes the header in yuzu, instead of saying HEAD-<hash>-dirty it'll say pr-verify-<hash> -DCLANG_FORMAT_SUFFIX=discordplzdontclang tricks the CMake stuff for discord-rpc to NOT run clang-format, as this was marking CI builds as dirty I'm also making it upload just the exe by itself, as the msvc builds are quite chunky. but maybe this is unnecessary. Currently the MSVC artifact option is a 274MB zip that contains 3 copies of the DLLs, and 4 copies of the source tarball, and zero copies of yuzu.exe This PR should have msvc artifacts of about 190MB that downloads as 81 MB zip
* / ci/windows: Cleanup unused data before packagingGravatar lat9nq2022-07-231-0/+3
|/ | | | | vcpkg data takes up a lot of space, and currently the scripts will package all that data with the source archive which is unnecessary.
* ci,CMake: Integrate vcpkg into CMakeListsGravatar lat9nq2022-07-222-2/+0
| | | | Uses manifest mode if the bundled vcpkg is used.
* ci,CMake: Drop Conan support for vcpkgGravatar lat9nq2022-07-223-5/+14
| | | | | | | | | | | | | | | | | | Between packages breaking, Conan always being a moving target for minimum required CMake support, and now their moves to Conan 2.0 causing existing packages to break, I suppose this was a long time coming. vcpkg isn't without its drawbacks, but at the moment it seems easier on the project to use for external packages. Mostly removes the logic for Conan from the root CMakeLists file, leaving basic find_package()'s in its place. Sets only the find_package()'s that require CONFIG mode as necessary. clang and linux CI now use the vcpkg toolchain file configured in the Docker container when possible. mingw CI turns off YUZU_TESTS because there's no way on the container to run Windows executables on a Linux host anyway, and it's not easy to get Catch2 there.