campo-sirio/cb5/r4group.c
alex a0f5e0898b This commit was generated by cvs2svn to compensate for changes in r975,
which included commits to RCS files with non-trunk default branches.

git-svn-id: svn://10.65.10.50/trunk@976 c028cbd2-c16b-5b4b-a496-9718f37d4682
1995-02-06 15:33:45 +00:00

634 lines
14 KiB
C
Executable File

/* r4group.c (c)Copyright Sequiter Software Inc., 1991-1994. All rights reserved. */
#include "d4all.h"
/************************************************************
*
* Function: group4create_group
*
* PARAMETERS:
* REPORT4* report - pointer to the current report
* char* name - name for the new group
* char* reset_expression - character source for the group reset
*
* DESCRIPTION: low level function for group creation
*
* RETURNS: pointer to a GROUP4 structure on success, NULL on failure
*
* By: Raymond Cypher
*
* HISTORY:
*
*/
GROUP4 * group4create_group( REPORT4 *report, char *name, char *reset_expression )
{
GROUP4 *group, *group_on;
EXPR4 *expr = NULL;
if( !report )
{
return NULL;
}
/* check that the name is not a duplicate */
if( name && name[0] != '\0' )
{
group_on=0;
group_on=(GROUP4 *)l4next(&report->groups,group_on);
while(group_on)
{
if( strcmp( group_on->group_label, name ) == 0 )
{
e4describe( report->code_base, e4group_create, E4_REP_DUPGNAME, 0, 0 );
return NULL;
}
group_on=(GROUP4 *)l4next(&report->groups,group_on);
}
}
/* if there is a reset expression make sure that it is valid */
if( reset_expression && reset_expression[0] != '\0' )
{
expr = expr4parse( report->relate->data, reset_expression );
if( ! expr )
{
e4describe( report->code_base, e4group_create, E4_REP_GEXPR, 0, 0 );
return NULL;
}
}
/* allocate the GROUP4 structure */
group = (GROUP4 *) u4alloc_free( report->code_base, sizeof(GROUP4) ) ;
if ( group == 0 )
{
/* error unable to create group */
return NULL;
}
/* reset the header and footer area lists */
memset( &group->header_areas, 0, sizeof(group->header_areas) );
memset( &group->footer_areas, 0, sizeof(group->footer_areas) );
/* set the reset expression */
group->reset_expression = expr;
/* set the group name */
if( name && name[0] != '\0' )
u4ncpy( group->group_label, name, sizeof( group->group_label ) ) ;
else
{
#ifdef S4WINDOWS
wsprintf( group->group_label, "Group %d", report->groups.n_link );
#else
sprintf( group->group_label, "Group %d", report->groups.n_link );
#endif
}
group->report = report ;
return group;
}
/************************************************************
*
* Function: group4create_title_summary()
*
* PARAMETERS: REPORT4* report - report to create a title/summary group for
*
* DESCRIPTION: creates a title/summary group for the report, unlike
* the page header/footer group the title summary is maintained as part
* of the overall group list. It is the first group in the list.
* This function is automatically called in report4init()
*
* RETURNS: pointer to GROUP4 on success, NULL on failure
*
* By: Raymond Cypher
*
* HISTORY:
*
*/
GROUP4 * S4FUNCTION group4create_title_summary( REPORT4 *report )
{
GROUP4 *group, *group_on;
#ifdef S4GERMAN
group = group4create_group( report, "Titel/SchluB", NULL );
#else
group = group4create_group( report, "Title/Summary", NULL );
#endif
if( !group )
return NULL;
group_on = (GROUP4 *)l4first( &report->groups );
if( !group_on )
l4add( &report->groups, group );
else
l4add_before( &report->groups, group_on, group );
group->title_summary = 1;
report->title_summary = group;
return group;
}
/************************************************************
*
* Function: group4create_pgheader_pgfooter()
*
* PARAMETERS: REPORT4* report - pointer to the current report
*
* DESCRIPTION: creates a page header/footer group for the report.
* this group is not kept in the reports group list. This fctn.
* is called by report4init()
*
* RETURNS: GROUP4 pointer on success, NULL on failure
*
* By: Raymond Cypher
*
* HISTORY:
*
*/
GROUP4 * S4FUNCTION group4create_pgheader_pgfooter( REPORT4 *report )
{
GROUP4 *group;
#ifdef S4GERMAN
group = group4create_group( report, "Seintenkopf/-fuB", NULL );
#else
group = group4create_group( report, "Pg Header/Footer", NULL );
#endif
if( !group )
return NULL;
group->header_footer = 1;
report->page_header_footer = group;
return group;
}
/************************************************************
*
* Function: group4create()
*
* PARAMETERS:
*
* DESCRIPTION: SEE the CR MANUAL
*
* RETURNS:
*
* By: Raymond Cypher
*
* HISTORY:
*
*/
GROUP4 * S4FUNCTION group4create( REPORT4 *r4, char *name, char *reset_expression )
{
GROUP4 *g4group, *group_on ;
int i ;
if( r4 == NULL )
{
/*error message; */
return NULL;
}
/* call the low level group create fctn */
g4group = group4create_group( r4, name, reset_expression );
if( !g4group )
return NULL;
/* the group is always added immediately after the title summary, thus
becoming the reports outermost group */
group_on = (PGROUP4)l4first( &r4->groups );
l4add_after( &r4->groups, group_on, g4group ) ;
/* set the position of each group, positioning runs reverse to the order
of the list. So the last group on the list will be group 1 (usually the
report body) and the title/summary will be the last group, even though it
is first on the list */
i = 1;
group_on = (GROUP4 *)l4last( &r4->groups );
while(group_on)
{
group_on->position = i ;
group_on=(GROUP4 *)l4prev(&r4->groups,group_on);
i++;
}
return g4group ;
}
/************************************************************
*
* Function: group4free()
*
* PARAMETERS: GROUP4* group - pointer to the group to be freed
*
* DESCRIPTION: SEE THE MANUAL
*
* RETURNS: none
*
* By: Raymond Cypher
*
* HISTORY:
*
*/
void S4FUNCTION group4free( GROUP4 *group )
{
AREA4 *area_on;
/* free the reset expression */
if( group->reset_expression )
expr4free( group->reset_expression );
/* free the stored reset value */
if( group->last_reset_value )
u4free( group->last_reset_value );
/* if in windows delete the info windows for the group header and footer,
these are the little windows that display info on the currently selected
area, etc. */
#ifdef S4WINDOWS
if( group->header_info_hWnd )
{
DestroyWindow( group->header_info_hWnd );
group->header_info_hWnd = 0;
}
if( group->footer_info_hWnd )
{
DestroyWindow( group->footer_info_hWnd );
group->footer_info_hWnd = 0;
}
#endif
/* free the header areas */
while( (area_on = (AREA4 *) l4first( &group->header_areas )) != NULL)
{
area4free( area_on );
}
/* free the footer areas */
while( (area_on = (AREA4 *) l4first( &group->footer_areas )) != NULL)
{
area4free( area_on );
}
/* remove from the reports group list */
if( group != group->report->page_header_footer )
l4remove( &group->report->groups, group );
/* free the GROUP4 structure */
u4free( group );
}
/************************************************************
*
* Function: group4positionSet()
*
* PARAMETERS: GROUP4* group - group to change position of
* int position - new position for the group
*
* DESCRIPTION: SEE THE MANUAL
*
* RETURNS: none
*
* By: Raymond Cypher
*
* HISTORY:
*
*/
void S4FUNCTION group4positionSet( GROUP4 *group, int position )
{
GROUP4 *group_on;
REPORT4 *report;
int i;
#ifdef S4DEBUG
if( group == NULL || position <= 0 )
{
if( group && position < 0 )
e4describe( group->report->code_base, e4parm, E4_REP_GPOS, 0, 0 );
return;
}
#endif
/* cannot change the position of the title/summary or page header/footer */
if( group->header_footer || group->title_summary )
return;
report = group->report;
/* position cannot be greater than the number of user defined groups */
if( position > (report->groups.n_link-1) )
position = report->groups.n_link - 1;
/* remove the group from the list */
l4remove( &report->groups, group );
/* redo the position numbering of the groups still in the list */
i = 1;
group_on = (GROUP4 *)l4last( &report->groups );
while( group_on )
{
group_on->position = i;
i++;
group_on = (GROUP4 *)l4prev( &report->groups, group_on );
}
/* start at the top of the list, which is the last positioned group. We
don't count the title/summary */
group_on = (GROUP4 *)l4first( &report->groups );
if( group_on->title_summary )
group_on = (GROUP4 *)l4next( &report->groups, group_on );
/* if there are no other groups or the position is 1 add to the end of the
list */
if( position == 1 || !group_on )
l4add( &report->groups, group );
else
{
/* starting at the bottom of the list (first group) find where to insert
the repositioned group */
group_on = (PGROUP4)l4last( &report->groups );
while( group_on )
{
if( position <= group_on->position )
{
l4add_after( &report->groups, group_on, group );
group_on = NULL;
}
else
group_on = (PGROUP4)l4prev( &report->groups, group_on );
}
}
/* redo the position members */
i = 1;
group_on = (GROUP4 *)l4last( &report->groups );
while( group_on )
{
group_on->position = i;
i++;
group_on = (GROUP4 *)l4prev( &report->groups, group_on );
}
}
/* SEE THE CODEREPORTER MANUAL */
int S4FUNCTION group4swapHeader( PGROUP4 group, int swap_header )
{
int temp;
if( !group || swap_header < 0 )
{
if( group && swap_header < 0 )
e4describe( group->report->code_base, e4parm, E4_REP_SWPHDR, 0, 0 );
return -1;
}
temp = group->swap_header;
group->swap_header = swap_header;
return temp;
}
/* SEE THE CODEREPORTER MANUAL */
int S4FUNCTION group4swapFooter( PGROUP4 group, int swap_footer )
{
int temp;
if( !group || swap_footer < 0 )
{
if( group && swap_footer < 0 )
e4describe( group->report->code_base, e4parm, E4_REP_SWPFTR, 0, 0 );
return -1;
}
temp = group->swap_footer;
group->swap_footer = swap_footer;
return temp;
}
/* SEE THE CODEREPORTER MANUAL */
int S4FUNCTION group4repeatHeader( PGROUP4 group, int repeat_header )
{
int temp;
if( !group || repeat_header < 0 )
{
if( group && repeat_header < 0 )
e4describe( group->report->code_base, e4parm, E4_REP_RPTHDR, 0, 0 );
return -1;
}
temp = group->repeat_header;
group->repeat_header = repeat_header;
return temp;
}
/* SEE THE CODEREPORTER MANUAL */
int S4FUNCTION group4resetPage( PGROUP4 group, int reset_page )
{
int temp = 0;
if( !group || reset_page < 0 )
{
if( group && reset_page < 0 )
e4describe( group->report->code_base, e4parm, E4_REP_RSTPG, 0, 0 );
return -1;
}
if( group->reset_page )
temp = 1;
group->reset_page = reset_page;
return temp;
}
/* SEE THE CODEREPORTER MANUAL */
int S4FUNCTION group4resetPageNum( PGROUP4 group, int reset_pagenum )
{
int temp = 0;
if( !group || reset_pagenum < 0 )
{
if( group && reset_pagenum < 0 )
e4describe( group->report->code_base, e4parm, E4_REP_RSTPGN, 0, 0 );
return -1;
}
if( group->reset_pagenum )
temp = 1;
group->reset_pagenum = reset_pagenum;
return temp;
}
/* SEE THE CODEREPORTER MANUAL */
PGROUP4 S4FUNCTION report4groupFirst( PREPORT4 report )
{
PGROUP4 group;
if( !report )
{
return NULL;
}
group = (PGROUP4)l4last( &report->groups );
if( group == report->title_summary )
group = NULL;
return group;
}
/* SEE THE CODEREPORTER MANUAL */
PGROUP4 S4FUNCTION report4groupNext( PREPORT4 report, PGROUP4 group )
{
PGROUP4 group_on;
if( !report )
{
return NULL;
}
group_on = (PGROUP4)l4prev( &report->groups, group );
if( group_on == report->title_summary )
group_on = NULL;
return group_on;
}
/* SEE THE CODEREPORTER MANUAL */
PGROUP4 S4FUNCTION report4groupLast( PREPORT4 report )
{
PGROUP4 group_on;
if( !report )
{
return NULL;
}
group_on = (PGROUP4)l4first( &report->groups );
if( group_on == report->title_summary )
group_on = (PGROUP4)l4next( &report->groups, group_on );
return group_on;
}
/* SEE THE CODEREPORTER MANUAL */
PGROUP4 S4FUNCTION report4groupPrev( PREPORT4 report, PGROUP4 group )
{
PGROUP4 group_on;
if( !report )
{
return NULL;
}
group_on = (PGROUP4)l4next( &report->groups, group );
if( group_on == report->title_summary )
return NULL;
else
return group_on;
}
/* SEE THE CODEREPORTER MANUAL */
int S4FUNCTION report4numGroups( PREPORT4 report )
{
if( !report )
{
return 0;
}
return report->groups.n_link;
}
/* SEE THE CODEREPORTER MANUAL */
PGROUP4 S4FUNCTION report4titleSummary( PREPORT4 report )
{
if( !report )
{
return NULL;
}
return report->title_summary;
}
/* SEE THE CODEREPORTER MANUAL */
PGROUP4 S4FUNCTION report4pageHeaderFooter( PREPORT4 report )
{
if( !report )
{
return NULL;
}
return report->page_header_footer;
}
/* SEE THE CODEREPORTER MANUAL */
PGROUP4 S4FUNCTION report4groupLookup( PREPORT4 report, char *group_name )
{
PGROUP4 group_on;
if( report == NULL )
return NULL;
if( group_name == NULL || group_name[0] == '\0' )
{
e4describe( report->code_base, e4parm, E4_REP_GRPLK, 0, 0 );
return NULL;
}
group_on = (PGROUP4)l4first( &report->groups );
while( group_on )
{
if( strcmp( group_on->group_label, group_name ) == 0 )
return group_on;
else
group_on = (PGROUP4)l4next( &report->groups, group_on );
}
return NULL;
}
/* SEE THE CODEREPORTER MANUAL */
int S4FUNCTION group4resetExprSet( PGROUP4 group, char *expr_src )
{
EXPR4 *expr;
if( !group )
{
return -1;
}
if( group->reset_expression )
expr4free( group->reset_expression );
group->reset_expression = NULL;
if( expr_src != NULL )
{
expr = expr4parse( group->report->relate->data, expr_src );
if( expr )
{
group->reset_expression = expr;
return 0;
}
else
{
e4describe( group->report->code_base, e4group_expr, E4_REP_GEXPR, 0, 0 );
return -1;
}
}
else
return 0;
}