-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathconfiguration.md
807 lines (565 loc) · 21.8 KB
/
configuration.md
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
# Configuration
Scikit-build-core supports a powerful unified configuration system. Every option
in scikit-build-core can be specified in one of three ways: as a
`pyproject.toml` option (preferred if static), as a config-settings options
(preferred if dynamic), or as an environment variable. Note that config-settings
options can optionally be prefixed with `skbuild.`, for example
`-C skbuild.logging.level=INFO`.
(verbosity)=
## Verbosity
You can increase the verbosity of the build with two settings - `build.verbose`
is a shortcut for verbose build output, and `logging.level` controls
scikit-build-core's internal logging. An example (with all configuration styles)
of setting both is:
````{tab} pyproject.toml
```toml
[tool.scikit-build]
cmake.verbose = true
logging.level = "INFO"
```
````
`````{tab} config-settings
````{tab} pip
```console
$ pip install . -v --config-settings=cmake.verbose=true --config-settings=logging.level=INFO
```
````
````{tab} build
```console
$ pipx run build --wheel -Ccmake.verbose=true -Clogging.level=INFO
```
````
````{tab} cibuildwheel
```toml
[tool.cibuildwheel.config-settings]
"cmake.verbose" = true
"logging.level" = "INFO"
```
````
`````
````{tab} Environment
```yaml
SKBUILD_CMAKE_VERBOSE: true
SKBUILD_LOGGING_LEVEL: "INFO"
```
````
:::{note}
When using `pip`, make sure you include at least a `-v` argument so that the
verbosity settings above are displayed.
:::
:::{warning}
In general, the environment variable method is intended as an emergency
workaround for legacy tooling.
:::
:::{versionchanged} 0.10
`cmake.verbose` was renamed to `build.verbose`.
:::
## Minimum version & defaults
Scikit-build-core, like CMake, has a special minimum required version setting.
If you set this, you get two benefits. First, if the version is less than this
version, you get a nice error message. But, more importantly, if
scikit-build-core is a newer version than the version set here, it will select
older defaults to help ensure your package can continue to build, even if a
default value changes in the future. This should help reduce the chance of ever
needed an upper cap on the scikit-build-core version, as upper caps are
discouraged.
It is recommended you set this value as high as you feel comfortable with, and
probably keep in sync with your build-system requirements.
```toml
[tool.scikit-build]
minimum-version = "0.2"
```
In your `pyproject.toml`, you can specify the special string
`"build-system.requires"`, which will read the minimum version from your
build-system requirements directly; you must specify a minimum there to use this
automatic feature.
```toml
[build-system]
requires = ["scikit-build-core>=0.10"]
[tool.scikit-build]
minimum-version = "build-system.requires"
```
:::{versionchanged} 0.10
The `"build-system.requires"` option was added.
:::
:::{warning}
The following behaviors are affected by `minimum-version`:
- `minimum-version` 0.5+ (or unset) provides the original name in metadata and
properly normalized SDist names.
- `minimum-version` 0.5+ (or unset) strips binaries by default.
- `minimum-version` 0.8+ (or unset) `cmake.minimum-version` and
`ninja.minimum-version` are replaced with `cmake.version` and `ninja.version`.
- `minimum-version` 0.10+ (or unset) `cmake.targets` and
`cmake.verbose` are replaced with `build.targets` and `build.verbose`. The
CMake minimum version will be detected if not given.
:::
## CMake and Ninja minimum versions
You can select a different minimum version for CMake and Ninja.
Scikit-build-core will automatically decide to download a wheel for these (if
possible) when the system version is less than this value.
For example, to require a recent CMake and Ninja:
```toml
[tool.scikit-build]
cmake.version = ">=3.26.1"
ninja.version = ">=1.11"
```
You can try to read the version from your CMakeLists.txt with the special
string `"CMakeLists.txt"`. This is an error if the minimum version was not
statically detectable in the file. If your `minimum-version` setting is unset
or set to "0.10" or higher, scikit-build-core will still try to read this if
possible, and will fall back on ">=3.15" if it can't read it.
You can also enforce ninja to be required even if make is present on Unix:
```toml
[tool.scikit-build]
ninja.make-fallback = false
```
You can also control the FindPython backport; by default, a backport of CMake
3.26.1's FindPython will be used if the CMake version is less than 3.26.1; you
can turn this down if you'd like ("3.15", scikit-build-core's minimum version,
would turn it off).
```toml
[tool.scikit-build]
backport.find-python = "3.15"
```
```{versionadded} 0.8
These used to be called `cmake.minimum-version` and `ninja.minimum-version`, and
only took a single value. Now they are full specifier sets, allowing for more
complex version requirements, like `>=3.15,!=3.18.0`.
```
## Configuring source file inclusion
Scikit-build-core defaults to using your `.gitignore` to select what to exclude
from the source distribution. You can list files to explicitly include and
exclude if you want:
```toml
[tool.scikit-build]
sdist.include = ["src/some_generated_file.txt"]
sdist.exclude = [".github"]
```
By default, scikit-build-core will respect `SOURCE_DATE_EPOCH`, and will lock
the modification time to a reproducible value if it's not set. You can disable
reproducible builds if you prefer, however:
```toml
[tool.scikit-build]
sdist.reproducible = false
```
You can also request CMake to run during this step:
```toml
[tool.scikit-build]
sdist.cmake = true
```
:::{note}
If you do this, you'll want to have some artifact from the configure in your
source directory; for example:
```cmake
include(FetchContent)
set(PYBIND11_FINDPYTHON ON)
if(NOT SKBUILD_STATE STREQUAL "sdist"
AND EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/pybind11/CMakeLists.txt")
message(STATUS "Using integrated pybind11")
add_subdirectory(pybind11)
else()
FetchContent_Declare(
pybind11
GIT_REPOSITORY https://github.com/pybind/pybind11.git
GIT_TAG v2.12.0
SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/pybind11)
FetchContent_MakeAvailable(pybind11)
endif()
```
The `/pybind11` directory is in the `.gitignore` and important parts are in
`sdist.include`:
```toml
[tool.scikit-build]
sdist.cmake = true
sdist.include = [
"pybind11/tools",
"pybind11/include",
"pybind11/CMakeLists.txt",
]
```
:::
## Customizing the built wheel
The wheel will automatically look for Python packages at `src/<package_name>`,
`python/<package_name>`, and `<package_name>`, in that order. If you want to
list packages explicitly, you can. The final path element is the package.
```toml
[tool.scikit-build]
wheel.packages = ["python/src/mypackage"]
```
This can also be a table, allowing full customization of where a source package
maps to a wheel directory. The final components of both paths must match due to the
way editable installs work. The equivalent of the above is:
```toml
[tool.scikit-build.wheel.packages]
mypackage = "python/src/mypackage"
```
But you can also do more complex moves:
```toml
[tool.scikit-build.wheel.packages]
"mypackage/subpackage" = "python/src/subpackage"
```
:::{versionadded} 0.10
Support for the table form.
:::
You can disable Python file inclusion entirely, and rely only on CMake's
install mechanism:
```toml
[tool.scikit-build]
wheel.packages = []
```
The install directory is normally site-packages; however, you can manually set
that to a different directory if you'd like to avoid changing your CMake files.
For example, to mimic scikit-build classic:
```toml
[tool.scikit-build]
wheel.install-dir = "mypackage"
```
:::{warning}
You can select a different wheel target directory, as well, but that syntax is
experimental; install to `${SKBUILD_DATA_DIR}`, etc. from within CMake instead
for now.
:::
By default, any `LICEN[CS]E*`, `COPYING*`, `NOTICE*`, or `AUTHORS*` file in the
root of the build directory will be picked up. You can specify an exact list of
files if you prefer, or if your license file is in a different directory.
Globbing patterns are supported.
```toml
[tool.scikit-build]
wheel.license-files = ["LICENSE"]
```
You can exclude files from the built wheel (on top of the `sdist.exclude` list)
as well (not guaranteed to be respected by editable installs):
```toml
[tool.scikit-build]
wheel.exclude = ["**.pyx"]
```
:::{versionchanged} 0.9
Previously these were matched on the source path, rather than the wheel path,
and didn't apply to CMake output.
:::
:::{note}
There are two more settings that are primarily intended for `overrides` (see
below). `wheel.cmake` defaults to `true`, and this enables/disables building
with CMake. It also changes the default of `wheel.platlib` unless it's set
explicitly; CMake builds assume `wheel.platlib = true`, and CMake-less builds
assume `wheel.platlib = false` (purelib targeted instead).
:::
## Customizing the output wheel
The python API tags for your wheel will be correct assuming you are building a
CPython extension. If you are building a Limited ABI extension, you should set
the wheel tags for the version you support:
```toml
[tool.scikit-build]
wheel.py-api = "cp37"
```
Scikit-build-core will only target ABI3 if the version of Python is equal to or
newer than the one you set. `${SKBUILD_SABI_COMPONENT}` is set to
`Development.SABIModule` when targeting ABI3, and is an empty string otherwise.
If you are not using CPython at all, you can specify any version of Python is
fine:
```toml
[tool.scikit-build]
wheel.py-api = "py3"
```
Or even Python 2 + 3 (you still will need a version of Python scikit-build-core
supports to build the initial wheel):
```toml
[tool.scikit-build]
wheel.py-api = "py2.py3"
```
Some older versions of pip are unable to load standard universal tags;
scikit-build-core can expand the macOS universal tags for you for maximum
historic compatibility if you'd like:
```toml
[tool.scikit-build]
wheel.expand-macos-universal-tags = true
```
You can also specify a build tag:
```{conftabs} wheel.build-tag 1
```
You can select only specific components to install:
```{conftabs} install.components ["python"]
```
And you can turn off binary stripping:
```{conftabs} install.strip False
```
## Configuring CMake arguments and defines
You can select a different build type, such as `Debug`:
```{conftabs} cmake.build-type "Debug"
```
You can specify CMake defines:
````{tab} pyproject.toml
```toml
[tool.scikit-build.cmake.define]
SOME_DEFINE = "ON"
```
````
`````{tab} config-settings
````{tab} pip
```console
$ pip install . --config-settings=cmake.define.SOME_DEFINE=ON
```
````
````{tab} build
```console
$ pipx run build --wheel -Ccmake.define.SOME_DEFINE=ON
```
````
````{tab} cibuildwheel
```toml
[tool.cibuildwheel.config-settings]
"cmake.define.SOME_DEFINE" = "ON"
```
````
`````
````{tab} Environment
```yaml
SKBUILD_CMAKE_DEFINE: SOME_DEFINE=ON
```
````
You can also (`pyproject.toml` only) specify a dict, with `env=` to load a
define from an environment variable, with optional `default=`.
```toml
[tool.scikit-build.cmake.define]
SOME_DEFINE = {env="SOME_DEFINE", default="EMPTY"}
```
You can also manually specify the exact CMake args. Beyond the normal
`SKBUILD_CMAKE_ARGS`, the `CMAKE_ARGS` space-separated environment variable is
also supported (with some filtering for options scikit-build-core doesn't
support overriding).
```{conftabs} cmake.args ["-DSOME_DEFINE=ON", "-DOTHER=OFF"]
```
:::{warning}
Setting defines through `cmake.args` in `pyproject.toml` is discouraged because
this cannot be later altered via command line. Use `cmake.define` instead.
:::
You can also specify this using `CMAKE_ARGS`, space separated:
```yaml
CMAKE_ARGS: -DSOME_DEFINE=ON -DOTHER=OFF
```
You can also specify only specific targets to build (leaving this off builds the
default targets):
```{conftabs} build.targets ["python"]
```
:::{versionchanged} 0.10
`cmake.targets` was renamed to `build.targets`.
:::
You can pass raw arguments directly to the build tool, as well:
```{conftabs} build.tool-args ["-j12", "-l13"]
```
```{versionadded} 0.9.4
```
## Dynamic metadata
Scikit-build-core supports dynamic metadata with three built-in plugins.
:::{tab} Setuptools-scm
You can use [setuptools-scm](https://github.com/pypa/setuptools_scm) to pull the
version from VCS:
```toml
[project]
name = "mypackage"
dynamic = ["version"]
[tool.scikit-build]
metadata.version.provider = "scikit_build_core.metadata.setuptools_scm"
sdist.include = ["src/package/_version.py"]
[tool.setuptools_scm] # Section required
write_to = "src/package/_version.py"
```
This sets the python project version according to
[git tags](https://github.com/pypa/setuptools_scm/blob/fb261332d9b46aa5a258042d85baa5aa7b9f4fa2/README.rst#default-versioning-scheme)
or a
[`.git_archival.txt`](https://github.com/pypa/setuptools_scm/blob/fb261332d9b46aa5a258042d85baa5aa7b9f4fa2/README.rst#git-archives)
file, or equivalents for other VCS systems.
If you need to set the CMake project version without scikit-build-core (which
provides `${SKBUILD_PROJECT_VERSION}`), you can use something like
[`DynamicVersion` module](https://github.com/LecrisUT/CMakeExtraUtils/blob/180604da50a3c3588f9d04e4ebc6abb4e5a0d234/cmake/DynamicVersion.md)
from
[github.com/LecrisUT/CMakeExtraUtils](https://github.com/LecrisUT/CMakeExtraUtils):
```cmake
# Import `CMakeExtraUtils` or bundle `DynamicVersion.cmake` from there
include(DynamicVersion)
# Set ${PROJECT_VERSION} according to git tag or `.git_archival.txt`
dynamic_version()
project(MyPackage VERSION ${PROJECT_VERSION})
```
:::
:::{tab} Fancy-pypi-readme
You can use
[hatch-fancy-pypi-readme](https://github.com/hynek/hatch-fancy-pypi-readme) to
render your README:
```toml
[project]
name = "mypackage"
dynamic = ["readme"]
[tool.scikit-build]
metadata.readme.provider = "scikit_build_core.metadata.fancy_pypi_readme"
# tool.hatch.metadata.hooks.fancy-pypi-readme options here
```
:::
:::{tab} Regex
If you want to pull a string-valued expression (usually version) from an
existing file, you can the integrated `regex` plugin to pull the information.
```toml
name = "mypackage"
dynamic = ["version"]
[tool.scikit-build.metadata.version]
provider = "scikit_build_core.metadata.regex"
input = "src/mypackage/__init__.py"
```
You can set a custom regex with `regex=`. By default when targeting version, you
get a reasonable regex for python files,
`'(?i)^(__version__|VERSION)(?: ?\: ?str)? *= *([\'"])v?(?P<value>.+?)\2'`.
You can set `result` to a format string to process the matches; the default is
`"{value}"`. You can also specify a regex for `remove=` which will strip any
matches from the final result. A more complex example:
```toml
[tool.scikit-build.metadata.version]
provider = "scikit_build_core.metadata.regex"
input = "src/mypackage/version.hpp"
regex = '''(?sx)
\#define \s+ VERSION_MAJOR \s+ (?P<major>\d+) .*?
\#define \s+ VERSION_MINOR \s+ (?P<minor>\d+) .*?
\#define \s+ VERSION_PATCH \s+ (?P<patch>\d+) .*?
\#define \s+ VERSION_DEV \s+ (?P<dev>\d+) .*?
'''
result = "{major}.{minor}.{patch}dev{dev}"
remove = "dev0"
```
This will remove the "dev" tag when it is equal to 0.
::::{versionchanged} 0.10
Support for `result` and `remove` added.
::::
:::
:::{warning}
Your package and third-party packages can also extend these with new plugins,
but this is currently not ready for development outside of scikit-build-core;
`tool.scikit-build.experimental=true` is required to use plugins that are not
shipped with scikit-build-core, since the interface is provisional and may
change between _minor_ versions.
:::
### Writing metadata
You can write out metadata to file(s) as well. Other info might become available
here in the future, but currently it supports anything available as strings in
metadata. (Note that arrays like this are only supported in TOML configuration.)
```toml
[[tool.scikit-build.generate]]
path = "package/_version.py"
template = '''
version = "${version}"
'''
```
`template` or `template-path` is required; this uses {class}`string.Template`
formatting. There are three options for output location; `location = "install"`
(the default) will go to the wheel, `location = "build"` will go to the CMake
build directory, and `location = "source"` will write out to the source
directory (be sure to .gitignore this file. It will automatically be added to
your SDist includes. It will overwrite existing files).
The path is generally relative to the base of the wheel / build dir / source
dir, depending on which location you pick.
## Editable installs
Experimental support for editable installs is provided, with some caveats and
configuration. Recommendations:
- Use `--no-build-isolation` when doing an editable install is recommended; you
should preinstall your dependencies.
- Automatic rebuilds do not have the original isolated build dir (pip deletes
it), so select a `build-dir` when using editable installs, especially if you
also enable automatic rebuilds.
- You need to reinstall to pick up new files.
Known limitations:
- Resources (via `importlib.resources`) are not properly supported (yet).
Currently experimentally supported except on Python 3.9 (3.7, 3.8, 3.10, 3.11,
and 3.12 work). `importlib_resources` may work on Python 3.9.
```console
# Very experimental rebuild on initial import feature
$ pip install --no-build-isolation --config-settings=editable.rebuild=true -Cbuild-dir=build -ve.
```
Due to the length of this line already being long, you do not need to set the
`experimental` setting to use editable installs, but please consider them
experimental and subject to change.
You can disable the verbose rebuild output with `editable.verbose=false` if you
want. (Also available as the `SKBUILD_EDITABLE_VERBOSE` envvar when importing;
this will override if non-empty, and `"0"` will disable verbose output).
The default `editable.mode`, `"redirect"`, uses a custom redirecting finder to
combine the static CMake install dir with the original source code. Python code
added via scikit-build-core's package discovery will be found in the original
location, so changes there are picked up on import, regardless of the
`editable.rebuild` setting.
:::{note}
A second experimental mode, `"inplace"`, is also available. This does an
in-place CMake build, so all the caveats there apply too -- only one build per
source directory, you can't change to an out-of-source builds without removing
the build artifacts, your source directory will be littered with build
artifacts, etc. Also, to make your binaries importable, you should set
`LIBRARY_OUTPUT_DIRECTORY` (include a generator expression, like the empty one
`$<0:>` for multi-config generator support, like MSVC, so you don't have to set
all possible `*_<CONFIG>` variations) to make sure they are placed inside your
source directory inside the Python packages; this will be run from the build
directory, rather than installed. This will also not support automatic rebuilds.
The build directory setting will be ignored if you use this and perform an
editable install. You can detect this mode by checking for an in-place build and
checking `SKBUILD` being set.
With all the caveats, this is very logically simple (one directory) and a near
identical replacement for `python setup.py build_ext --inplace`. Some third
party tooling might work better with this mode. Scikit-build-core will simply
install a `.pth` file that points at your source package(s) and do an inplace
CMake build.
On the command line, you can pass `-Ceditable.mode=inplace` to enable this mode.
:::
## Messages
You can add a message to be printed after a successful or failed build. For example:
```toml
[tool.scikit-build]
messages.after-sucesss = "{green}Wheel successfully built"
messages.after-failure = """
{bold.red}Sorry{normal}, build failed. Your platform is {platform.platform}.
"""
```
This will be run through Python's formatter, so escape curly brackets if you
need them. Currently, there are several formatter-style keywords available:
`sys`, `platform` (parenthesis will be added for items like `platform.platform`
for you), `__version__` for scikit-build-core's version, and style keywords.
For styles, the colors are `default`, `red`, `green`, `yellow`, `blue`,
`magenta`, `cyan`, and `white`. These can be accessed as `fg.*` or `bg.*`,
without a qualifier the foreground is assumed. Styles like `normal`, `bold`,
`italic`, `underline`, `reverse` are also provided. A full clearing of all
styles is possible with `reset`. These all can be chained, as well, so
`bold.red.bg.blue` is valid, and will produce an optimized escape code.
Remember that you need to set the environment variable `FORCE_COLOR` to see
colors with pip.
```{versionadded} 0.10
```
## Other options
You can select a custom build dir; by default scikit-build-core will use a
temporary dir. If you select a persistent one, you can get major rebuild
speedups.
```{conftabs} build-dir "build/{wheel_tag}"
```
There are several values you can access through Python's formatting syntax:
- `cache_tag`: `sys.implementation.cache_tag`
- `wheel_tag`: The tags as computed for the wheel
- `build_type`: The current build type (`Release` by default)
- `state`: The current run state, `sdist`, `wheel`, `editable`,
`metadata_wheel`, and `metadata_editable`
Scikit-build-core also strictly validates configuration; if you need to disable
this, you can:
```toml
[tool.scikit-build]
strict-config = false
```
Scikit-build-core also occasionally has experimental features. This is applied
to features that do not yet carry the same forward compatibility (using
minimum-version) guarantee that other scikit-build-core features have. These can
only be used if you enable them:
```toml
[tool.scikit-build]
experimental = true
```
You can also fail the build with `fail = true`. This is useful with overrides if
you want to make a specific configuration fail. If this is set, extra
dependencies like `"cmake"` will not be requested.
```{versionadded} 0.10
```
## Overrides
The overrides system allows you to customize for a wide variety of situations.
It is described at [](#overrides).
## Full Schema
You can see the full schema at [](#schema).