f4a7163433
define anything special. If you are not an exporter, then it now assumes that you are an importer. - modified: test2-dynamic/module1.h test2-dynamic/uselib.cc test3-twomodules/module1.h test3-twomodules/module2.h test3-twomodules/uselib.cc test4-interdep/module1.h test4-interdep/module2.h test4-interdep/uselib.cc |
||
---|---|---|
.. | ||
Makefile | ||
module1.cc | ||
module1.h | ||
module2.cc | ||
module2.h | ||
README | ||
uselib.cc | ||
uselib.h |
test4-interdep Can one module reference objects in another module? Yes. module1 exports module_name and operate(int,int). module2 exports n_operations and operation_occurred(). uselib.cc uses symbols and functions from both modules. Module1 calls operation_occurred() in module2. To do this, module2 must be built first. Then module1 is linked against module2 so that the missing symbols are available. Then, uselib is linked against both. This shows that we can chain libraries. I haven't seen any way to resolve a circular dependency, where mod1 depends on mod2 and vice versa, in win32 DLLs. Probably those are not supported.