diff --git a/authors.txt b/authors.txt index 85a4770f5..8b0396cfe 100644 --- a/authors.txt +++ b/authors.txt @@ -10,3 +10,4 @@ Masashi Fujita Juhani Simola Robin McCorkell Axel Waggershauser +Igor Gnatenko diff --git a/interpreter.py b/interpreter.py index 98875ce45..edc7721ab 100644 --- a/interpreter.py +++ b/interpreter.py @@ -616,6 +616,8 @@ class ModuleHolder(InterpreterObject): self.interpreter.environment.get_build_dir()) state.subdir = self.interpreter.subdir state.environment = self.interpreter.environment + state.project_name = self.interpreter.build.project_name + state.targets = self.interpreter.build.targets value = fn(state, args, kwargs) return self.interpreter.module_method_callback(value) diff --git a/modules/rpm.py b/modules/rpm.py new file mode 100644 index 000000000..56f4ae08d --- /dev/null +++ b/modules/rpm.py @@ -0,0 +1,69 @@ +# Copyright 2015 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. + +'''This module provides helper functions for RPM related +functionality such as generating RPM spec file.''' + +import build +import mlog + +class RPMModule: + + def generate_spec(self, state, args, kwargs): + proj = state.project_name.replace(' ', '_').replace('\t', '_') + fn = open('%s.spec' % proj, 'w+') + fn.write('Name: %s\n' % proj) + fn.write('\n') + for dep in state.environment.coredata.deps: + fn.write('BuildRequires: pkgconfig(%s)\n' % dep) + for lib in state.environment.coredata.ext_libs.values(): + fn.write('BuildRequires: %s # FIXME\n' % lib.fullpath) + mlog.log('Warning, replace', mlog.bold(lib.fullpath), 'with real package.', + 'You can use following command to find package which contains this lib:', + mlog.bold('dnf provides %s' % lib.fullpath)) + for prog in state.environment.coredata.ext_progs.values(): + fn.write('BuildRequires: %s\n' % ' '.join(prog.fullpath)) + fn.write('BuildRequires: meson\n') + fn.write('\n') + fn.write('%prep\n') + fn.write('%autosetup\n') + fn.write('rm -rf build && mkdir build\n') + fn.write('\n') + fn.write('%build\n') + fn.write('pushd build\n') + fn.write(' meson ..\n') + fn.write(' ninja-build -v\n') + fn.write('popd\n') + fn.write('\n') + fn.write('%isntall\n') + fn.write('pushd build\n') + fn.write(' DESTDIR=%{buildroot} ninja-build -v install\n') + fn.write('popd\n') + fn.write('\n') + fn.write('%files\n') + for target in state.targets.values(): + if isinstance(target, build.Executable) and target.need_install: + fn.write('%%{_bindir}/%s\n' % target.filename) + elif isinstance(target, build.SharedLibrary) and target.need_install: + fn.write('%%{_libdir}/%s\n' % target.filename) + elif isinstance(target, build.StaticLibrary) and target.need_install: + fn.write('%%{_libdir}/%s\n' % target.filename) + mlog.log('Warning, installing static libs (', + mlog.bold(target.filename), + ') not recommended') + fn.write('\n') + fn.close() + +def initialize(): + return RPMModule()