Commit d8f56d10 authored by claes's avatar claes

Reopening and closing of unfinished action

parent c21a24bd
/* /*
* Proview $Id: ge_graph_journal.cpp,v 1.2 2008-05-14 06:51:51 claes Exp $ * Proview $Id: ge_graph_journal.cpp,v 1.3 2008-05-23 07:48:16 claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB. * Copyright (C) 2005 SSAB Oxelsund AB.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
...@@ -194,14 +194,6 @@ int GraphJournal::store( journal_eAction action, grow_tObject o) ...@@ -194,14 +194,6 @@ int GraphJournal::store( journal_eAction action, grow_tObject o)
{ {
static grow_tObject lock_object = 0; static grow_tObject lock_object = 0;
if ( status == journal_eStatus_AnteProperties &&
!((action == journal_eAction_PostPropertiesObject ||
action == journal_eAction_PostPropertiesSelect)
&& o == lock_object)) {
printf( "Journalfile blocked\n");
return 0;
}
switch ( action) { switch ( action) {
case journal_eAction_AntePropertiesSelect: case journal_eAction_AntePropertiesSelect:
case journal_eAction_PostPropertiesSelect: case journal_eAction_PostPropertiesSelect:
...@@ -213,13 +205,64 @@ int GraphJournal::store( journal_eAction action, grow_tObject o) ...@@ -213,13 +205,64 @@ int GraphJournal::store( journal_eAction action, grow_tObject o)
int sel_count; int sel_count;
grow_GetSelectList( graph->grow->ctx, &sel_list, &sel_count); grow_GetSelectList( graph->grow->ctx, &sel_list, &sel_count);
if ( sel_count == 0) if ( sel_count == 0) {
return GE__SUCCESS; return GE__SUCCESS;
}
break; break;
} }
default: ; default: ;
} }
if ( status == journal_eStatus_AnteProperties &&
!((action == journal_eAction_PostPropertiesObject ||
action == journal_eAction_PostPropertiesSelect)
&& o == lock_object)) {
if ( debug)
printf( "Unfinished action, forced close\n");
// Close prevoius action
poslist[current_idx].redo_pos = fp.tellp();
fp << journal_cTag_Redo << " " << journal_eAction_No << " " << status << " " << current_idx << endl;
current_idx++;
status = journal_eStatus_Stored;
lock_object = 0;
if ( debug)
printf( "Store(F)x: %3d list: %3d undo: %10d redo: %10d\n", current_idx-1, poslist.size() - 1,
(int)poslist[poslist.size()-1].undo_pos, (int)poslist[poslist.size()-1].redo_pos);
}
if ( (status != journal_eStatus_AnteProperties ||
(status == journal_eStatus_AnteProperties && lock_object != o)) &&
(action == journal_eAction_PostPropertiesObject ||
action == journal_eAction_PostPropertiesSelect)) {
if ( debug)
printf( "Interrupted action, reopening\n");
// Open prevoius action
JournalPos up;
switch ( status) {
case journal_eStatus_Stored:
case journal_eStatus_Redo:
case journal_eStatus_Undo:
fp.seekp( poslist[current_idx-1].end_pos);
break;
default: ;
}
while ( (int)poslist.size() > current_idx) {
if ( debug)
printf( "Remove %d\n", poslist.size()-1);
poslist.pop_back();
}
up.undo_pos = fp.tellp();
poslist.push_back(up);
fp << journal_cTag_Undo << " " << journal_eAction_No << " " << status << " " << current_idx << endl;
status = journal_eStatus_AnteProperties;
}
if ( action == journal_eAction_AntePropertiesSelect || if ( action == journal_eAction_AntePropertiesSelect ||
action == journal_eAction_AntePropertiesObject || action == journal_eAction_AntePropertiesObject ||
action == journal_eAction_AnteGroupSelect || action == journal_eAction_AnteGroupSelect ||
...@@ -490,6 +533,8 @@ int GraphJournal::undo() ...@@ -490,6 +533,8 @@ int GraphJournal::undo()
case journal_eAction_PostRename: case journal_eAction_PostRename:
undo_rename(); undo_rename();
break; break;
case journal_eAction_No:
break;
default: ; default: ;
} }
...@@ -565,6 +610,8 @@ int GraphJournal::redo() ...@@ -565,6 +610,8 @@ int GraphJournal::redo()
case journal_eAction_PostRename: case journal_eAction_PostRename:
redo_rename(); redo_rename();
break; break;
case journal_eAction_No:
break;
default: ; default: ;
} }
...@@ -835,8 +882,10 @@ int GraphJournal::undo_properties_object() ...@@ -835,8 +882,10 @@ int GraphJournal::undo_properties_object()
fp.getline( name, sizeof(name)); fp.getline( name, sizeof(name));
sts = grow_FindObjectByName( graph->grow->ctx, name, &o); sts = grow_FindObjectByName( graph->grow->ctx, name, &o);
if ( ODD(sts)) if ( EVEN(sts))
grow_ObjectOpen( o, (ifstream&)fp); return GE__SUCCESS;
grow_ObjectOpen( o, (ifstream&)fp);
fp.get(); fp.get();
fp.getline( line, sizeof(line)); fp.getline( line, sizeof(line));
...@@ -1658,6 +1707,8 @@ int GraphJournal::restore( char *fname) ...@@ -1658,6 +1707,8 @@ int GraphJournal::restore( char *fname)
case journal_eAction_PostRename: case journal_eAction_PostRename:
redo_rename(); redo_rename();
break; break;
case journal_eAction_No:
break;
default: ; default: ;
} }
nr = 0; nr = 0;
......
/* /*
* Proview $Id: ge_graph_journal.h,v 1.1 2008-05-13 13:59:02 claes Exp $ * Proview $Id: ge_graph_journal.h,v 1.2 2008-05-23 07:48:16 claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB. * Copyright (C) 2005 SSAB Oxelsund AB.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
...@@ -55,7 +55,8 @@ typedef enum { ...@@ -55,7 +55,8 @@ typedef enum {
journal_eAction_AntePaste, journal_eAction_AntePaste,
journal_eAction_PostPaste, journal_eAction_PostPaste,
journal_eAction_AnteRename, journal_eAction_AnteRename,
journal_eAction_PostRename journal_eAction_PostRename,
journal_eAction_No
} journal_eAction; } journal_eAction;
typedef enum { typedef enum {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment