-
Notifications
You must be signed in to change notification settings - Fork 3.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add Ninja build system to Mac, Linux and Windows #514
Comments
Added to Issue: Area for Triage: Packages |
@alepauly , Tool can be installed in runtime using the following commands:
Installation takes about 10 seconds |
Hi @Toxe, thanks for your suggestion but considering that it' easy to add Ninja to workflows on demand, we won't add it to the image just yet. |
That's a bummer. And I honestly don't really get it, because out of all CI solutions I have tried over the last weeks the Github Actions VMs seem to be the best equipped and up-to-date installations with (nearly) everything one would need. And if there are the newest compiler versions (among several other versions) and tools like GNU Make and CMake installed out-of-the-box I really don't get why a tiny tool like Ninja (that, like CMake, is becoming the defacto standard for a lot of people) does not get included. In most of my CI scripts Ninja is pretty much the only thing I need to install by hand and then I am good to go. If it were available by default this would shave of a couple of seconds of runtime and would run Github Actions scripts even faster than they already do. Yeah, sorry, as I said I don't really get it. But okay, it's your system and not the end of the world, obviously I can cope with it without a problem. But, would have been nice. |
@Toxe thanks for your thoughts. We are trying to improve on a few things about the images for virtual environments including the reliability of building the images themselves, the effort to keep them up to date, the disk foot print, and others. This means that we are being fairly picky right now about what to install by default and since there's an easy workaround for Ninja, it seems like we can avoid installing it. One alternative I can suggest is to have a We are happy to revisit this in the future as we improve on the things I mentioned, feel free to ping me whenever to remind. Thanks again for speaking up. |
Thank you for explaining your thoughts on this. |
4 years later, please re-open and re-consider this.
Understandable, but: For cross-platform C/C++ there are only 3 build systems in widespread use:
So not having ninja installed by default means you don't care much about C/C++? Besides running doxygen, there is basically nothing that can be done with C/C++ unless you build it. Even static analyzers usually work by intercepting the ninja build as their first step. In fact even doxygen is often implemented as a CMake target for convenience.
It is indeed super weird to have CMake installed by default without its most popular and only cross-platform backend. Very inconsistent. Moreover, CMake is quite complex and adding new features regularly which means the CMake version available by default is not always the version you want. Rarely ever any such compatibility issue with the so much simpler ninja.
ninja is by explicit design an extremely simple tool, delegating all the complexity to the front end: https://ninja-build.org/manual.html#_design_goals No "reliability" issue here.
As ninja is every simple, it extremely rarely needs to be updated (Unlike for instance: CMake)
ninja is very small.
Other important considerations: CPU and bandwidth...
Pre-installing ninja would save more than just a couple seconds because by design you must run @maxim-lobanov, @alepauly please take a quick look at which package is most frequently installed at run-time across all C/C++ projects. I bet you have those stats internally because they translate to CPU cycles and bandwidth = money.
19 seconds on Windows: https://github.com/thesofproject/sof/actions/runs/7689520973/job/20952092062 Worse: on Windows ninja ... comes and goes! #741 ~19 seconds on Ubuntu: I have never tried To build CMake projects on Ubuntu, a workaround is to use CMake+GNU Make. This can save the time to |
Yet another year later...
Still no recommended way to install ninja on Windows... Could you at least maintain an official GitHub Action hosted at https://github.com/actions that installs ninja? This would avoid guarding "install" code with OS-specific conditionals or auditing the security of 3rd party actions that already do this (like #741 (comment)).
An official, install-ninja action would:
|
Right, with each passing year I understand this less and less. Ninja is one of the most popular build tools for good reasons and also tiny. It improves build times by a lot and not having to install it manually would also reduce VM runtime. But clearly resource costs and therefore saving money does not seem to matter here. 🤔 |
I just asked runtime installation to be officially documented, please upvote: Ever growing list of duplicates: |
The biggest issue is with Windows. Unless Ninja is installed using the Visual Studio Installer there are build packages that are written for languages like Python that will not be able to properly detect it. Here is an MSVC build system that integrates into setuptools and distutils for Python. It allows for compiling not only Python extension modules but also compiling executables as well at static and dynamic libraries. One of the things is does is it uses COM objects that are apart of the Visual Studio installer to locate various bits and pieces that are installed. The COM objects when I wrote the code were undocumented. My point is if it is not installed using the Visual Studio installer then anything that uses some kind of a build system may not be able to locate it. There are a lot of build systems that use vswhere and that uses the same COM objects as the system I wrote. It doesn't make any sense that ninja is not installed by default. Just like it doesn't make sense that arm compilers are not installed either. |
Yes, especially, and I cannot stress this enough, that we are talking about a tool that is tiny (0.5 MB on Windows). |
When you start adding up all of the people that are having to install it manually and the resources that end up being wasted from having to do so, tied to the cost of bandwidth.. from a monetary standpoint it really doesn't make any sense as to why it's not already installed. It looks like at one point in time it was at least with Windows. What really throws me for a loop with the Windows images is Visual Studio is installed.. Why? Not like anyone is using the IDE portions of it in the CI... only the build tools need to be installed and Microsoft does have a package that has only the build tools and not the entire IDE. Talk about a waste there, Visual studio is a pretty large piece of software. |
Interesting, can you share some references? (I'm not familiar with Windows) Just trying to play devil's advocate: maybe this lighter package is rarely used, poorly tested and has some subtle differences with the "real" thing that everyone uses? That would not surprise me considering ninja already "came and went" even when sticking to the same Microsoft package! #741 (comment) All toolchains are notoriously brittle, not just on Windows far from it. |
It installs all of the exact same pieces that get installed when you install the IDE except it doesn't install the IDE. https://visualstudio.microsoft.com/visual-cpp-build-tools/ The installer that is used for the build tools is the same installer as Visual Studio, it just has the IDE bits left out. |
Toolchains are brittle because they change things from version to version. Important things like location, environment variable names. Things like that. With Windows it is actually worse because people that develop applications don't clean up the registry entries that are made when something gets updated or uninstalled. This leaves a bunch of invalid entries in the registry. Microsoft is the most guilty of doing this. The undocumented COM objects were added in Visual Studio 2017 and that makes it easier to know what is actually installed and what is not. It doesn't give all of the information needed to set up a proper build environment though. You still need to go into the registry to collect location paths and things of that nature. The MSVC build script I wrote in Python supports locating installations of Visual Studio, Visual C++ and the build tools. all the way back to versions released in 2008. It detects Windows SDK installations back to version 6.0A (Windows 7) along with ALL .NET versions. it detects HTML Help, F#, and a plethora of other compilers that get installed with VS, VC++ or the build tools including Clang and Ninja. It also detects Nmake and CMake as well. It sets up a factory MSVC build environment that works 100% of the time. It took me years to iron all the bugs out of it due to Microsoft having zero consistency up until VS 2017 with where things are stored in both the registry and also the file system. |
That is what a CI is supposed to solve by having commonly used tools pre installed. |
Tool information
Area for Triage: Packages
Question, Bug, or Feature?: Feature
Virtual environments affected
Can this tool be installed during the build?
Yes. See: https://github.com/ninja-build/ninja/wiki/Pre-built-Ninja-packages
Here is an example how I am using it in my own project:
https://github.com/Toxe/example-cpp-ci-project/blob/master/.github/workflows/ci.yml
brew install ninja
sudo apt-get install ninja-build
Are you willing to submit a PR?
I might, but I am no expert about Actions/Environments and the manual installation is pretty simple anyways, so I suppose it would be pretty fast and easy to do for someone who actually know what they are doing.
The text was updated successfully, but these errors were encountered: