aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/project (unfollow)
Commit message (Collapse)Author
2021-01-18project.ci: add GitHub ActionsEgor Tensin
2021-01-18project.ci: --install picks the directory automaticallyEgor Tensin
2021-01-18project.cmake: create the build dir if necessaryEgor Tensin
2021-01-17README: updateEgor Tensin
2021-01-17README: updateEgor Tensin
2021-01-17fix PyLint warningsEgor Tensin
2021-01-17GIANT CLUSTERFUCK OF A COMMITEgor Tensin
OK, this is epic. I was basically just trying to a) support Clang and b) add more test coverage. _THREE MONTHS_ and a few hundred CI runs later, this is what I came up with. I don't know how it ended up being what it is, but here we go. Some highlights of the changes: 1) CI builds has been moved to GitHub Actions, 2) the entire notion of a toolchain has been reworked; it now supports Clang on all platforms. * .github: this directory contains the GitHub Actions workflow scripts/actions. In the process, I created like 6 external GitHub actions, but it's still pretty massive. An upside is that it covers much more platform/toolchain combinations _and_ check a lot of the expected post-conditions. TODO: .ci/Makefile is obsolete now, as well as .travis.yml and .appveyor.yml. * common.cmake: added Clang support. In the process, a great deal has been learned about how CMake works; in particular, static runtime support has been reworked to be more robust. * project: the entire notion of a "toolchain" has been reworked. Instead of a measly --mingw parameter, there's now a separate --toolset parameter, which allows you to choose between GCC, Clang, MSVC, etc. Both Boost and CMake build scripts were enhanced greatly to support Clang and other toolchains in a more robust way.
2020-10-18README: elaborateEgor Tensin
2020-10-04fix build dir path on Travis/AppVeyorEgor Tensin
I.e. it used to be just C:\projects instead of C:\projects\build on AppVeyor.
2020-04-04project.boost.download: add dest_dir parameterEgor Tensin
2020-04-04project.boost.download: --unpack = --cache if specifiedEgor Tensin
2020-03-31project.boost: retry downloadsEgor Tensin
2020-03-30project.cmake: support --mingw for Travis/AppVeyorEgor Tensin
2020-03-30project.ci: dedupe codeEgor Tensin
2020-03-30project.cmake: make it --boost awareEgor Tensin
2020-03-30project.boost.build: switch to --layout=systemEgor Tensin
2020-03-30project.cmake: make it --platform awareEgor Tensin
2020-03-30project.cmake.build: refactoringEgor Tensin
2020-03-30project: code styleEgor Tensin
2020-03-30project.boost: support --mingw for Travis/AppVeyorEgor Tensin
2020-03-30project.build.build: more restrictive defaultsEgor Tensin
2020-03-30project: minor-ish refactoringEgor Tensin
2020-03-29project.boost: first-class MinGW-w64 supportEgor Tensin
2020-03-29project: add os.pyEgor Tensin
2020-03-29fix READMEs, code style, etc.Egor Tensin
2020-03-29project.boost: -d0 by defaultEgor Tensin
2020-03-29project.cmake: insignificant refactoringEgor Tensin
2020-03-29project.cmake: factor out common utilsEgor Tensin
2020-03-28project.boost: factor out everything elseEgor Tensin
I finally snapped. This starts to resemble sensible structure though.
2020-03-28project.boost: factor out BoostVersionEgor Tensin
2020-03-28project.boost: factor out Configuration/Platform/LinkageEgor Tensin
2020-03-28WIP: restructureEgor Tensin
A stupid attempt to reduce code duplication led me to believe that all the scripts could use _a bit_ of refactoring. This is going to be a major pain (factoring out all the things), which I'll take gladly. All the links and usage examples are broken right now, but nobody cares, so whatevs.