File: code_structure.rst

package info (click to toggle)
roc-toolkit 0.4.0%2Bdfsg-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 9,684 kB
  • sloc: cpp: 102,987; ansic: 8,959; python: 6,125; sh: 942; makefile: 16; javascript: 9
file content (161 lines) | stat: -rw-r--r-- 6,901 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
Code structure
**************

.. contents:: Table of contents:
   :local:
   :depth: 1

Overview
========

`Roc Toolkit <https://github.com/roc-streaming/roc-toolkit>`_ consists of the following high-level components:

* **Internal modules**

  Internal C++ libraries, not part of public API. Basic building blocks for library and tools. See `Doxygen documentation <https://roc-streaming.org/toolkit/doxygen/>`_ for details.

* **C library**

  Public C API (libroc) for C and C++ applications. See :doc:`/api` page.

* **Command-line tools**

  Command-line tools for developers and advanced users. See :doc:`/tools/command_line_tools` page.

Besides toolkit, `Roc Streaming <https://github.com/roc-streaming>`_ project provides some software on top of it:

* **Language bindings**

  Library bindings for other programming languages. See :doc:`/api/bindings` page.

* **Sound server modules**

  Modules for OS-specific sound servers, like PulseAudio and PipeWire. See :doc:`/tools/sound_server_modules` page.

* **Applications**

  Desktop and mobile apps for end-users. See :doc:`/tools/applications` page.

.. image:: ../_images/code_structure.png
    :align: center
    :alt: Overview

Modules
=======

Essentially, a module is just a C++ library providing a set of related classes. Every module has its own namespace, include path, and a set of unit tests. Modules may be built separately.

See `Doxygen documentation <https://roc-streaming.org/toolkit/doxygen/>`_ for details.

Modules can be grouped into several layers, as shown on the diagram above:

* network I/O layer (roc_netio)

* processing layer (roc_pipeline), with two sub-layers:

 * packet processing sub-layer (roc_packet, roc_rtp, roc_rtcp, roc_fec, and others)

 * frame processing sub-layer (roc_audio)

* sound I/O layer (roc_sndio)

* control layer (roc_ctl)

* node layer (roc_node)

On receiver media flows from network I/O layer, through processing layer, to sound I/O layer. Accordingly, on sender media flows from sound I/O layer, through processing layer, to network I/O layer. On both receiver and sender, there is also control layer that handles various supportive tasks. Finally, node layer is a top-level layer which glues everything together.

Here is the full list of available modules:

================= =================================
module            description
================= =================================
`roc_core`_       General-purpose building blocks (containers, memory management, multithreading, etc)
`roc_status`_     Status codes
`roc_address`_    Network URIs and addresses
`roc_packet`_     Network packets and packet processing
`roc_rtp`_        RTP support
`roc_rtcp`_       RTCP support
`roc_fec`_        FEC support
`roc_sdp`_        SDP support
`roc_audio`_      Audio frames and audio processing
`roc_pipeline`_   Pipeline loop that arranges all packet and frame processors into a chain
`roc_ctl`_        Control loop that handles signaling protocols and background tasks
`roc_netio`_      Network I/O loop
`roc_sndio`_      Sound I/O loop
`roc_node`_       Top-level module that glues everything together
================= =================================

.. _roc_core: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1core.html
.. _roc_status: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1status.html
.. _roc_address: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1address.html
.. _roc_packet: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1packet.html
.. _roc_rtp: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1rtp.html
.. _roc_rtcp: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1rtcp.html
.. _roc_fec: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1fec.html
.. _roc_sdp: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1sdp.html
.. _roc_audio: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1audio.html
.. _roc_pipeline: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1pipeline.html
.. _roc_ctl: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1ctl.html
.. _roc_netio: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1netio.html
.. _roc_sndio: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1sndio.html
.. _roc_node: https://roc-streaming.org/toolkit/doxygen/namespaceroc_1_1node.html

.. _targets:

Targets
=======

Roc supports multiple platforms and compilers. The major part of the source code is platform-independent. However, there are also parts that depend on specific platform features or optional third-party libraries.

Such platform-dependent code is isolated inside "target" directories. Every target directory corresponds to platform or feature enabled at compile time. When SCons builds the project, it determines target directories to use, depending on the target platform, available third-party libraries, and command-line options.

Every module can have its own target directories. Headers from enabled target directories are added to the include path, and source files from enabled target directories are added to the build.

Currently supported targets are:

===================== ===============================================
target                description
===================== ===============================================
target_pc             Enabled for PC (like server, desktop, laptop)
target_posix          Enabled for a POSIX OS
target_posix_ext      Enabled for a POSIX OS with POSIX extensions
target_posix_pc       Enabled for a POSIX OS on PC
target_gnu            Enabled for GNU-like libc and compiler
target_darwin         Enabled for macOS
target_android        Enabled for Android
target_c11            Enabled for C11 compilers
target_libunwind      Enabled if libunwind is available
target_libatomic_ops  Enabled if libatomic_ops is available
target_libuv          Enabled if libuv is available
target_openfec        Enabled if OpenFEC is available
target_speexdsp       Enabled if SpeexDSP is available
target_sox            Enabled if SoX is available
target_pulseaudio     Enabled if PulseAudio is available
target_nobacktrace    Enabled if no backtrace API is available
target_nodemangle     Enabled if no demangling API is available
===================== ===============================================

Example directory structure employing targets:

::

    roc_core
    ├── target_posix
    │   └── roc_core
    │       ├── ...
    │       ├── mutex.cpp
    │       └── mutex.h
    ├── target_posix_ext
    │   └── roc_core
    │       ├── ...
    │       ├── time.cpp
    │       └── time.h
    ├── target_darwin
    │   └── roc_core
    │       ├── ...
    │       ├── time.cpp
    │       └── time.h
    ├── ...
    ├── array.h
    └── list.h