c

Base for c programs/libraries

waflib.Tools.c.c_hook(self, node)[source]

Bind the c file extension to the creation of a waflib.Tools.c.c instance

class waflib.Tools.c.c(*k, **kw)[source]

Bases: waflib.Task.Task

Compile C files into object files

vars = ['ARCH', 'ARCH_ST', 'CC', 'CCDEPS', 'CC_SRC_F', 'CC_TGT_F', 'CFLAGS', 'CPPFLAGS', 'CPPPATH_ST', 'DEFINES', 'DEFINES_ST', 'FRAMEWORKPATH', 'FRAMEWORKPATH_ST', 'INCPATHS']
ext_in = ['.h']
scan(task)

Get the dependencies using a c/c++ preprocessor, this is required for finding dependencies of the kind:

#include some_macro()

This function is bound as a task method on waflib.Tools.c.c and waflib.Tools.cxx.cxx for example

__doc__ = 'Compile C files into object files'
__module__ = 'waflib.Tools.c'
exec_command(*k, **kw)

Change the command-line execution for msvc programs. Instead of quoting all the paths and keep using the shell, we can just join the options msvc is interested in

exec_command_nomsvc(cmd, **kw)

Wrapper for waflib.Context.Context.exec_command() which sets a current working directory to build.variant_dir

Returns:the return code
Return type:int
exec_mf()

Create the manifest file

hcode = '${CC} ${ARCH_ST:ARCH} ${CFLAGS} ${CPPFLAGS} ${FRAMEWORKPATH_ST:FRAMEWORKPATH} ${CPPPATH_ST:INCPATHS} ${DEFINES_ST:DEFINES} ${CC_SRC_F}${SRC} ${CC_TGT_F}${TGT}'
class waflib.Tools.c.cprogram(*k, **kw)[source]

Bases: waflib.Tools.ccroot.link_task

Link object files into a c program

ext_out = ['.bin']
vars = ['ARCH', 'ARCH_ST', 'CCLNK_SRC_F', 'CCLNK_TGT_F', 'FRAMEWORK', 'FRAMEWORKPATH', 'FRAMEWORKPATH_ST', 'FRAMEWORK_ST', 'LIB', 'LIBPATH', 'LIBPATH_ST', 'LIB_ST', 'LINKDEPS', 'LINKFLAGS', 'LINK_CC', 'RPATH', 'RPATH_ST', 'SHLIB_MARKER', 'STLIB', 'STLIBPATH', 'STLIBPATH_ST', 'STLIB_MARKER', 'STLIB_ST']
inst_to = '${BINDIR}'
__doc__ = 'Link object files into a c program'
__module__ = 'waflib.Tools.c'
exec_command(*k, **kw)

Change the command-line execution for msvc programs. Instead of quoting all the paths and keep using the shell, we can just join the options msvc is interested in

exec_command_nomsvc(cmd, **kw)

Wrapper for waflib.Context.Context.exec_command() which sets a current working directory to build.variant_dir

Returns:the return code
Return type:int
exec_mf()

Create the manifest file

hcode = '${LINK_CC} ${LINKFLAGS} ${CCLNK_SRC_F}${SRC} ${CCLNK_TGT_F}${TGT[0].abspath()} ${RPATH_ST:RPATH} ${FRAMEWORKPATH_ST:FRAMEWORKPATH} ${FRAMEWORK_ST:FRAMEWORK} ${ARCH_ST:ARCH} ${STLIB_MARKER} ${STLIBPATH_ST:STLIBPATH} ${STLIB_ST:STLIB} ${SHLIB_MARKER} ${LIBPATH_ST:LIBPATH} ${LIB_ST:LIB}'
class waflib.Tools.c.cshlib(*k, **kw)[source]

Bases: waflib.Tools.c.cprogram

Link object files into a c shared library

inst_to = '${LIBDIR}'
__doc__ = 'Link object files into a c shared library'
__module__ = 'waflib.Tools.c'
exec_command(*k, **kw)

Change the command-line execution for msvc programs. Instead of quoting all the paths and keep using the shell, we can just join the options msvc is interested in

exec_command_nomsvc(*k, **kw)

Change the command-line execution for msvc programs. Instead of quoting all the paths and keep using the shell, we can just join the options msvc is interested in

exec_mf()

Create the manifest file

hcode = '\tdef run(self):\n\t\tbld = self.generator.bld\n\t\tif bld.cache_global and not bld.nocache:\n\t\t\tif self.can_retrieve_cache():\n\t\t\t\treturn 0\n\t\treturn m1(self)\n'
class waflib.Tools.c.cstlib(*k, **kw)[source]

Bases: waflib.Tools.ccroot.stlink_task

Link object files into a c static library

__doc__ = 'Link object files into a c static library'
__module__ = 'waflib.Tools.c'
exec_command(*k, **kw)

Change the command-line execution for msvc programs. Instead of quoting all the paths and keep using the shell, we can just join the options msvc is interested in

exec_command_nomsvc(cmd, **kw)

Wrapper for waflib.Context.Context.exec_command() which sets a current working directory to build.variant_dir

Returns:the return code
Return type:int
exec_mf()

Create the manifest file

hcode = '\tdef wrap(self):\n\t\ttry: os.remove(self.outputs[0].abspath())\n\t\texcept OSError: pass\n\t\treturn old(self)\n'

Bases: waflib.Tools.ccroot.link_task

Base for static link tasks, which use ar most of the time. The target is always removed before being written.

Bases: waflib.Task.Task

Base class for all link tasks. A task generator is supposed to have at most one link task bound in the attribute link_task. See waflib.Tools.ccroot.apply_link().

Inheritance diagram of waflib.Tools.ccroot.stlink_task, waflib.Tools.c.cprogram, waflib.Tools.c.cshlib, waflib.Tools.cxx.cxxstlib, waflib.Tools.cxx.cxxprogram, waflib.Tools.cxx.cxxshlib, waflib.Tools.d.dprogram, waflib.Tools.d.dshlib, waflib.Tools.d.dstlib, waflib.Tools.ccroot.fake_shlib, waflib.Tools.ccroot.fake_stlib, waflib.Tools.asm.asmprogram, waflib.Tools.asm.asmshlib, waflib.Tools.asm.asmstlib

Process the target attribute to add the platform-specific prefix/suffix such as .so or .exe. The settings are retrieved from env.clsname_PATTERN

Previous topic

ccroot

Next topic

cxx

This Page