Yate Design
|  (Created page with "  The purpose of Yate's design is to provide an extensible telephony engine. Holding the base code as simple as possible and adding functionality as needed allows one to find ...") | |||
| Line 5: | Line 5: | ||
| ===Engine=== | ===Engine=== | ||
| − | The engine holds the base C++ classes of Yate and connects together all components. There is a diagram showing how all components interact. | + | The engine holds the base C++ classes of Yate and connects together all components. There is a [Yate_architecture|diagram]] showing how all components interact. | 
| ===Modules=== | ===Modules=== | ||
| Line 18: | Line 18: | ||
| '''See also''' | '''See also''' | ||
| − | * External Module | + | * [[External Module]] | 
| * [[Messages]] | * [[Messages]] | ||
Revision as of 19:11, 14 November 2012
The purpose of Yate's design is to provide an extensible telephony engine. Holding the base code as simple as possible and adding functionality as needed allows one to find the best balance between desired functionality, performance and stability.
Engine
The engine holds the base C++ classes of Yate and connects together all components. There is a [Yate_architecture|diagram]] showing how all components interact.
Modules
Most real functionality is provided by modules loaded at runtime. These can be dynamical libraries loaded as plugins in the engine or external applications started by a specific module (extmodule) that allows them to talk to the engine and other modules.
Messages
The signaling between Yate modules (either plugins or external modules) is performed by using messages. They provide extensibility, customization and technology independence. Each module that needs something from another or tries to notify about some event creates and emits a message. The message flows through the Engine which tries to deliver it to the proper target.
See also
