Example #1
0
        def __call__(self, sched_ctx):
            from wonderbuild.cxx_tool_chain import PkgConfigCheckTask
            from wonderbuild.std_checks.std_math import StdMathCheckTask
            from wonderbuild.std_checks.std_cxx import StdCxxCheckTask
            from wonderbuild.std_checks.boost import BoostCheckTask
            from wonderbuild.std_checks.multithreading_support import MultithreadingSupportCheckTask
            from wonderbuild.std_checks.openmp import OpenMPCheckTask
            from wonderbuild.std_checks.dynamic_loading_support import DynamicLoadingSupportCheckTask

            check_cfg = self.cfg.clone()
            std_math = StdMathCheckTask.shared(check_cfg)
            std_cxx11 = StdCxxCheckTask.shared(check_cfg, 11)
            self._boost = boost = BoostCheckTask.shared(
                check_cfg, (1, 40, 0),
                ('system', 'thread', 'filesystem', 'date_time'))
            mt = MultithreadingSupportCheckTask.shared(check_cfg)
            openmp = OpenMPCheckTask.shared(check_cfg)
            dl = DynamicLoadingSupportCheckTask.shared(check_cfg)
            glibmm = PkgConfigCheckTask.shared(
                check_cfg, ['glibmm-2.4', 'gmodule-2.0', 'gthread-2.0'])

            req = [
                std_math, boost
            ]  # required because pre-compiled.private.hpp includes them unconditionaly
            opt = [std_cxx11, mt, openmp, dl, glibmm]
            for x in sched_ctx.parallel_wait(*(req + opt)):
                yield x
            self.private_deps += req + [o for o in opt if o]
        def __call__(self, sched_ctx):
            from wonderbuild.cxx_tool_chain import PkgConfigCheckTask
            from wonderbuild.std_checks.std_math import StdMathCheckTask
            from wonderbuild.std_checks.std_cxx11 import StdCxx11CheckTask
            from wonderbuild.std_checks.boost import BoostCheckTask
            from wonderbuild.std_checks.multithreading_support import MultithreadingSupportCheckTask
            from wonderbuild.std_checks.openmp import OpenMPCheckTask
            from wonderbuild.std_checks.dynamic_loading_support import DynamicLoadingSupportCheckTask

            check_cfg = self.cfg.clone()
            std_math = StdMathCheckTask.shared(check_cfg)
            std_cxx11 = StdCxx11CheckTask.shared(check_cfg)
            self._boost = boost = BoostCheckTask.shared(
                check_cfg, (1, 40, 0), ("system", "thread", "filesystem", "date_time")
            )
            mt = MultithreadingSupportCheckTask.shared(check_cfg)
            openmp = OpenMPCheckTask.shared(check_cfg)
            dl = DynamicLoadingSupportCheckTask.shared(check_cfg)
            glibmm = PkgConfigCheckTask.shared(check_cfg, ["glibmm-2.4", "gmodule-2.0", "gthread-2.0"])

            req = [std_math, boost]  # required because pre-compiled.private.hpp includes them unconditionaly
            opt = [std_cxx11, mt, openmp, dl, glibmm]
            for x in sched_ctx.parallel_wait(*(req + opt)):
                yield x
            self.private_deps += req + [o for o in opt if o]
Example #3
0
	def __call__(self, sched_ctx):
		top_src_dir = self.src_dir.parent
		src_dir = self.src_dir / 'src'
		
		diversalis = ScriptLoaderTask.shared(self.project, top_src_dir / 'diversalis')
		for x in sched_ctx.parallel_wait(diversalis): yield x
		diversalis = diversalis.script_task
		self._common = common = diversalis.common
		diversalis = diversalis.mod_dep_phases
		pch = common.pch
		cfg = common.cfg.clone()

		from wonderbuild.cxx_tool_chain import PkgConfigCheckTask, ModTask
		from wonderbuild.std_checks.std_math import StdMathCheckTask
		from wonderbuild.std_checks.std_cxx11 import StdCxx11CheckTask
		from wonderbuild.std_checks.boost import BoostCheckTask
		from wonderbuild.std_checks.multithreading_support import MultithreadingSupportCheckTask
		from wonderbuild.std_checks.openmp import OpenMPCheckTask
		from wonderbuild.std_checks.dynamic_loading_support import DynamicLoadingSupportCheckTask
		from wonderbuild.std_checks.winmm import WinMMCheckTask

		check_cfg = cfg.clone()
		std_math = StdMathCheckTask.shared(check_cfg)
		std_cxx11 = StdCxx11CheckTask.shared(check_cfg)
		boost = BoostCheckTask.shared(check_cfg, (1, 40, 0), ('system', 'thread', 'filesystem', 'date_time'))
		boost_test = BoostCheckTask.shared(check_cfg, (1, 40, 0), ('unit_test_framework',))
		mt = MultithreadingSupportCheckTask.shared(check_cfg)
		openmp = OpenMPCheckTask.shared(check_cfg)
		dl = DynamicLoadingSupportCheckTask.shared(check_cfg)
		glibmm = PkgConfigCheckTask.shared(check_cfg, ['glibmm-2.4', 'gmodule-2.0', 'gthread-2.0'])
		winmm = WinMMCheckTask.shared(check_cfg)
		
		from wonderbuild.install import InstallTask

		class UniversalisMod(ModTask):
			def __init__(self): ModTask.__init__(self, 'universalis', ModTask.Kinds.LIB, cfg)
				
			def do_set_deps(self, sched_ctx):
				self.public_deps = [diversalis, std_math, boost, mt, dl]
				if self.cfg.dest_platform.os == 'win': self.public_deps.append(winmm)
				req = self.all_deps
				opt = [std_cxx11, openmp, glibmm]
				for x in sched_ctx.parallel_wait(*(req + opt)): yield x
				self.public_deps += [o for o in opt if o]
				self.cxx_phase = self.__class__.InstallHeaders(self.base_cfg.project, self.name + '-headers')

			class InstallHeaders(InstallTask):
				@property
				def trim_prefix(self): return src_dir

				@property
				def dest_dir(self): return self.fhs.include

				@property
				def sources(self):
					try: return self._sources
					except AttributeError:
						self._sources = [self.trim_prefix / 'universalis.hpp'] + \
							list((self.trim_prefix / 'universalis').find_iter(
								in_pats = ('*.hpp',), ex_pats = ('*.private.hpp',), prune_pats = ('todo',)))
						return self._sources

			def apply_cxx_to(self, cfg):
				if self.cxx_phase.dest_dir not in cfg.include_paths: cfg.include_paths.append(self.cxx_phase.dest_dir)
				if not self.cfg.shared: cfg.defines['UNIVERSALIS__SOURCE'] = '-1'

			def do_mod_phase(self):
				if self.cfg.shared: self.cfg.defines['UNIVERSALIS__SHARED'] = None
				self.cfg.defines['UNIVERSALIS__META__MODULE__NAME'] = '"' + self.name +'"'
				self.cfg.defines['UNIVERSALIS__META__MODULE__VERSION'] = 0
				self.cfg.include_paths.appendleft(src_dir)
				for s in (src_dir / 'universalis').find_iter(in_pats = ('*.cpp',), prune_pats = ('todo',)): self.sources.append(s)
			
		self._mod_dep_phases = mod_dep_phases = universalis = UniversalisMod()
		common.pch.private_deps.append(mod_dep_phases)
		self.default_tasks.append(mod_dep_phases.mod_phase)

		for x in sched_ctx.parallel_wait(boost_test): yield x
		if boost_test:
			class UnitTestMod(ModTask):
				def __init__(self): ModTask.__init__(self, 'universalis-unit-tests', ModTask.Kinds.PROG, cfg)

				def do_set_deps(self, sched_ctx):
					if False: yield
					self.private_deps = [pch.prog_task, universalis, boost_test]

				def do_mod_phase(self):
					self.cfg.include_paths.appendleft(src_dir)
					self.cfg.defines['UNIVERSALIS__META__MODULE__NAME'] = '"' + self.name +'"'
					self.cfg.defines['UNIVERSALIS__META__MODULE__VERSION'] = 0
					self.sources.append(src_dir / 'unit_tests.cpp')
				
			unit_tests = UnitTestMod()
			self.default_tasks.append(unit_tests.mod_phase)