Commit 0adb7804 authored by Claes Sjofors's avatar Claes Sjofors

Merge branch 'master' of pwrcvs:/data1/git/pwr

parents ee2dae07 dede565c
...@@ -651,12 +651,75 @@ void WFoe::delete_subwindow_ok_cb( void *ctx, void *data) ...@@ -651,12 +651,75 @@ void WFoe::delete_subwindow_ok_cb( void *ctx, void *data)
foe->gre->delete_selected(); foe->gre->delete_selected();
} }
void WFoe::delete_subwindows_ok_cb( void *ctx, void *data)
{
WFoe *foe = (WFoe *) ctx;
vldh_t_node *nodelist;
unsigned long node_count;
pwr_tStatus sts, rsts;
pwr_tOid child, nextchild;
vldh_t_wind wind = foe->gre->wind;
unsigned long wind_count;
vldh_t_wind *windlist;
vldh_t_wind *wind_ptr;
int i;
foe->gre->get_selnodes( &node_count, &nodelist);
for ( unsigned int j = 0; j < node_count; j++) {
vldh_t_node node = nodelist[j];
if ( node->ln.subwindow != 0 ) {
/* Check that subwindow is not open */
sts = vldh_get_wind_subwindows( foe->gre->wind,
&wind_count, &windlist);
if( EVEN(sts)) { foe->error_msg( sts); return;}
for ( sts = ldh_GetChild( wind->hw.ldhses, node->ln.oid, &child);
ODD(sts);
sts = ldh_GetNextSibling( wind->hw.ldhses, child, &child)) {
wind_ptr = windlist;
for ( i = 0; i < (int)wind_count; i++) {
if ( cdh_ObjidIsEqual( (*wind_ptr)->lw.oid, child)) {
foe->wow->DisplayError( "Window open",
"Subwindow is open\nClose subwindow first");
free((char *) windlist);
free( (char *)nodelist);
return;
}
wind_ptr++;
}
}
if ( wind_count > 0) free((char *) windlist);
}
}
for ( unsigned int j = 0; j < node_count; j++) {
vldh_t_node node = nodelist[j];
if ( node->ln.subwindow != 0 ) {
for ( sts = ldh_GetChild( wind->hw.ldhses, node->ln.oid, &child);
ODD(sts);
child = nextchild) {
sts = ldh_GetNextSibling( wind->hw.ldhses, child, &nextchild);
rsts = ldh_DeleteObjectTree( wind->hw.ldhses, child, 0);
if ( EVEN(rsts)) { foe->error_msg( rsts); return; }
}
node->ln.subwindow = 0;
}
}
foe->gre->delete_selected();
free( (char *)nodelist);
}
void WFoe::activate_delete() void WFoe::activate_delete()
{ {
unsigned long node_count; unsigned long node_count;
vldh_t_node *nodelist; vldh_t_node *nodelist;
vldh_t_node *node_ptr; vldh_t_node *node_ptr;
int i, subwind_found; int i;
if ( msg_label_id != 0 ) message( ""); if ( msg_label_id != 0 ) message( "");
...@@ -678,25 +741,29 @@ void WFoe::activate_delete() ...@@ -678,25 +741,29 @@ void WFoe::activate_delete()
} }
node_ptr = nodelist; node_ptr = nodelist;
subwind_found = FALSE; int subwind_cnt = 0;
for( i = 0; i < (int)node_count; i++) { for( i = 0; i < (int)node_count; i++) {
if ( (*node_ptr)->ln.subwindow != 0 ) { if ( (*node_ptr)->ln.subwindow != 0 )
subwind_found = TRUE; subwind_cnt++;
break;
}
node_ptr++; node_ptr++;
} }
if ( node_count > 0) free((char *) nodelist); if ( node_count > 0) free((char *) nodelist);
if ( subwind_found ) {
wow->DisplayError( "Subwindow found", if ( subwind_cnt ) {
"Subwindow found\nDelete objects with subwindows separately"); char msg[200];
BEEP; sprintf( msg,
} "%d objects have subwindows\n Do you want to delete the subwindows?",
else { subwind_cnt);
/* Delete selected nodes */ wow->DisplayQuestion( this,
gre->delete_selected(); "Delete subwindows", msg,
delete_subwindows_ok_cb, 0, 0);
popupmenu_node = 0; popupmenu_node = 0;
return;
} }
/* Delete selected nodes */
gre->delete_selected();
popupmenu_node = 0;
} }
void WFoe::activate_createobject( float x, float y) void WFoe::activate_createobject( float x, float y)
......
...@@ -348,6 +348,7 @@ class WFoe : public WUtility { ...@@ -348,6 +348,7 @@ class WFoe : public WUtility {
static void edit_exit_save( WFoe *foe); static void edit_exit_save( WFoe *foe);
static void edit_exit_nosave( WFoe *foe); static void edit_exit_nosave( WFoe *foe);
static void delete_subwindow_ok_cb( void *ctx, void *data); static void delete_subwindow_ok_cb( void *ctx, void *data);
static void delete_subwindows_ok_cb( void *ctx, void *data);
static void delete_ok_cb( void *ctx, void *data); static void delete_ok_cb( void *ctx, void *data);
static void exit_save( WFoe *foe); static void exit_save( WFoe *foe);
......
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