Multimedia processing graphs
Find a file
Wim Taymans b6239fb1ab node: improve scheduling
Don't use the graph scheduler anymore, instead use a more simple
method using the nodes directly. The idea is that when a node
pulls, we walk the graph backwards and collect nodes to process.
Searching stops on a node with output. Then we process the nodes,
each one in turn calling process on the next one when all dependend
nodes are processed. This is quite similar to jack2 and with some
modifications seems to work well for more complicated input/output
patterns.
Set per mix input/output buffers.
Implement mixing in the audio-dsp node.
remote: handle mix ports a little better
2018-04-03 16:29:36 +02:00
doc update docs 2017-09-05 13:35:25 +02:00
man man: update man pages 2017-09-19 10:19:53 +02:00
pkgconfig Add example to play sine wave 2017-09-07 10:22:32 +02:00
po Update POTFILES.in 2017-09-19 17:42:12 +02:00
spa alsa: small cleanups 2018-04-03 16:29:36 +02:00
src node: improve scheduling 2018-04-03 16:29:36 +02:00
.gitignore pinos -> pipewire 2017-05-23 19:15:33 +02:00
_config.yml Set theme jekyll-theme-slate 2017-09-04 19:55:46 +02:00
autogen.sh Add beginnings of jack module 2017-06-26 13:04:47 +02:00
config.h.meson config.h: add version numbers 2018-01-30 14:49:45 +01:00
git-version-gen Initial commit 2015-04-16 16:58:33 +02:00
GPL Initial commit 2015-04-16 16:58:33 +02:00
LGPL Initial commit 2015-04-16 16:58:33 +02:00
LICENSE pinos -> pipewire 2017-05-23 19:15:33 +02:00
Makefile.in Makefile.in: use right build command 2017-09-19 16:04:41 +02:00
meson.build Release 0.1.9 2018-02-27 13:34:22 +01:00
meson_options.txt make gstreamer elements optional 2017-11-13 20:08:29 +01:00
NEWS Add some NEWS 2018-02-27 14:00:19 +01:00
PROTOCOL Initial commit 2015-04-16 16:58:33 +02:00
README readme: add section on building with make or meson 2017-10-19 22:45:19 +02:00

PipeWire
--------

PipeWire is a server and user space API to deal with multimedia
pipelines. This includes:

  - Making available sources of video (such as from a capture devices or
       application provided streams) and multiplexing this with
       clients.
  - Accessing sources of video for consumption.
  - Generating graphs for audio and video processing.

Nodes in the graph can be implemented as separate processes,
communicating with sockets and exchanging multimedia content using fd
passing.

Building
--------

Pipewire uses the Meson and Ninja build system to compile. If you're not
familiar with these tools, the included "autogen.sh" script will
automatically run the correct meson/ninja commands, and output a Makefile.
It follows that there are two methods to build Pipewire, however both rely
on Meson and Ninja to actually perform the compilation:

$ ./autogen.sh
$ make

or the Meson/Ninja native method:

$ meson build
$ cd build
$ ninja