1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-12 09:18:10 +03:00
samba-mirror/source4/build/smb_build
2007-10-10 13:08:58 -05:00
..
check_cc.m4 r2011: remove this broken and never reached test 2007-10-10 12:58:17 -05:00
check_ld.m4 r968: use sinlcude() and no function, that's more portable between 2007-10-10 12:56:24 -05:00
check_path.m4 r3651: Add a new configure option --with-eparserdir 2007-10-10 13:05:41 -05:00
check_perl.m4 r968: use sinlcude() and no function, that's more portable between 2007-10-10 12:56:24 -05:00
check_shld.m4 r968: use sinlcude() and no function, that's more portable between 2007-10-10 12:56:24 -05:00
check_types.m4 r968: use sinlcude() and no function, that's more portable between 2007-10-10 12:56:24 -05:00
config_mk.pm r3733: More build system fixes/features: 2007-10-10 13:05:47 -05:00
core.m4 r3751: Some fixes to using enable and disable for subsystems, ext libs and modules 2007-10-10 13:05:51 -05:00
dot.pm r3733: More build system fixes/features: 2007-10-10 13:05:47 -05:00
env.m4 r1073: import DYNEXP flags to smb_build 2007-10-10 12:56:36 -05:00
input.pm r3768: Fix build of libraries 2007-10-10 13:05:52 -05:00
main.pm r4729: add dummy "winbind" service 2007-10-10 13:08:49 -05:00
makefile.pm r4814: cope with perl not being in /usr/bin for idl building 2007-10-10 13:08:58 -05:00
output.pm r4812: removed dependence on Data::Dumper 2007-10-10 13:08:58 -05:00
public.m4 r3751: Some fixes to using enable and disable for subsystems, ext libs and modules 2007-10-10 13:05:51 -05:00
README.txt r3730: More build system fixes and simplifications 2007-10-10 13:05:47 -05:00
smb_build_h.pm r3744: Support building subsystems as a shared library. Modules don't work yet, 2007-10-10 13:05:50 -05:00

The Samba Build System
----------------------
----------------------

Object Types
------------
the build system knows about the following object types

SUBSYSTEM:
	a SUBSYSTEM is basicly a collection of functions, which provide an
	an generic API for a specific problem (e.g. libldb provides an api
	for gneric ldb databases. libldb_plugin provides a generic api
	for calling ldb plugins, so 'libldb' and 'libldb_plugin' are subsystems)

MODULE:
	a MODULE is a specify implementation of a API provided by a SUBSYSTEM.
	(e.g. 'libldb_tdb' and 'libldb_ldap' are implementations of the subsystem 'libldb' API,
	 and 'libldb_plugin_timestamp' is a module of the 'libldb_plugin' subsystem)	

EXT_LIB:
	an EXT_LIB is an external library which is needed by a SUBSYSTEM, MODULE, BINARY or LIBRARY.
	(e.g. 'gtk' or 'KRB5')

BINARY:
	a BINARY means a executable binary file.
	(e.g. 'smbtorture' or 'ldbedit')
	a BINARY typicly has only commandline handling and basic 
	functionality code in it and depends on the functions of
	SUBSYSTEM's (required_subsystems/REQUIRED_SUBSYSTEMS).

LIBRARY:
	a LIBRARY means a static and/or shared library,
	which depends on the used OS.
	(e.g. for libldb 'libldb.so', 'libldb.so.0' 'libldb.so.0.0.1'
	      and libldb.a are created on linux)
	a LIBRARY typicly has only glue code in it and depends on
	SUBSYSTEM's (required_subsystems/REQUIRED_SUBSYSTEMS).


Macrodescriptions
----------------
On top of build/smb_build/public.m4 is a list of all public macros of the build system.


Layout
-------

Toplevel file: configure.in
- included by autogen.sh: aclocal.m4
  which includes the SMB_YXZ*() macros

- default tests of the build system
  are in build/smb_build/check_*.m4
  (mostly compiler and basic C type and function
   checks)

- subsystem specific stuff should be included by 'SMB_INLUDE_M4()'


Generating of 'configure'
-------------------------
you need to rerun ./autogen.sh when 'configure.in' or any
'.m4' file was modified, then you need to rerun configure.


Generating of 'config.status'
-----------------------------
you need to run ./config.status (or 'configure') after a '.mk'
file was changed.


Examples
--------
for now please take a look at the .m4 and .mk files
you find in the source tree, they should be a good reference to start.


README-TODO
------------
SMB_XYZ() vs. SMB_XYZ_MK()
meaning of the macros parameters and the .mk file handling
examples