update from Merge

This commit is contained in:
Laptop 2015-06-26 17:00:04 -04:00
parent 4ff00bfb95
commit 000261ace5
5 changed files with 74 additions and 18 deletions

View file

@ -4,9 +4,16 @@
#include <math.h>
#include <ctype.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include "parameters.h"
#include "hook.h"
extern unsigned char OutLEDs[MAX_LEDS*3];
extern int UsedLEDs;
struct RecorderPlugin
{
int is_recording;
@ -29,11 +36,12 @@ void StopRecording( struct RecorderPlugin * rp )
rp->TimeSinceStart = 0;
rp->DunBoop = 0;
fclose( rp->fRec );
fclose( rp->fPlay );
if( rp->fRec ) fclose( rp->fRec );
if( rp->fPlay) fclose( rp->fPlay );
rp->is_recording = 0;
rp->fRec = 0;
rp->fPlay = 0;
printf( "Stopped.\n" );
}
void StartRecording( struct RecorderPlugin * rp )
@ -44,6 +52,8 @@ void StartRecording( struct RecorderPlugin * rp )
rp->DunBoop = 0;
rp->is_recording = 1;
printf( "Starting Recording: /%s/%s/\n", rp->In_Filename, rp->Out_Filename );
if( rp->In_Filename[0] == 0 )
{
//Nothing
@ -56,6 +66,7 @@ void StartRecording( struct RecorderPlugin * rp )
{
fprintf( stderr, "Warning: Could not play filename: %s\n", rp->In_Filename );
}
printf( "Play file opened.\n" );
}
if( rp->Out_Filename[0] == 0 )
@ -65,10 +76,11 @@ void StartRecording( struct RecorderPlugin * rp )
}
else
{
struct stat buf;
char cts[1024];
int i;
for( i = 0; i < 999; i++ )
{
char cts[1024];
if( i == 0 )
{
snprintf( cts, 1023, "%s", rp->Out_Filename );
@ -78,9 +90,17 @@ void StartRecording( struct RecorderPlugin * rp )
snprintf( cts, 1023, "%s.%03d", rp->Out_Filename, i );
}
rp->fRec = fopen( cts, "wb" );
if( rp->fRec ) break;
if( stat( cts, &buf ) != 0 )
break;
}
printf( "Found rec file %s\n", cts );
rp->fRec = fopen( cts, "wb" );
if( !rp->fRec )
{
fprintf( stderr, "Error: cannot start recording file \"%s\"\n", cts );
return;
}
printf( "Recording...\n" );
}
}
@ -88,6 +108,7 @@ void StartRecording( struct RecorderPlugin * rp )
static void RecordEvent(void * v, int samples, float * samps, int channel_ct)
{
struct RecorderPlugin * rp = (struct RecorderPlugin*)v;
if( !rp->fRec || !rp->is_recording ) return;
if( rp->DunBoop || !rp->fPlay )
@ -105,15 +126,20 @@ static void PlaybackEvent(void * v, int samples, float * samps, int channel_ct)
struct RecorderPlugin * rp = (struct RecorderPlugin*)v;
if( !rp->fPlay ) return;
int r = fread( samps, channel_ct * sizeof( float ), samples, rp->fPlay );
if( r != samples )
{
StopRecording( rp );
}
rp->TimeSinceStart += samples;
if( rp->TimeSinceStart < rp->BypassLength )
{
int r = fread( samps, channel_ct * sizeof( float ), samples, rp->fPlay );
if( r != samples )
{
StopRecording( rp );
}
if( rp->is_recording )
force_white = 1;
else
force_white = 0;
rp->TimeSinceStart += samples;
if( rp->TimeSinceStart > rp->BypassLength )
{
rp->DunBoop = 1;
@ -127,6 +153,10 @@ static void PlaybackEvent(void * v, int samples, float * samps, int channel_ct)
}
}
}
else
{
force_white = 0;
}
}
static void MKeyEvent( void * v, int keycode, int down )
@ -146,7 +176,18 @@ static void DPOUpdate(void * id, struct NoteFinder*nf)
static void DPOParams(void * id )
{
struct RecorderPlugin * d = (struct RecorderPlugin*)id;
d->is_recording = 0;
d->fRec = 0;
d->fPlay = 0;
d->DunBoop = 0;
d->TimeSinceStart = 0;
memset( d->In_Filename, 0, PARAM_BUFF ); RegisterValue( "player_filename", PABUFFER, d->In_Filename, PARAM_BUFF );
memset( d->Out_Filename, 0, PARAM_BUFF ); RegisterValue( "recorder_filename", PABUFFER, d->Out_Filename, PARAM_BUFF );
d->sps = 0; RegisterValue( "samplerate", PAINT, &d->sps, sizeof( d->sps ) );
d->BypassLength = 0; RegisterValue( "recorder_bypass", PAINT, &d->BypassLength, sizeof( d->BypassLength ) );
}
static struct DriverInstances * RecorderPlugin(const char * parameters)

4
hook.c
View file

@ -25,6 +25,7 @@ void HookKeyEvent( void (*KeyE)( void * v, int key, int down ), void * v )
{
KeyEvents[i].KeyE = KeyE;
KeyEvents[i].v = v;
break;
}
}
}
@ -54,6 +55,7 @@ struct SoundEvent
void (*SoundE)( void * v, int samples, float * samps, int channel_ct );
void * v;
};
struct SoundEvent SoundEvents[2][MAX_SOUND_EVENTS];
@ -64,7 +66,6 @@ void SoundEventHappened( int samples, float * samps, int is_out, int channel_ct
{
if( SoundEvents[is_out][i].SoundE )
{
printf( "%d\n", i );
SoundEvents[is_out][i].SoundE( SoundEvents[is_out][i].v, samples, samps, channel_ct );
}
}
@ -79,6 +80,7 @@ void HookSoundInEvent( void (*SoundE)( void * v, int samples, float * samps, int
{
SoundEvents[is_out][i].SoundE = SoundE;
SoundEvents[is_out][i].v = v;
break;
}
}
}

21
main.c
View file

@ -123,11 +123,13 @@ void SoundCB( float * out, float * in, int samplesr, int * samplesp, struct Soun
else
{
float f = in[i*channelin+sample_channel];
if( f > -1 && f < 1 )
{
if( f > 1 || f < -1 )
{
f = (f>0)?1:-1;
}
//printf( "Sound fault B %d/%d\n", i, samplesr );
sound[soundhead] = f;
soundhead = (soundhead+1)%SOUNDCBSIZE;
@ -135,8 +137,8 @@ void SoundCB( float * out, float * in, int samplesr, int * samplesp, struct Soun
}
}
SoundEventHappened( samplesr, in, channelin, 0 );
SoundEventHappened( samplesr, out, sd->channelsPlay, 1 );
SoundEventHappened( samplesr, in, 0, channelin );
SoundEventHappened( samplesr, out, 1, sd->channelsPlay );
*samplesp = samplesr;
}
@ -334,13 +336,24 @@ int main(int argc, char ** argv)
RunNoteFinder( nf, sound, (soundhead-1+SOUNDCBSIZE)%SOUNDCBSIZE, SOUNDCBSIZE );
//Done all ColorChord work.
VisTimeStart = OGGetAbsoluteTime();
for( i = 0; i < MAX_OUT_DRIVERS; i++ )
{
if( force_white )
{
memset( OutLEDs, 0x7f, MAX_LEDS*3 );
}
if( outdriver[i] )
outdriver[i]->Func( outdriver[i]->id, nf );
}
VisTimeEnd = OGGetAbsoluteTime();
if( !headless )
{
//Handle outputs.

View file

@ -5,7 +5,7 @@
#include <stdio.h>
#include <stdlib.h>
int force_white = 0;
unsigned char OutLEDs[MAX_LEDS*3];
int UsedLEDs;

View file

@ -10,7 +10,7 @@ struct NoteFinder;
#define MAX_LEDS 32678
extern int force_white;
extern unsigned char OutLEDs[MAX_LEDS*3];
extern int UsedLEDs;