It can only be used for projects that don't have any rules at all, i.e. they are purely using Meson to: - configure files - run (script?) tests - install files that exist by the end of the setup stage This can be useful e.g. for Meson itself, a pure python project.pull/10779/head
parent
2a0b80eb67
commit
a024d75e15
12 changed files with 91 additions and 10 deletions
@ -0,0 +1,4 @@ |
||||
## New "none" backend |
||||
|
||||
The `--backend=none` option has been added, to configure a project that has no |
||||
build rules, only install rules. This avoids depending on ninja. |
@ -0,0 +1,31 @@ |
||||
# Copyright 2022 The Meson development team |
||||
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); |
||||
# you may not use this file except in compliance with the License. |
||||
# You may obtain a copy of the License at |
||||
|
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
||||
|
||||
# Unless required by applicable law or agreed to in writing, software |
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
# See the License for the specific language governing permissions and |
||||
# limitations under the License. |
||||
|
||||
from __future__ import annotations |
||||
|
||||
from .backends import Backend |
||||
from .. import mlog |
||||
from ..mesonlib import MesonBugException |
||||
|
||||
|
||||
class NoneBackend(Backend): |
||||
|
||||
name = 'none' |
||||
|
||||
def generate(self): |
||||
if self.build.get_targets(): |
||||
raise MesonBugException('None backend cannot generate target rules, but should have failed earlier.') |
||||
mlog.log('Generating simple install-only backend') |
||||
self.serialize_tests() |
||||
self.create_install_data_files() |
@ -0,0 +1,3 @@ |
||||
testcase expect_error('Install-only backend cannot generate target rules, try using `--backend=ninja`.') |
||||
import('fs').copyfile('../test.py') |
||||
endtestcase |
Loading…
Reference in new issue