Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add recording support with Reaper Project generation #2

Merged
merged 3 commits into from
Apr 10, 2019

Conversation

pljones
Copy link
Collaborator

@pljones pljones commented Apr 3, 2019

Includes the following changes

  • Initial .gitignore
    Administrative

  • Fix up warning message

  • Not all Windows file systems are case insensitive
    Bugfixes

  • (Qt5) Use QCoreApplication for headless
    Possible solution to get the application to run as a headless server but it loses the nice history graph, so not ideal.

  • Avoid ESC closing chat
    Because ESC shouldn't close the chat window. Or the main app window.

  • Add console logging support for Windows
    Whilst looking for the headless support, I found this idea for Windows logging. New improved version. This makes far fewer changes.


  • Add recording support with Reaper Project generation
    The main feature!
    • New -r option to enable recording of PCM files and conversion to Reaper RPP with WAV files
    • New -R option to set the directory in which to create recording sessions
      You need to specify the -R option, there's no default... so I guess -r and -R could be combined.
    • New -T option to convert a session directory with PCM files into a Reaper RPP with WAV files
      You can use -T on "failed" sessions, if the -r option captures the PCMs but the RPP converter doesn't run for some reaon. (It was useful during development, maybe less so once things seem stable.)

The recorder is implemented as a new thread with queuing from the main "real time" server thread.

When a new client connects or if its audio format changes (e.g. mono to stereo), a new RIFF WAVE file is started. Each frame of decompressed audio for each client written out as LPCM to the file. When the client disconnects, the RIFF WAVE headers are updated to reflect the file length.

Once all clients disconnect, the session is considered ended and a Reaper RPP file is written.

pljones and others added 3 commits April 3, 2019 18:12
Includes the following changes

* Initial .gitignore
Administrative

* Fix up warning message
* Not all Windows file systems are case insensitive
Bugfixes

* (Qt5) Use QCoreApplication for headless
Possible solution to get the application to run as a headless server but it loses the nice history graph, so not ideal.

* Avoid ESC closing chat
Because ESC shouldn't close the chat window. Or the main app window.

* Add console logging support for Windows
Whilst looking for the headless support, I found this idea for Windows logging.  New improved version.  This makes far fewer changes.

----

* Add recording support with Reaper Project generation
The main feature!
    * New -r option to enable recording of PCM files and conversion to Reaper RPP with WAV files
    * New -R option to set the directory in which to create recording sessions
    You need to specify the -R option, there's no default... so I guess -r and -R could be combined.
    * New -T option to convert a session directory with PCM files into a Reaper RPP with WAV files
    You can use -T on "failed" sessions, if the -r option captures the PCMs but the RPP converter doesn't run for some reaon. (It was useful during development, maybe less so once things seem stable.)

The recorder is implemented as a new thread with queuing from the main "real time" server thread.

When a new client connects or if its audio format changes (e.g. mono to stereo), a new RIFF WAVE file is started.  Each frame of decompressed audio for each client written out as LPCM to the file.  When the client disconnects, the RIFF WAVE headers are updated to reflect the file length.

Once all clients disconnect, the session is considered ended and a Reaper RPP file is written.
@corrados corrados changed the base branch from master to integrate_recorder April 10, 2019 17:32
@corrados corrados merged commit 703b458 into jamulussoftware:integrate_recorder Apr 10, 2019
doloopuntil pushed a commit to doloopuntil/jamulus that referenced this pull request Apr 21, 2020
doloopuntil pushed a commit to doloopuntil/jamulus that referenced this pull request Apr 22, 2020
corrados pushed a commit that referenced this pull request May 10, 2020
bug fix: fixed that Jamulus segfaults when jackd is restarted (Ticket…
corrados pushed a commit that referenced this pull request May 16, 2020
corrados pushed a commit that referenced this pull request May 23, 2020
corrados pushed a commit that referenced this pull request Jun 5, 2020
corrados pushed a commit that referenced this pull request Jun 8, 2020
corrados pushed a commit that referenced this pull request Jun 19, 2020
corrados pushed a commit that referenced this pull request Jul 10, 2020
corrados pushed a commit that referenced this pull request Jul 17, 2020
add the names of the instrument icon creators to the contributors lis…
corrados pushed a commit that referenced this pull request Aug 12, 2020
@gene96817 gene96817 mentioned this pull request Nov 20, 2020
npostavs pushed a commit to npostavs/jamulus that referenced this pull request Feb 11, 2021
Make CJamStreamer::process data parameter a reference
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants