| Authors: | Matthias Rustler (some parts copied from other documents) | 
|---|---|
| Copyright: | Copyright (C) 2008-2010, The AROS Development Team | 
| Version: | $Revision$ | 
| Date: | $Date$ | 
| Status: | Unfinished | 
| ToDo: | Complete... | 
Contents
Modules are shared binaries. Their main purpose is to deliver tables of functions and classes for object-oriented access to GUI elements and multimedia data.
Building modules consists of two parts: + a macro to use in mmakefile.src files + a configuration file that describes the contents of the module.
The build system has the macro "build_module" for the task of creating modules. The parameters are:
The name to be used for the static link library that contains the library autoinit code and the stubs converting C stack calling convention to a call of the function from the library functable with the appropriate calling mechanism. These stubs are normally not needed when the AROS defines for module functions are not disabled.
There will always be a file generated with the name $(LIBDIR)/lib%(linklibname).a and by default linklibname will be the same as modname.
A list of static libraries to add when linking the module. This is the name of the library without the lib prefix or the .a suffix and without the -l prefix for the use in the flags for the C compiler.
By default no libraries are used when linking the module.
The build system calls the tool "genmodule" in order to create some additional C source and header files. This tool is driven be a configuration file which allows to set a lot of options for the fine tuning of the generated files. Configuration files contain named sections with definitions:
##begin <sectionname> <definitions> ##end <sectionname>
Sectionname can be "config", "cdef", "cdefprivate", "functionlist", "cfunctionlist", "startup", "methodlist", "class", "handler", "interface" or "attributelist".
The lines in this section have all the same format:
optionname string
with the string starting from the first non-white-space after optionname to the last non-white-space character on that line.
Sets the value of the rt_Pri field in struct Resident. Additionally, the resident flag is set:
| priority | flag | 
|---|---|
| >=105 | RTF_SINGLETASK | 
| >=-60 | RTF_COLDSTART | 
| <-120 | RTF_AFTERDOS | 
Comma separated list of options. The defaults depend on the type of module.
The variable which contains a pointer to the class is per default hidden. If you need to have access to this pointer you have to use this option, like:
classptr_var MyClass
Public name of the class, either a string or a C macros. Examples:
classid "gradientslider.gadget" classid AROSCHECKBOXCLASS
You need "class" sections only when you want to define additional classes in your module. If you create a module for e.g. a gadget a class for a gadget is automatically created. This means you can use the definitions below in the "config" section.
Type of the class. Possible values:
In this section all the C code has to be written that will declare all the type of the arguments of the function listed in the function. All valid C code is possible including the use of #include.
Like "cdef" but for all declarations which must not be visible for the module user.
In this section are all the functions that are externally accessible by programs.
For stack-based argument passing, only a list of the functions has to be given:
##begin functionlist void func1(LONG a, LONG b) int func2(char *s, ULONG a) ##end functionlist
For register-based argument passing, the names of the register have to be given between parentheses:
##begin functionlist ULONG func5(ULONG a, STRPTR b) (D0,A0) ##end functionlist
There are some modifiers which influence the previously defined function.
Do not create a vararg wrapper for the function. By default that wrapper is generated for register based functions if:
There are some modifiers which influence the following functions.
Same as functionlist but with modifier ".cfunction" for each function.
Here you can list all you methods for an automatic creation of a dispatcher. The real function name for a method "name" must become <basename>__<name> in the source code.
There are some tags which influence the previously defined method.
The content will be written at the begin of autoinit.c which will be part of the autostart linker library.
FIXME
FIXME
| Type | Target directory | 1st LVO | 
|---|---|---|
| library | Libs | 5 | 
| mcc | Classes/Zune | 6 | 
| mui | Classes/Zune | 6 | 
| mcp | Classes/Zune | 6 | 
| device | Devs | 7 | 
| resource | Devs | 1 | 
| gadget | Classes/Gadgets | 5 | 
| datatype | Classes/Datatypes | 6 | 
| hidd | Devs/Drivers | 5 | 
| Type | Superclass | 
|---|---|
| mcc | MUIC_Area | 
| mui | MUIC_Area | 
| mcp | MUIC_Mccprefs | 
| image | IMAGECLASS | 
| gadget | GADGETCLASS | 
| datatype | DATATYPESCLASS | 
| class | ROOTCLASS | 
| hidd | CLID_Root |