Improve journaling.
This commit is contained in:
parent
0f9d79b3d8
commit
cc39d05c7a
27
Loggable.C
27
Loggable.C
|
@ -129,17 +129,22 @@ log_diff ( char **sa1, char **sa2 )
|
||||||
void
|
void
|
||||||
Loggable::log_start ( void )
|
Loggable::log_start ( void )
|
||||||
{
|
{
|
||||||
// if ( _old_state )
|
if ( ! _old_state )
|
||||||
// log_end();
|
_old_state = log_dump();
|
||||||
if ( _old_state )
|
|
||||||
return;
|
++_nest;
|
||||||
|
|
||||||
_old_state = log_dump();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
Loggable::log_end ( void )
|
Loggable::log_end ( void )
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if ( --_nest > 0 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// assert( _old_state );
|
||||||
|
|
||||||
char **_new_state = log_dump();
|
char **_new_state = log_dump();
|
||||||
|
|
||||||
// if ( _old_state )
|
// if ( _old_state )
|
||||||
|
@ -152,11 +157,21 @@ Loggable::log_end ( void )
|
||||||
log_print( _old_state, _new_state );
|
log_print( _old_state, _new_state );
|
||||||
}
|
}
|
||||||
|
|
||||||
free_sa( _old_state );
|
|
||||||
if ( _new_state )
|
if ( _new_state )
|
||||||
free_sa( _new_state );
|
free_sa( _new_state );
|
||||||
|
|
||||||
|
if ( _old_state )
|
||||||
|
free_sa( _old_state );
|
||||||
|
|
||||||
_old_state = NULL;
|
_old_state = NULL;
|
||||||
|
|
||||||
|
/* if ( _old_state ) */
|
||||||
|
/* { */
|
||||||
|
/* free_sa( _old_state ); */
|
||||||
|
/* _old_state = NULL; */
|
||||||
|
/* } */
|
||||||
|
|
||||||
|
// _old_state = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
39
Loggable.H
39
Loggable.H
|
@ -29,6 +29,7 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
using std::vector;
|
using std::vector;
|
||||||
|
|
||||||
|
class Logger;
|
||||||
class Loggable
|
class Loggable
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -44,6 +45,7 @@ private:
|
||||||
char **_old_state;
|
char **_old_state;
|
||||||
char **_new_state;
|
char **_new_state;
|
||||||
|
|
||||||
|
int _nest;
|
||||||
|
|
||||||
static
|
static
|
||||||
void indent ( void )
|
void indent ( void )
|
||||||
|
@ -89,6 +91,7 @@ public:
|
||||||
{
|
{
|
||||||
_id = ++_log_id;
|
_id = ++_log_id;
|
||||||
_old_state = NULL;
|
_old_state = NULL;
|
||||||
|
_nest = 0;
|
||||||
|
|
||||||
_loggables.push_back( this );
|
_loggables.push_back( this );
|
||||||
}
|
}
|
||||||
|
@ -115,8 +118,44 @@ public:
|
||||||
|
|
||||||
int id ( void ) { return _id; }
|
int id ( void ) { return _id; }
|
||||||
|
|
||||||
|
friend class Logger;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class Logger
|
||||||
|
{
|
||||||
|
|
||||||
|
Loggable *_this;
|
||||||
|
Logger ( ) {}
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
Logger ( Loggable *l ) : _this( l )
|
||||||
|
{
|
||||||
|
_this->log_start();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
~Logger ( )
|
||||||
|
{
|
||||||
|
_this->log_end();
|
||||||
|
}
|
||||||
|
|
||||||
|
void hold ( void )
|
||||||
|
{
|
||||||
|
printf( "hold\n" );
|
||||||
|
_this->_nest++;
|
||||||
|
}
|
||||||
|
|
||||||
|
void release ( void )
|
||||||
|
{
|
||||||
|
printf( "release\n" );
|
||||||
|
_this->_nest--;
|
||||||
|
assert( _this->_nest );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/* #ifndef _LOGGABLE_C */
|
/* #ifndef _LOGGABLE_C */
|
||||||
/* #define log( act, fmt, args... ) log( __CLASS__, act, fmt, ## args ) */
|
/* #define log( act, fmt, args... ) log( __CLASS__, act, fmt, ## args ) */
|
||||||
/* #endif */
|
/* #endif */
|
||||||
|
|
19
Region.C
19
Region.C
|
@ -144,6 +144,7 @@ Region::trim ( enum trim_e t, int X )
|
||||||
int
|
int
|
||||||
Region::handle ( int m )
|
Region::handle ( int m )
|
||||||
{
|
{
|
||||||
|
static bool dragging = false;
|
||||||
|
|
||||||
static int ox, oy;
|
static int ox, oy;
|
||||||
static enum trim_e trimming;
|
static enum trim_e trimming;
|
||||||
|
@ -156,7 +157,8 @@ Region::handle ( int m )
|
||||||
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
log_start();
|
Logger _log( this );
|
||||||
|
//log_start();
|
||||||
|
|
||||||
switch ( m )
|
switch ( m )
|
||||||
{
|
{
|
||||||
|
@ -170,9 +172,11 @@ Region::handle ( int m )
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
trim( trimming = LEFT, X );
|
trim( trimming = LEFT, X );
|
||||||
|
// _log.hold();
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
trim( trimming = RIGHT, X );
|
trim( trimming = RIGHT, X );
|
||||||
|
// _log.hold();
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
{
|
{
|
||||||
|
@ -240,10 +244,19 @@ Region::handle ( int m )
|
||||||
{
|
{
|
||||||
trimming = NO;
|
trimming = NO;
|
||||||
}
|
}
|
||||||
printf( "releasing\n");
|
if ( dragging )
|
||||||
|
_log.release();
|
||||||
|
|
||||||
|
dragging = false;
|
||||||
goto changed;
|
goto changed;
|
||||||
case FL_DRAG:
|
case FL_DRAG:
|
||||||
|
|
||||||
|
if ( ! dragging )
|
||||||
|
{
|
||||||
|
_log.hold();
|
||||||
|
dragging = true;
|
||||||
|
}
|
||||||
|
|
||||||
if ( Fl::event_state() & FL_SHIFT &&
|
if ( Fl::event_state() & FL_SHIFT &&
|
||||||
Fl::event_state() & FL_CTRL )
|
Fl::event_state() & FL_CTRL )
|
||||||
{
|
{
|
||||||
|
@ -307,7 +320,7 @@ Region::handle ( int m )
|
||||||
|
|
||||||
changed:
|
changed:
|
||||||
|
|
||||||
log_end();
|
// log_end();
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,9 +40,17 @@ protected:
|
||||||
|
|
||||||
const char *class_name ( void ) { return "Tempo_Point"; }
|
const char *class_name ( void ) { return "Tempo_Point"; }
|
||||||
|
|
||||||
/* void log_create ( void ) { log( "create", "%lu %f", _offset, _tempo ); } */
|
char ** log_dump ( void )
|
||||||
/* void log_destroy ( void ) { log( "destroy", NULL ); } */
|
{
|
||||||
/* void log_move ( void ) { log( "move", "%lu", _offset ); } */
|
char **sa = (char**)malloc( sizeof( char* ) * 3 );
|
||||||
|
|
||||||
|
sa[2] = NULL;
|
||||||
|
|
||||||
|
asprintf( &sa[0], ":x %lu", _offset );
|
||||||
|
asprintf( &sa[1], ":tempo %f", _tempo );
|
||||||
|
|
||||||
|
return sa;
|
||||||
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|
15
Time_Point.H
15
Time_Point.H
|
@ -54,9 +54,18 @@ protected:
|
||||||
|
|
||||||
const char *class_name ( void ) { return "Time_Point"; }
|
const char *class_name ( void ) { return "Time_Point"; }
|
||||||
|
|
||||||
/* void log_create ( void ) { log( "create", "%lu %d %d", _offset, _time.beats_per_bar, _time.note_type ); } */
|
char ** log_dump ( void )
|
||||||
/* void log_destroy ( void ) { log( "destroy", NULL ); } */
|
{
|
||||||
/* void log_move ( void ) { log( "move", "%lu", _offset ); } */
|
char **sa = (char**)malloc( sizeof( char* ) * 4 );
|
||||||
|
|
||||||
|
sa[3] = NULL;
|
||||||
|
|
||||||
|
asprintf( &sa[0], ":x %lu", _offset );
|
||||||
|
asprintf( &sa[1], ":beats_per_bar %d", _time.beats_per_bar );
|
||||||
|
asprintf( &sa[2], ":beat_type %d", _time.note_type );
|
||||||
|
|
||||||
|
return sa;
|
||||||
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|
|
@ -179,7 +179,7 @@ struct Timeline : public Fl_Group
|
||||||
|
|
||||||
if ( damage() & FL_DAMAGE_SCROLL )
|
if ( damage() & FL_DAMAGE_SCROLL )
|
||||||
{
|
{
|
||||||
printf( "doing scroll\n" );
|
// printf( "doing scroll\n" );
|
||||||
int dx = ts_to_x( _old_position ) - ts_to_x( xoffset );
|
int dx = ts_to_x( _old_position ) - ts_to_x( xoffset );
|
||||||
|
|
||||||
fl_scroll( X, tracks->y(), W, tracks->h(), dx, 0, draw_clip, this );
|
fl_scroll( X, tracks->y(), W, tracks->h(), dx, 0, draw_clip, this );
|
||||||
|
|
4
Track.C
4
Track.C
|
@ -88,7 +88,7 @@ Track::event_widget ( void )
|
||||||
void
|
void
|
||||||
Track::add ( Track_Widget *r )
|
Track::add ( Track_Widget *r )
|
||||||
{
|
{
|
||||||
log_start();
|
Logger _log( this );
|
||||||
|
|
||||||
if ( r->track() )
|
if ( r->track() )
|
||||||
{
|
{
|
||||||
|
@ -99,8 +99,6 @@ Track::add ( Track_Widget *r )
|
||||||
_widgets.push_back( r );
|
_widgets.push_back( r );
|
||||||
|
|
||||||
r->track( this );
|
r->track( this );
|
||||||
|
|
||||||
log_end();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* snap /r/ to nearest edge */
|
/* snap /r/ to nearest edge */
|
||||||
|
|
|
@ -32,14 +32,6 @@ protected:
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
char ** log_dump ( void )
|
|
||||||
{
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
void log_change ( void )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
Fl_Align align ( void ) const { return FL_ALIGN_RIGHT; }
|
Fl_Align align ( void ) const { return FL_ALIGN_RIGHT; }
|
||||||
|
|
|
@ -199,11 +199,13 @@ public:
|
||||||
handle ( int m )
|
handle ( int m )
|
||||||
{
|
{
|
||||||
static int ox, oy;
|
static int ox, oy;
|
||||||
static bool moved = false;
|
static bool dragging = false;
|
||||||
|
|
||||||
int X = Fl::event_x();
|
int X = Fl::event_x();
|
||||||
int Y = Fl::event_y();
|
int Y = Fl::event_y();
|
||||||
|
|
||||||
|
Logger _log( this );
|
||||||
|
|
||||||
switch ( m )
|
switch ( m )
|
||||||
{
|
{
|
||||||
case FL_ENTER:
|
case FL_ENTER:
|
||||||
|
@ -230,16 +232,19 @@ public:
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
case FL_RELEASE:
|
case FL_RELEASE:
|
||||||
if ( moved )
|
if ( dragging )
|
||||||
{
|
_log.release();
|
||||||
// log_move();
|
dragging = false;
|
||||||
moved = false;
|
|
||||||
}
|
|
||||||
// dump();
|
|
||||||
fl_cursor( FL_CURSOR_DEFAULT );
|
fl_cursor( FL_CURSOR_DEFAULT );
|
||||||
return 1;
|
return 1;
|
||||||
case FL_DRAG:
|
case FL_DRAG:
|
||||||
{
|
{
|
||||||
|
if ( ! dragging )
|
||||||
|
{
|
||||||
|
dragging = true;
|
||||||
|
_log.hold();
|
||||||
|
}
|
||||||
|
|
||||||
redraw();
|
redraw();
|
||||||
|
|
||||||
if ( ox + X >= _track->x() )
|
if ( ox + X >= _track->x() )
|
||||||
|
@ -249,8 +254,6 @@ public:
|
||||||
_offset = timeline->x_to_ts( nx ) + timeline->xoffset;
|
_offset = timeline->x_to_ts( nx ) + timeline->xoffset;
|
||||||
|
|
||||||
_track->snap( this );
|
_track->snap( this );
|
||||||
|
|
||||||
moved = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// _track->redraw();
|
// _track->redraw();
|
||||||
|
|
Loading…
Reference in New Issue