diff options
-rw-r--r-- | Source/CursesDialog/form/frm_driver.c | 1461 |
1 files changed, 730 insertions, 731 deletions
diff --git a/Source/CursesDialog/form/frm_driver.c b/Source/CursesDialog/form/frm_driver.c index c7b8119..af67220 100644 --- a/Source/CursesDialog/form/frm_driver.c +++ b/Source/CursesDialog/form/frm_driver.c @@ -45,8 +45,7 @@ MODULE_ID("$Id$") /* These declarations are missing from curses.h on some platforms. */ extern int winnstr(WINDOW *, char *, int); - -#if 0 +#if defined(__DECCXX_VER) extern int waddnstr(WINDOW *,const char *const,int); extern void wbkgdset(WINDOW *,chtype); #ifndef untouchwin @@ -366,11 +365,11 @@ static void Buffer_To_Window(const FIELD * field, WINDOW * win) row++, pBuffer += width ) { if ((len = (int)( After_End_Of_Data( pBuffer, width ) - pBuffer )) > 0) - { - wmove( win, row, 0 ); - waddnstr( win, pBuffer, len ); - } - } + { + wmove( win, row, 0 ); + waddnstr( win, pBuffer, len ); + } + } } /*--------------------------------------------------------------------------- @@ -411,10 +410,10 @@ static void Window_To_Buffer(WINDOW * win, FIELD * field) { int i; for(i=0; i<len; i++, p++) - { - if (*p==pad) - *p = C_BLANK; - } + { + if (*p==pad) + *p = C_BLANK; + } } } @@ -471,104 +470,104 @@ static bool Field_Grown(FIELD * field, int amount) int growth; FORM *form = field->form; bool need_visual_update = ((form != (FORM *)0) && - (form->status & _POSTED) && - (form->current==field)); + (form->status & _POSTED) && + (form->current==field)); if (need_visual_update) - Synchronize_Buffer(form); + Synchronize_Buffer(form); if (single_line_field) - { - growth = field->cols * amount; - if (field->maxgrow) - growth = Minimum(field->maxgrow - field->dcols,growth); - field->dcols += growth; - if (field->dcols == field->maxgrow) - field->status &= ~_MAY_GROW; - } + { + growth = field->cols * amount; + if (field->maxgrow) + growth = Minimum(field->maxgrow - field->dcols,growth); + field->dcols += growth; + if (field->dcols == field->maxgrow) + field->status &= ~_MAY_GROW; + } else - { - growth = (field->rows + field->nrow) * amount; - if (field->maxgrow) - growth = Minimum(field->maxgrow - field->drows,growth); - field->drows += growth; - if (field->drows == field->maxgrow) - field->status &= ~_MAY_GROW; - } + { + growth = (field->rows + field->nrow) * amount; + if (field->maxgrow) + growth = Minimum(field->maxgrow - field->drows,growth); + field->drows += growth; + if (field->drows == field->maxgrow) + field->status &= ~_MAY_GROW; + } /* drows, dcols changed, so we get really the new buffer length */ new_buflen = Buffer_Length(field); newbuf=(char *)malloc((size_t)Total_Buffer_Size(field)); if (!newbuf) - { /* restore to previous state */ - field->dcols = old_dcols; - field->drows = old_drows; - if (( single_line_field && (field->dcols!=field->maxgrow)) || - (!single_line_field && (field->drows!=field->maxgrow))) - field->status |= _MAY_GROW; - return FALSE; - } + { /* restore to previous state */ + field->dcols = old_dcols; + field->drows = old_drows; + if (( single_line_field && (field->dcols!=field->maxgrow)) || + (!single_line_field && (field->drows!=field->maxgrow))) + field->status |= _MAY_GROW; + return FALSE; + } else - { /* Copy all the buffers. This is the reason why we can't - just use realloc(). - */ - int i; - char *old_bp; - char *new_bp; - - field->buf = newbuf; - for(i=0;i<=field->nbuf;i++) - { - new_bp = Address_Of_Nth_Buffer(field,i); - old_bp = oldbuf + i*(1+old_buflen); - memcpy(new_bp,old_bp,(size_t)old_buflen); - if (new_buflen > old_buflen) - memset(new_bp + old_buflen,C_BLANK, - (size_t)(new_buflen - old_buflen)); - *(new_bp + new_buflen) = '\0'; - } - - if (need_visual_update) - { - WINDOW *new_window = newpad(field->drows,field->dcols); - if (!new_window) - { /* restore old state */ - field->dcols = old_dcols; - field->drows = old_drows; - field->buf = oldbuf; - if (( single_line_field && - (field->dcols!=field->maxgrow)) || - (!single_line_field && - (field->drows!=field->maxgrow))) - field->status |= _MAY_GROW; - free( newbuf ); - return FALSE; - } - assert(form!=(FORM *)0); - delwin(form->w); - form->w = new_window; - Set_Field_Window_Attributes(field,form->w); - werase(form->w); - Buffer_To_Window(field,form->w); - untouchwin(form->w); - wmove(form->w,form->currow,form->curcol); - } - - free(oldbuf); - /* reflect changes in linked fields */ - if (field != field->link) - { - FIELD *linked_field; - for(linked_field = field->link; - linked_field!= field; - linked_field = linked_field->link) - { - linked_field->buf = field->buf; - linked_field->drows = field->drows; - linked_field->dcols = field->dcols; - } - } - result = TRUE; - } + { /* Copy all the buffers. This is the reason why we can't + just use realloc(). + */ + int i; + char *old_bp; + char *new_bp; + + field->buf = newbuf; + for(i=0;i<=field->nbuf;i++) + { + new_bp = Address_Of_Nth_Buffer(field,i); + old_bp = oldbuf + i*(1+old_buflen); + memcpy(new_bp,old_bp,(size_t)old_buflen); + if (new_buflen > old_buflen) + memset(new_bp + old_buflen,C_BLANK, + (size_t)(new_buflen - old_buflen)); + *(new_bp + new_buflen) = '\0'; + } + + if (need_visual_update) + { + WINDOW *new_window = newpad(field->drows,field->dcols); + if (!new_window) + { /* restore old state */ + field->dcols = old_dcols; + field->drows = old_drows; + field->buf = oldbuf; + if (( single_line_field && + (field->dcols!=field->maxgrow)) || + (!single_line_field && + (field->drows!=field->maxgrow))) + field->status |= _MAY_GROW; + free( newbuf ); + return FALSE; + } + assert(form!=(FORM *)0); + delwin(form->w); + form->w = new_window; + Set_Field_Window_Attributes(field,form->w); + werase(form->w); + Buffer_To_Window(field,form->w); + untouchwin(form->w); + wmove(form->w,form->currow,form->curcol); + } + + free(oldbuf); + /* reflect changes in linked fields */ + if (field != field->link) + { + FIELD *linked_field; + for(linked_field = field->link; + linked_field!= field; + linked_field = linked_field->link) + { + linked_field->buf = field->buf; + linked_field->drows = field->drows; + linked_field->dcols = field->dcols; + } + } + result = TRUE; + } } return(result); } @@ -605,10 +604,10 @@ _nc_Position_Form_Cursor(FORM * form) if ( Has_Invisible_Parts(field) ) { /* in this case fieldwin isn't derived from formwin, so we have - to move the cursor in formwin by hand... */ + to move the cursor in formwin by hand... */ wmove(formwin, - field->frow + form->currow - form->toprow, - field->fcol + form->curcol - form->begincol); + field->frow + form->currow - form->toprow, + field->fcol + form->curcol - form->begincol); wcursyncup(formwin); } else @@ -645,99 +644,99 @@ _nc_Refresh_Current_Field(FORM * form) if (field->opts & O_PUBLIC) { if (Is_Scroll_Field(field)) - { - /* Again, in this case the fieldwin isn't derived from formwin, - so we have to perform a copy operation. */ - if (Single_Line_Field(field)) - { /* horizontal scrolling */ - if (form->curcol < form->begincol) - form->begincol = form->curcol; - else - { - if (form->curcol >= (form->begincol + field->cols)) - form->begincol = form->curcol - field->cols + 1; - } - copywin(form->w, - formwin, - 0, - form->begincol, - field->frow, - field->fcol, - field->frow, - field->cols + field->fcol - 1, - 0); - } - else - { /* A multiline, i.e. vertical scrolling field */ - int row_after_bottom,first_modified_row,first_unmodified_row; - - if (field->drows > field->rows) - { - row_after_bottom = form->toprow + field->rows; - if (form->currow < form->toprow) - { - form->toprow = form->currow; - field->status |= _NEWTOP; - } - if (form->currow >= row_after_bottom) - { - form->toprow = form->currow - field->rows + 1; - field->status |= _NEWTOP; - } - if (field->status & _NEWTOP) - { /* means we have to copy whole range */ - first_modified_row = form->toprow; - first_unmodified_row = first_modified_row + field->rows; - field->status &= ~_NEWTOP; - } - else - { /* we try to optimize : finding the range of touched + { + /* Again, in this case the fieldwin isn't derived from formwin, + so we have to perform a copy operation. */ + if (Single_Line_Field(field)) + { /* horizontal scrolling */ + if (form->curcol < form->begincol) + form->begincol = form->curcol; + else + { + if (form->curcol >= (form->begincol + field->cols)) + form->begincol = form->curcol - field->cols + 1; + } + copywin(form->w, + formwin, + 0, + form->begincol, + field->frow, + field->fcol, + field->frow, + field->cols + field->fcol - 1, + 0); + } + else + { /* A multiline, i.e. vertical scrolling field */ + int row_after_bottom,first_modified_row,first_unmodified_row; + + if (field->drows > field->rows) + { + row_after_bottom = form->toprow + field->rows; + if (form->currow < form->toprow) + { + form->toprow = form->currow; + field->status |= _NEWTOP; + } + if (form->currow >= row_after_bottom) + { + form->toprow = form->currow - field->rows + 1; + field->status |= _NEWTOP; + } + if (field->status & _NEWTOP) + { /* means we have to copy whole range */ + first_modified_row = form->toprow; + first_unmodified_row = first_modified_row + field->rows; + field->status &= ~_NEWTOP; + } + else + { /* we try to optimize : finding the range of touched lines */ - first_modified_row = form->toprow; - while(first_modified_row < row_after_bottom) - { - if (is_linetouched(form->w,first_modified_row)) - break; - first_modified_row++; - } - first_unmodified_row = first_modified_row; - while(first_unmodified_row < row_after_bottom) - { - if (!is_linetouched(form->w,first_unmodified_row)) - break; - first_unmodified_row++; - } - } - } - else - { - first_modified_row = form->toprow; - first_unmodified_row = first_modified_row + field->rows; - } - if (first_unmodified_row != first_modified_row) - copywin(form->w, - formwin, - first_modified_row, - 0, - field->frow + first_modified_row - form->toprow, - field->fcol, - field->frow + first_unmodified_row - form->toprow - 1, - field->cols + field->fcol - 1, - 0); - } - wsyncup(formwin); - } + first_modified_row = form->toprow; + while(first_modified_row < row_after_bottom) + { + if (is_linetouched(form->w,first_modified_row)) + break; + first_modified_row++; + } + first_unmodified_row = first_modified_row; + while(first_unmodified_row < row_after_bottom) + { + if (!is_linetouched(form->w,first_unmodified_row)) + break; + first_unmodified_row++; + } + } + } + else + { + first_modified_row = form->toprow; + first_unmodified_row = first_modified_row + field->rows; + } + if (first_unmodified_row != first_modified_row) + copywin(form->w, + formwin, + first_modified_row, + 0, + field->frow + first_modified_row - form->toprow, + field->fcol, + field->frow + first_unmodified_row - form->toprow - 1, + field->cols + field->fcol - 1, + 0); + } + wsyncup(formwin); + } else - { /* if the field-window is simply a derived window, i.e. contains - no invisible parts, the whole thing is trivial - */ - wsyncup(form->w); - } + { /* if the field-window is simply a derived window, i.e. contains + no invisible parts, the whole thing is trivial + */ + wsyncup(form->w); + } } untouchwin(form->w); return _nc_Position_Form_Cursor(form); } - + /*--------------------------------------------------------------------------- | Facility : libnform | Function : static void Perform_Justification( @@ -762,18 +761,18 @@ static void Perform_Justification(FIELD * field, WINDOW * win) assert(win && (field->drows == 1) && (field->dcols == field->cols)); switch(field->just) - { - case JUSTIFY_LEFT: - break; - case JUSTIFY_CENTER: - col = (field->cols - len)/2; - break; - case JUSTIFY_RIGHT: - col = field->cols - len; - break; - default: - break; - } + { + case JUSTIFY_LEFT: + break; + case JUSTIFY_CENTER: + col = (field->cols - len)/2; + break; + case JUSTIFY_RIGHT: + col = field->cols - len; + break; + default: + break; + } wmove(win,0,col); waddnstr(win,bp,len); @@ -825,17 +824,17 @@ static bool Check_Char(FIELDTYPE * typ, int ch, TypeArgument *argp) if (typ) { if (typ->status & _LINKED_TYPE) - { - assert(argp != 0); - return( - Check_Char(typ->left ,ch,argp->left ) || - Check_Char(typ->right,ch,argp->right) ); - } + { + assert(argp != 0); + return( + Check_Char(typ->left ,ch,argp->left ) || + Check_Char(typ->right,ch,argp->right) ); + } else - { - if (typ->ccheck) - return typ->ccheck(ch,(void *)argp); - } + { + if (typ->ccheck) + return typ->ccheck(ch,(void *)argp); + } } return (isprint((unsigned char)ch) ? TRUE : FALSE); } @@ -863,28 +862,28 @@ static int Display_Or_Erase_Field(FIELD * field, bool bEraseFlag) fwin = Get_Form_Window(field->form); win = derwin(fwin, - field->rows,field->cols,field->frow,field->fcol); + field->rows,field->cols,field->frow,field->fcol); if (!win) return E_SYSTEM_ERROR; else { if (field->opts & O_VISIBLE) - Set_Field_Window_Attributes(field,win); + Set_Field_Window_Attributes(field,win); else - wattrset(win,getattrs(fwin)); + wattrset(win,getattrs(fwin)); werase(win); } if (!bEraseFlag) { if (field->opts & O_PUBLIC) - { - if (Justification_Allowed(field)) - Perform_Justification(field,win); - else - Buffer_To_Window(field,win); - } + { + if (Justification_Allowed(field)) + Perform_Justification(field,win); + else + Buffer_To_Window(field,win); + } field->status &= ~_NEWTOP; } wsyncup(win); @@ -919,20 +918,20 @@ static int Synchronize_Field(FIELD * field) && Field_Really_Appears(field)) { if (field == form->current) - { - form->currow = form->curcol = form->toprow = form->begincol = 0; - werase(form->w); + { + form->currow = form->curcol = form->toprow = form->begincol = 0; + werase(form->w); - if ( (field->opts & O_PUBLIC) && Justification_Allowed(field) ) - Undo_Justification( field, form->w ); - else - Buffer_To_Window( field, form->w ); - - field->status |= _NEWTOP; - res = _nc_Refresh_Current_Field( form ); - } + if ( (field->opts & O_PUBLIC) && Justification_Allowed(field) ) + Undo_Justification( field, form->w ); + else + Buffer_To_Window( field, form->w ); + + field->status |= _NEWTOP; + res = _nc_Refresh_Current_Field( form ); + } else - res = Display_Field( field ); + res = Display_Field( field ); } field->status |= _CHANGED; return(res); @@ -967,8 +966,8 @@ static int Synchronize_Linked_Fields(FIELD * field) linked_field = linked_field->link ) { if (((syncres=Synchronize_Field(linked_field)) != E_OK) && - (res==E_OK)) - res = syncres; + (res==E_OK)) + res = syncres; } return(res); } @@ -998,34 +997,34 @@ int _nc_Synchronize_Attributes(FIELD * field) && Field_Really_Appears(field)) { if (form->current==field) - { - Synchronize_Buffer(form); - Set_Field_Window_Attributes(field,form->w); - werase(form->w); - if (field->opts & O_PUBLIC) - { - if (Justification_Allowed(field)) - Undo_Justification(field,form->w); - else - Buffer_To_Window(field,form->w); - } - else - { - formwin = Get_Form_Window(form); - copywin(form->w,formwin, - 0,0, - field->frow,field->fcol, - field->rows-1,field->cols-1,0); - wsyncup(formwin); - Buffer_To_Window(field,form->w); - field->status |= _NEWTOP; /* fake refresh to paint all */ - _nc_Refresh_Current_Field(form); - } - } + { + Synchronize_Buffer(form); + Set_Field_Window_Attributes(field,form->w); + werase(form->w); + if (field->opts & O_PUBLIC) + { + if (Justification_Allowed(field)) + Undo_Justification(field,form->w); + else + Buffer_To_Window(field,form->w); + } + else + { + formwin = Get_Form_Window(form); + copywin(form->w,formwin, + 0,0, + field->frow,field->fcol, + field->rows-1,field->cols-1,0); + wsyncup(formwin); + Buffer_To_Window(field,form->w); + field->status |= _NEWTOP; /* fake refresh to paint all */ + _nc_Refresh_Current_Field(form); + } + } else - { - res = Display_Field(field); - } + { + res = Display_Field(field); + } } return(res); } @@ -1062,30 +1061,30 @@ _nc_Synchronize_Options(FIELD *field, Field_Options newopts) if (form) { if (form->current == field) - { - field->opts = oldopts; - return(E_CURRENT); - } + { + field->opts = oldopts; + return(E_CURRENT); + } if (form->status & _POSTED) - { - if ((form->curpage == field->page)) - { - if (changed_opts & O_VISIBLE) - { - if (newopts & O_VISIBLE) - res = Display_Field(field); - else - res = Erase_Field(field); - } - else - { - if ((changed_opts & O_PUBLIC) && - (newopts & O_VISIBLE)) - res = Display_Field(field); - } - } - } + { + if ((form->curpage == field->page)) + { + if (changed_opts & O_VISIBLE) + { + if (newopts & O_VISIBLE) + res = Display_Field(field); + else + res = Erase_Field(field); + } + else + { + if ((changed_opts & O_PUBLIC) && + (newopts & O_VISIBLE)) + res = Display_Field(field); + } + } + } } if (changed_opts & O_STATIC) @@ -1094,37 +1093,37 @@ _nc_Synchronize_Options(FIELD *field, Field_Options newopts) int res2 = E_OK; if (newopts & O_STATIC) - { /* the field becomes now static */ - field->status &= ~_MAY_GROW; - /* if actually we have no hidden columns, justification may - occur again */ - if (single_line_field && - (field->cols == field->dcols) && - (field->just != NO_JUSTIFICATION) && - Field_Really_Appears(field)) - { - res2 = Display_Field(field); - } - } + { /* the field becomes now static */ + field->status &= ~_MAY_GROW; + /* if actually we have no hidden columns, justification may + occur again */ + if (single_line_field && + (field->cols == field->dcols) && + (field->just != NO_JUSTIFICATION) && + Field_Really_Appears(field)) + { + res2 = Display_Field(field); + } + } else - { /* field is no longer static */ - if ((field->maxgrow==0) || - ( single_line_field && (field->dcols < field->maxgrow)) || - (!single_line_field && (field->drows < field->maxgrow))) - { - field->status |= _MAY_GROW; - /* a field with justification now changes its behaviour, - so we must redisplay it */ - if (single_line_field && - (field->just != NO_JUSTIFICATION) && - Field_Really_Appears(field)) - { - res2 = Display_Field(field); - } - } - } + { /* field is no longer static */ + if ((field->maxgrow==0) || + ( single_line_field && (field->dcols < field->maxgrow)) || + (!single_line_field && (field->drows < field->maxgrow))) + { + field->status |= _MAY_GROW; + /* a field with justification now changes its behaviour, + so we must redisplay it */ + if (single_line_field && + (field->just != NO_JUSTIFICATION) && + Field_Really_Appears(field)) + { + res2 = Display_Field(field); + } + } + } if (res2 != E_OK) - res = res2; + res = res2; } return(res); @@ -1162,43 +1161,43 @@ _nc_Set_Current_Field(FORM *form, FIELD *newfield) !(form->status & _POSTED)) { if ((form->w) && - (field->opts & O_VISIBLE) && - (field->form->curpage == field->page)) - { - _nc_Refresh_Current_Field(form); - if (field->opts & O_PUBLIC) - { - if (field->drows > field->rows) - { - if (form->toprow==0) - field->status &= ~_NEWTOP; - else - field->status |= _NEWTOP; - } - else - { - if (Justification_Allowed(field)) - { - Window_To_Buffer(form->w,field); - werase(form->w); - Perform_Justification(field,form->w); - wsyncup(form->w); - } - } - } - delwin(form->w); - } + (field->opts & O_VISIBLE) && + (field->form->curpage == field->page)) + { + _nc_Refresh_Current_Field(form); + if (field->opts & O_PUBLIC) + { + if (field->drows > field->rows) + { + if (form->toprow==0) + field->status &= ~_NEWTOP; + else + field->status |= _NEWTOP; + } + else + { + if (Justification_Allowed(field)) + { + Window_To_Buffer(form->w,field); + werase(form->w); + Perform_Justification(field,form->w); + wsyncup(form->w); + } + } + } + delwin(form->w); + } field = newfield; if (Has_Invisible_Parts(field)) - new_window = newpad(field->drows,field->dcols); + new_window = newpad(field->drows,field->dcols); else - new_window = derwin(Get_Form_Window(form), - field->rows,field->cols,field->frow,field->fcol); + new_window = derwin(Get_Form_Window(form), + field->rows,field->cols,field->frow,field->fcol); if (!new_window) - return(E_SYSTEM_ERROR); + return(E_SYSTEM_ERROR); form->current = field; form->w = new_window; @@ -1206,19 +1205,19 @@ _nc_Set_Current_Field(FORM *form, FIELD *newfield) Set_Field_Window_Attributes(field,form->w); if (Has_Invisible_Parts(field)) - { - werase(form->w); - Buffer_To_Window(field,form->w); - } + { + werase(form->w); + Buffer_To_Window(field,form->w); + } else - { - if (Justification_Allowed(field)) - { - werase(form->w); - Undo_Justification(field,form->w); - wsyncup(form->w); - } - } + { + if (Justification_Allowed(field)) + { + werase(form->w); + Undo_Justification(field,form->w); + wsyncup(form->w); + } + } untouchwin(form->w); } @@ -1248,21 +1247,21 @@ static int IFN_Next_Character(FORM * form) if ((++(form->curcol))==field->dcols) { if ((++(form->currow))==field->drows) - { + { #if GROW_IF_NAVIGATE - if (!Single_Line_Field(field) && Field_Grown(field,1)) { - form->curcol = 0; - return(E_OK); - } + if (!Single_Line_Field(field) && Field_Grown(field,1)) { + form->curcol = 0; + return(E_OK); + } #endif - form->currow--; + form->currow--; #if GROW_IF_NAVIGATE - if (Single_Line_Field(field) && Field_Grown(field,1)) - return(E_OK); + if (Single_Line_Field(field) && Field_Grown(field,1)) + return(E_OK); #endif - form->curcol--; - return(E_REQUEST_DENIED); - } + form->curcol--; + return(E_REQUEST_DENIED); + } form->curcol = 0; } return(E_OK); @@ -1284,11 +1283,11 @@ static int IFN_Previous_Character(FORM * form) if ((--(form->curcol))<0) { if ((--(form->currow))<0) - { - form->currow++; - form->curcol++; - return(E_REQUEST_DENIED); - } + { + form->currow++; + form->curcol++; + return(E_REQUEST_DENIED); + } form->curcol = form->current->dcols - 1; } return(E_OK); @@ -1311,7 +1310,7 @@ static int IFN_Next_Line(FORM * form) { #if GROW_IF_NAVIGATE if (!Single_Line_Field(field) && Field_Grown(field,1)) - return(E_OK); + return(E_OK); #endif form->currow--; return(E_REQUEST_DENIED); @@ -1363,11 +1362,11 @@ static int IFN_Next_Word(FORM * form) current position). This is then the startpoint to look for the next non-blank data */ s = Get_First_Whitespace_Character(bp,Buffer_Length(field) - - (int)(bp - field->buf)); + (int)(bp - field->buf)); /* Find the start of the next word */ t = Get_Start_Of_Data(s,Buffer_Length(field) - - (int)(s - field->buf)); + (int)(s - field->buf)); #if !FRIENDLY_PREV_NEXT_WORD if (s==t) return(E_REQUEST_DENIED); @@ -1422,7 +1421,7 @@ static int IFN_Previous_Word(FORM * form) t = After_Last_Whitespace_Character(field->buf,(int)(s - field->buf)); #if !FRIENDLY_PREV_NEXT_WORD if (s==t) - return(E_REQUEST_DENIED); + return(E_REQUEST_DENIED); #endif } Adjust_Cursor_Position(form,t); @@ -1444,7 +1443,7 @@ static int IFN_Beginning_Of_Field(FORM * form) Synchronize_Buffer(form); Adjust_Cursor_Position(form, - Get_Start_Of_Data(field->buf,Buffer_Length(field))); + Get_Start_Of_Data(field->buf,Buffer_Length(field))); return(E_OK); } @@ -1487,8 +1486,8 @@ static int IFN_Beginning_Of_Line(FORM * form) Synchronize_Buffer(form); Adjust_Cursor_Position(form, - Get_Start_Of_Data(Address_Of_Current_Row_In_Buffer(form), - field->dcols)); + Get_Start_Of_Data(Address_Of_Current_Row_In_Buffer(form), + field->dcols)); return(E_OK); } @@ -1555,7 +1554,7 @@ static int IFN_Right_Character(FORM * form) #if GROW_IF_NAVIGATE FIELD *field = form->current; if (Single_Line_Field(field) && Field_Grown(field,1)) - return(E_OK); + return(E_OK); #endif --(form->curcol); return(E_REQUEST_DENIED); @@ -1601,7 +1600,7 @@ static int IFN_Down_Character(FORM * form) { #if GROW_IF_NAVIGATE if (!Single_Line_Field(field) && Field_Grown(field,1)) - return(E_OK); + return(E_OK); #endif --(form->currow); return(E_REQUEST_DENIED); @@ -1635,26 +1634,26 @@ static int VSC_Generic(FORM *form, int lines) if (lines > 0) { if ( (rows_to_go + form->toprow) > (field->drows - field->rows) ) - rows_to_go = (field->drows - field->rows - form->toprow); + rows_to_go = (field->drows - field->rows - form->toprow); if (rows_to_go > 0) - { - form->currow += rows_to_go; - form->toprow += rows_to_go; - res = E_OK; - } + { + form->currow += rows_to_go; + form->toprow += rows_to_go; + res = E_OK; + } } else { if (rows_to_go > form->toprow) - rows_to_go = form->toprow; + rows_to_go = form->toprow; if (rows_to_go > 0) - { - form->currow -= rows_to_go; - form->toprow -= rows_to_go; - res = E_OK; - } + { + form->currow -= rows_to_go; + form->toprow -= rows_to_go; + res = E_OK; + } } return(res); } @@ -1686,7 +1685,7 @@ static int Vertical_Scrolling(int (* const fct) (FORM *), FORM * form) { res = fct(form); if (res == E_OK) - form->current->status |= _NEWTOP; + form->current->status |= _NEWTOP; } return(res); } @@ -1801,26 +1800,26 @@ static int HSC_Generic(FORM *form, int columns) if (columns > 0) { if ((cols_to_go + form->begincol) > (field->dcols - field->cols)) - cols_to_go = field->dcols - field->cols - form->begincol; + cols_to_go = field->dcols - field->cols - form->begincol; if (cols_to_go > 0) - { - form->curcol += cols_to_go; - form->begincol += cols_to_go; - res = E_OK; - } + { + form->curcol += cols_to_go; + form->begincol += cols_to_go; + res = E_OK; + } } else { if ( cols_to_go > form->begincol ) - cols_to_go = form->begincol; + cols_to_go = form->begincol; if (cols_to_go > 0) - { - form->curcol -= cols_to_go; - form->begincol -= cols_to_go; - res = E_OK; - } + { + form->curcol -= cols_to_go; + form->begincol -= cols_to_go; + res = E_OK; + } } return(res); } @@ -1982,7 +1981,7 @@ INLINE static bool Is_There_Room_For_A_Char_In_Line(FORM * form) last_char_in_line = (int)(winch(form->w) & A_CHARTEXT); wmove(form->w,form->currow,form->curcol); return (((last_char_in_line == form->current->pad) || - is_blank(last_char_in_line)) ? TRUE : FALSE); + is_blank(last_char_in_line)) ? TRUE : FALSE); } #define There_Is_No_Room_For_A_Char_In_Line(f) \ @@ -2033,40 +2032,40 @@ static int Insert_String(FORM *form, int row, char *txt, int len) } else { /* we have to move characters on the next line. If we are on the - last line this may work, if the field is growable */ + last line this may work, if the field is growable */ if ((row == (field->drows - 1)) && Growable(field)) - { - if (!Field_Grown(field,1)) - { - free(Space); - return(E_SYSTEM_ERROR); - } - /* !!!Side-Effect : might be changed due to growth!!! */ - bp = Address_Of_Row_In_Buffer(field,row); - } + { + if (!Field_Grown(field,1)) + { + free(Space); + return(E_SYSTEM_ERROR); + } + /* !!!Side-Effect : might be changed due to growth!!! */ + bp = Address_Of_Row_In_Buffer(field,row); + } if (row < (field->drows - 1)) - { - split = After_Last_Whitespace_Character(bp, - (int)(Get_Start_Of_Data(bp + field->dcols - requiredlen , - requiredlen) - bp)); - /* split points now to the first character of the portion of the - line that must be moved to the next line */ - datalen = (int)(split-bp); /* + freelen has to stay on this line */ - freelen = field->dcols - (datalen + freelen); /* for the next line */ - - if ((result=Insert_String(form,row+1,split,freelen))==E_OK) - { - wmove(form->w,row,datalen); - wclrtoeol(form->w); - wmove(form->w,row,0); - winsnstr(form->w,txt,len); - wmove(form->w,row,len); - winsnstr(form->w,Space,1); - free(Space); - return E_OK; - } - } + { + split = After_Last_Whitespace_Character(bp, + (int)(Get_Start_Of_Data(bp + field->dcols - requiredlen , + requiredlen) - bp)); + /* split points now to the first character of the portion of the + line that must be moved to the next line */ + datalen = (int)(split-bp); /* + freelen has to stay on this line */ + freelen = field->dcols - (datalen + freelen); /* for the next line */ + + if ((result=Insert_String(form,row+1,split,freelen))==E_OK) + { + wmove(form->w,row,datalen); + wclrtoeol(form->w); + wmove(form->w,row,0); + winsnstr(form->w,txt,len); + wmove(form->w,row,len); + winsnstr(form->w,Space,1); + free(Space); + return E_OK; + } + } free(Space); return(result); } @@ -2103,11 +2102,11 @@ static int Wrapping_Not_Necessary_Or_Wrapping_Ok(FORM * form) int chars_to_be_wrapped; int chars_to_remain_on_line; if (Last_Row) - { /* the above logic already ensures, that in this case the field - is growable */ - if (!Field_Grown(field,1)) - return E_SYSTEM_ERROR; - } + { /* the above logic already ensures, that in this case the field + is growable */ + if (!Field_Grown(field,1)) + return E_SYSTEM_ERROR; + } bp = Address_Of_Current_Row_In_Buffer(form); Window_To_Buffer(form->w,field); split = After_Last_Whitespace_Character(bp,field->dcols); @@ -2116,29 +2115,29 @@ static int Wrapping_Not_Necessary_Or_Wrapping_Ok(FORM * form) chars_to_remain_on_line = (int)(split - bp); chars_to_be_wrapped = field->dcols - chars_to_remain_on_line; if (chars_to_remain_on_line > 0) - { - if ((result=Insert_String(form,form->currow+1,split, - chars_to_be_wrapped)) == E_OK) - { - wmove(form->w,form->currow,chars_to_remain_on_line); - wclrtoeol(form->w); - if (form->curcol >= chars_to_remain_on_line) - { - form->currow++; - form->curcol -= chars_to_remain_on_line; - } - return E_OK; - } - } + { + if ((result=Insert_String(form,form->currow+1,split, + chars_to_be_wrapped)) == E_OK) + { + wmove(form->w,form->currow,chars_to_remain_on_line); + wclrtoeol(form->w); + if (form->curcol >= chars_to_remain_on_line) + { + form->currow++; + form->curcol -= chars_to_remain_on_line; + } + return E_OK; + } + } else - return E_OK; + return E_OK; if (result!=E_OK) - { - wmove(form->w,form->currow,form->curcol); - wdelch(form->w); - Window_To_Buffer(form->w,field); - result = E_REQUEST_DENIED; - } + { + wmove(form->w,form->currow,form->curcol); + wdelch(form->w); + Window_To_Buffer(form->w,field); + result = E_REQUEST_DENIED; + } } else result = E_OK; /* wrapping was not necessary */ @@ -2182,26 +2181,26 @@ static int Field_Editing(int (* const fct) (FORM *), FORM * form) else { if (fct==FE_New_Line) - { - if ((form->opts & O_NL_OVERLOAD) && - First_Position_In_Current_Field(form)) - { - res = Inter_Field_Navigation(FN_Next_Field,form); - } - else - /* FE_New_Line deals itself with the _WINDOW_MODIFIED flag */ - res = fct(form); - } + { + if ((form->opts & O_NL_OVERLOAD) && + First_Position_In_Current_Field(form)) + { + res = Inter_Field_Navigation(FN_Next_Field,form); + } + else + /* FE_New_Line deals itself with the _WINDOW_MODIFIED flag */ + res = fct(form); + } else - { - /* From now on, everything must be editable */ - if (form->current->opts & O_EDIT) - { - res = fct(form); - if (res==E_OK) - form->status |= _WINDOW_MODIFIED; - } - } + { + /* From now on, everything must be editable */ + if (form->current->opts & O_EDIT) + { + res = fct(form); + if (res==E_OK) + form->status |= _WINDOW_MODIFIED; + } + } } return res; } @@ -2228,62 +2227,62 @@ static int FE_New_Line(FORM * form) if (form->status & _OVLMODE) { if (Last_Row && - (!(Growable(field) && !Single_Line_Field(field)))) - { - if (!(form->opts & O_NL_OVERLOAD)) - return(E_REQUEST_DENIED); - wclrtoeol(form->w); - /* we have to set this here, although it is also - handled in the generic routine. The reason is, - that FN_Next_Field may fail, but the form is - definitively changed */ - form->status |= _WINDOW_MODIFIED; - return Inter_Field_Navigation(FN_Next_Field,form); - } + (!(Growable(field) && !Single_Line_Field(field)))) + { + if (!(form->opts & O_NL_OVERLOAD)) + return(E_REQUEST_DENIED); + wclrtoeol(form->w); + /* we have to set this here, although it is also + handled in the generic routine. The reason is, + that FN_Next_Field may fail, but the form is + definitively changed */ + form->status |= _WINDOW_MODIFIED; + return Inter_Field_Navigation(FN_Next_Field,form); + } else - { - if (Last_Row && !Field_Grown(field,1)) - { /* N.B.: due to the logic in the 'if', LastRow==TRUE - means here that the field is growable and not - a single-line field */ - return(E_SYSTEM_ERROR); - } - wclrtoeol(form->w); - form->currow++; - form->curcol = 0; - form->status |= _WINDOW_MODIFIED; - return(E_OK); - } + { + if (Last_Row && !Field_Grown(field,1)) + { /* N.B.: due to the logic in the 'if', LastRow==TRUE + means here that the field is growable and not + a single-line field */ + return(E_SYSTEM_ERROR); + } + wclrtoeol(form->w); + form->currow++; + form->curcol = 0; + form->status |= _WINDOW_MODIFIED; + return(E_OK); + } } else { /* Insert Mode */ if (Last_Row && - !(Growable(field) && !Single_Line_Field(field))) - { - if (!(form->opts & O_NL_OVERLOAD)) - return(E_REQUEST_DENIED); - return Inter_Field_Navigation(FN_Next_Field,form); - } + !(Growable(field) && !Single_Line_Field(field))) + { + if (!(form->opts & O_NL_OVERLOAD)) + return(E_REQUEST_DENIED); + return Inter_Field_Navigation(FN_Next_Field,form); + } else - { - bool May_Do_It = !Last_Row && Is_There_Room_For_A_Line(form); - - if (!(May_Do_It || Growable(field))) - return(E_REQUEST_DENIED); - if (!May_Do_It && !Field_Grown(field,1)) - return(E_SYSTEM_ERROR); - - bp= Address_Of_Current_Position_In_Buffer(form); - t = After_End_Of_Data(bp,field->dcols - form->curcol); - wclrtoeol(form->w); - form->currow++; - form->curcol=0; - wmove(form->w,form->currow,form->curcol); - winsertln(form->w); - waddnstr(form->w,bp,(int)(t-bp)); - form->status |= _WINDOW_MODIFIED; - return E_OK; - } + { + bool May_Do_It = !Last_Row && Is_There_Room_For_A_Line(form); + + if (!(May_Do_It || Growable(field))) + return(E_REQUEST_DENIED); + if (!May_Do_It && !Field_Grown(field,1)) + return(E_SYSTEM_ERROR); + + bp= Address_Of_Current_Position_In_Buffer(form); + t = After_End_Of_Data(bp,field->dcols - form->curcol); + wclrtoeol(form->w); + form->currow++; + form->curcol=0; + wmove(form->w,form->currow,form->curcol); + winsertln(form->w); + waddnstr(form->w,bp,(int)(t-bp)); + form->status |= _WINDOW_MODIFIED; + return E_OK; + } } } @@ -2306,16 +2305,16 @@ static int FE_Insert_Character(FORM * form) bool There_Is_Room = Is_There_Room_For_A_Char_In_Line(form); if (There_Is_Room || - ((Single_Line_Field(field) && Growable(field)))) - { - if (!There_Is_Room && !Field_Grown(field,1)) - result = E_SYSTEM_ERROR; - else - { - winsch(form->w,(chtype)C_BLANK); - result = Wrapping_Not_Necessary_Or_Wrapping_Ok(form); - } - } + ((Single_Line_Field(field) && Growable(field)))) + { + if (!There_Is_Room && !Field_Grown(field,1)) + result = E_SYSTEM_ERROR; + else + { + winsch(form->w,(chtype)C_BLANK); + result = Wrapping_Not_Necessary_Or_Wrapping_Ok(form); + } + } } return result; } @@ -2337,20 +2336,20 @@ static int FE_Insert_Line(FORM * form) if (Check_Char(field->type,(int)C_BLANK,(TypeArgument *)(field->arg))) { bool Maybe_Done = (form->currow!=(field->drows-1)) && - Is_There_Room_For_A_Line(form); + Is_There_Room_For_A_Line(form); if (!Single_Line_Field(field) && - (Maybe_Done || Growable(field))) - { - if (!Maybe_Done && !Field_Grown(field,1)) - result = E_SYSTEM_ERROR; - else - { - form->curcol = 0; - winsertln(form->w); - result = E_OK; - } - } + (Maybe_Done || Growable(field))) + { + if (!Maybe_Done && !Field_Grown(field,1)) + result = E_SYSTEM_ERROR; + else + { + form->curcol = 0; + winsertln(form->w); + result = E_OK; + } + } } return result; } @@ -2395,7 +2394,7 @@ static int FE_Delete_Previous(FORM * form) form->curcol++; if (form->status & _OVLMODE) - return E_REQUEST_DENIED; + return E_REQUEST_DENIED; prev_line = Address_Of_Row_In_Buffer(field,(form->currow-1)); this_line = Address_Of_Row_In_Buffer(field,(form->currow)); @@ -2403,8 +2402,8 @@ static int FE_Delete_Previous(FORM * form) prev_end = After_End_Of_Data(prev_line,field->dcols); this_end = After_End_Of_Data(this_line,field->dcols); if ((int)(this_end-this_line) > - (field->cols-(int)(prev_end-prev_line))) - return E_REQUEST_DENIED; + (field->cols-(int)(prev_end-prev_line))) + return E_REQUEST_DENIED; wdeleteln(form->w); Adjust_Cursor_Position(form,prev_end); wmove(form->w,form->currow,form->curcol); @@ -2456,7 +2455,7 @@ static int FE_Delete_Word(FORM * form) /* move cursor to begin of word and erase to end of screen-line */ Adjust_Cursor_Position(form, - After_Last_Whitespace_Character(bp,form->curcol)); + After_Last_Whitespace_Character(bp,form->curcol)); wmove(form->w,form->currow,form->curcol); wclrtoeol(form->w); @@ -2580,8 +2579,8 @@ static bool Next_Choice(FIELDTYPE * typ, FIELD *field, TypeArgument *argp) { assert(argp != 0); return( - Next_Choice(typ->left ,field,argp->left) || - Next_Choice(typ->right,field,argp->right) ); + Next_Choice(typ->left ,field,argp->left) || + Next_Choice(typ->right,field,argp->right) ); } else { @@ -2612,8 +2611,8 @@ static bool Previous_Choice(FIELDTYPE *typ, FIELD *field, TypeArgument *argp) { assert(argp != 0); return( - Previous_Choice(typ->left ,field,argp->left) || - Previous_Choice(typ->right,field,argp->right)); + Previous_Choice(typ->left ,field,argp->left) || + Previous_Choice(typ->right,field,argp->right)); } else { @@ -2643,7 +2642,7 @@ static int CR_Next_Choice(FORM * form) FIELD *field = form->current; Synchronize_Buffer(form); return ((Next_Choice(field->type,field,(TypeArgument *)(field->arg))) ? - E_OK : E_REQUEST_DENIED); + E_OK : E_REQUEST_DENIED); } /*--------------------------------------------------------------------------- @@ -2660,7 +2659,7 @@ static int CR_Previous_Choice(FORM * form) FIELD *field = form->current; Synchronize_Buffer(form); return ((Previous_Choice(field->type,field,(TypeArgument *)(field->arg))) ? - E_OK : E_REQUEST_DENIED); + E_OK : E_REQUEST_DENIED); } /*---------------------------------------------------------------------------- End of Routines for Choice Requests @@ -2689,27 +2688,27 @@ static bool Check_Field(FIELDTYPE *typ, FIELD *field, TypeArgument *argp) if (typ) { if (field->opts & O_NULLOK) - { - char *bp = field->buf; - assert(bp != 0); - while(is_blank(*bp)) - { bp++; } - if (*bp == '\0') - return TRUE; - } + { + char *bp = field->buf; + assert(bp != 0); + while(is_blank(*bp)) + { bp++; } + if (*bp == '\0') + return TRUE; + } if (typ->status & _LINKED_TYPE) - { - assert(argp != 0); - return( - Check_Field(typ->left ,field,argp->left ) || - Check_Field(typ->right,field,argp->right) ); - } + { + assert(argp != 0); + return( + Check_Field(typ->left ,field,argp->left ) || + Check_Field(typ->right,field,argp->right) ); + } else - { - if (typ->fcheck) - return typ->fcheck(field,(void *)argp); - } + { + if (typ->fcheck) + return typ->fcheck(field,(void *)argp); + } } return TRUE; } @@ -2735,7 +2734,7 @@ _nc_Internal_Validation(FORM *form) (!(field->opts & O_PASSOK))) { if (!Check_Field(field->type,field,(TypeArgument *)(field->arg))) - return FALSE; + return FALSE; form->status &= ~_FCHECK_REQUIRED; field->status |= _CHANGED; Synchronize_Linked_Fields(field); @@ -2795,9 +2794,9 @@ INLINE static FIELD *Next_Field_On_Page(FIELD * field) do { field_on_page = - (field_on_page==last_on_page) ? first_on_page : field_on_page + 1; + (field_on_page==last_on_page) ? first_on_page : field_on_page + 1; if (Field_Is_Selectable(*field_on_page)) - break; + break; } while(field!=(*field_on_page)); return(*field_on_page); } @@ -2821,32 +2820,32 @@ _nc_First_Active_Field(FORM * form) if (proposed == *last_on_page) { /* there might be the special situation, where there is no - active and visible field on the current page. We then select - the first visible field on this readonly page + active and visible field on the current page. We then select + the first visible field on this readonly page */ if (Field_Is_Not_Selectable(proposed)) - { - FIELD **field = &form->field[proposed->index]; - FIELD **first = &form->field[form->page[form->curpage].pmin]; - - do - { - field = (field==last_on_page) ? first : field + 1; - if (((*field)->opts & O_VISIBLE)) - break; - } while(proposed!=(*field)); - - proposed = *field; - - if ((proposed == *last_on_page) && !(proposed->opts&O_VISIBLE)) - { /* This means, there is also no visible field on the page. - So we propose the first one and hope the very best... - Some very clever user has designed a readonly and invisible - page on this form. - */ - proposed = *first; - } - } + { + FIELD **field = &form->field[proposed->index]; + FIELD **first = &form->field[form->page[form->curpage].pmin]; + + do + { + field = (field==last_on_page) ? first : field + 1; + if (((*field)->opts & O_VISIBLE)) + break; + } while(proposed!=(*field)); + + proposed = *field; + + if ((proposed == *last_on_page) && !(proposed->opts&O_VISIBLE)) + { /* This means, there is also no visible field on the page. + So we propose the first one and hope the very best... + Some very clever user has designed a readonly and invisible + page on this form. + */ + proposed = *first; + } + } } return(proposed); } @@ -2872,9 +2871,9 @@ INLINE static FIELD *Previous_Field_On_Page(FIELD * field) do { field_on_page = - (field_on_page==first_on_page) ? last_on_page : field_on_page - 1; + (field_on_page==first_on_page) ? last_on_page : field_on_page - 1; if (Field_Is_Selectable(*field_on_page)) - break; + break; } while(field!=(*field_on_page)); return (*field_on_page); @@ -2898,7 +2897,7 @@ INLINE static FIELD *Sorted_Next_Field(FIELD * field) { field_on_page = field_on_page->snext; if (Field_Is_Selectable(field_on_page)) - break; + break; } while(field_on_page!=field); return (field_on_page); @@ -2922,7 +2921,7 @@ INLINE static FIELD *Sorted_Previous_Field(FIELD * field) { field_on_page = field_on_page->sprev; if (Field_Is_Selectable(field_on_page)) - break; + break; } while(field_on_page!=field); return (field_on_page); @@ -3010,14 +3009,14 @@ static FIELD *Upper_Neighbour_Field(FIELD * field) frow = field_on_page->frow; /* We walk to the left as long as we are really right of the - field. */ + field. */ while(field_on_page->frow==frow && field_on_page->fcol>fcol) - field_on_page = Sorted_Previous_Field(field_on_page); + field_on_page = Sorted_Previous_Field(field_on_page); /* If we wrapped, just go to the right which is the first field on - the row */ + the row */ if (field_on_page->frow!=frow) - field_on_page = Sorted_Next_Field(field_on_page); + field_on_page = Sorted_Next_Field(field_on_page); } return (field_on_page); @@ -3057,14 +3056,14 @@ static FIELD *Down_Neighbour_Field(FIELD * field) frow = field_on_page->frow; /* We walk to the right as long as we are really left of the - field. */ + field. */ while(field_on_page->frow==frow && field_on_page->fcol<fcol) - field_on_page = Sorted_Next_Field(field_on_page); + field_on_page = Sorted_Next_Field(field_on_page); /* If we wrapped, just go to the left which is the last field on - the row */ + the row */ if (field_on_page->frow!=frow) - field_on_page = Sorted_Previous_Field(field_on_page); + field_on_page = Sorted_Previous_Field(field_on_page); } return(field_on_page); @@ -3116,7 +3115,7 @@ static int Inter_Field_Navigation(int (* const fct) (FORM *),FORM *form) static int FN_Next_Field(FORM * form) { return _nc_Set_Current_Field(form, - Next_Field_On_Page(form->current)); + Next_Field_On_Page(form->current)); } /*--------------------------------------------------------------------------- @@ -3132,7 +3131,7 @@ static int FN_Next_Field(FORM * form) static int FN_Previous_Field(FORM * form) { return _nc_Set_Current_Field(form, - Previous_Field_On_Page(form->current)); + Previous_Field_On_Page(form->current)); } /*--------------------------------------------------------------------------- @@ -3179,7 +3178,7 @@ static int FN_Last_Field(FORM * form) static int FN_Sorted_Next_Field(FORM * form) { return _nc_Set_Current_Field(form, - Sorted_Next_Field(form->current)); + Sorted_Next_Field(form->current)); } /*--------------------------------------------------------------------------- @@ -3195,7 +3194,7 @@ static int FN_Sorted_Next_Field(FORM * form) static int FN_Sorted_Previous_Field(FORM * form) { return _nc_Set_Current_Field(form, - Sorted_Previous_Field(form->current)); + Sorted_Previous_Field(form->current)); } /*--------------------------------------------------------------------------- @@ -3211,7 +3210,7 @@ static int FN_Sorted_Previous_Field(FORM * form) static int FN_Sorted_First_Field(FORM * form) { return _nc_Set_Current_Field(form, - Sorted_Next_Field(form->field[form->page[form->curpage].smax])); + Sorted_Next_Field(form->field[form->page[form->curpage].smax])); } /*--------------------------------------------------------------------------- @@ -3227,7 +3226,7 @@ static int FN_Sorted_First_Field(FORM * form) static int FN_Sorted_Last_Field(FORM * form) { return _nc_Set_Current_Field(form, - Sorted_Previous_Field(form->field[form->page[form->curpage].smin])); + Sorted_Previous_Field(form->field[form->page[form->curpage].smin])); } /*--------------------------------------------------------------------------- @@ -3243,7 +3242,7 @@ static int FN_Sorted_Last_Field(FORM * form) static int FN_Left_Field(FORM * form) { return _nc_Set_Current_Field(form, - Left_Neighbour_Field(form->current)); + Left_Neighbour_Field(form->current)); } /*--------------------------------------------------------------------------- @@ -3259,7 +3258,7 @@ static int FN_Left_Field(FORM * form) static int FN_Right_Field(FORM * form) { return _nc_Set_Current_Field(form, - Right_Neighbour_Field(form->current)); + Right_Neighbour_Field(form->current)); } /*--------------------------------------------------------------------------- @@ -3277,7 +3276,7 @@ static int FN_Right_Field(FORM * form) static int FN_Up_Field(FORM * form) { return _nc_Set_Current_Field(form, - Upper_Neighbour_Field(form->current)); + Upper_Neighbour_Field(form->current)); } /*--------------------------------------------------------------------------- @@ -3295,7 +3294,7 @@ static int FN_Up_Field(FORM * form) static int FN_Down_Field(FORM * form) { return _nc_Set_Current_Field(form, - Down_Neighbour_Field(form->current)); + Down_Neighbour_Field(form->current)); } /*---------------------------------------------------------------------------- END of Field Navigation routines @@ -3333,21 +3332,21 @@ _nc_Set_Form_Page(FORM * form, int page, FIELD * field) form->curpage = page; last_field = field_on_page = form->field[form->page[page].smin]; do - { - if (field_on_page->opts & O_VISIBLE) - if ((res=Display_Field(field_on_page))!=E_OK) - return(res); - field_on_page = field_on_page->snext; - } while(field_on_page != last_field); + { + if (field_on_page->opts & O_VISIBLE) + if ((res=Display_Field(field_on_page))!=E_OK) + return(res); + field_on_page = field_on_page->snext; + } while(field_on_page != last_field); if (field) - res = _nc_Set_Current_Field(form,field); + res = _nc_Set_Current_Field(form,field); else - /* N.B.: we don't encapsulate this by Inter_Field_Navigation(), - because this is already executed in a page navigation - context that contains field navigation - */ - res = FN_First_Field(form); + /* N.B.: we don't encapsulate this by Inter_Field_Navigation(), + because this is already executed in a page navigation + context that contains field navigation + */ + res = FN_First_Field(form); } return(res); } @@ -3505,47 +3504,47 @@ static int Data_Entry(FORM * form, int c) ) { if ( (field->opts & O_BLANK) && - First_Position_In_Current_Field(form) && - !(form->status & _FCHECK_REQUIRED) && - !(form->status & _WINDOW_MODIFIED) ) - werase(form->w); + First_Position_In_Current_Field(form) && + !(form->status & _FCHECK_REQUIRED) && + !(form->status & _WINDOW_MODIFIED) ) + werase(form->w); if (form->status & _OVLMODE) - { - waddch(form->w,(chtype)c); - } + { + waddch(form->w,(chtype)c); + } else /* no _OVLMODE */ - { - bool There_Is_Room = Is_There_Room_For_A_Char_In_Line(form); + { + bool There_Is_Room = Is_There_Room_For_A_Char_In_Line(form); - if (!(There_Is_Room || - ((Single_Line_Field(field) && Growable(field))))) - return E_REQUEST_DENIED; + if (!(There_Is_Room || + ((Single_Line_Field(field) && Growable(field))))) + return E_REQUEST_DENIED; - if (!There_Is_Room && !Field_Grown(field,1)) - return E_SYSTEM_ERROR; + if (!There_Is_Room && !Field_Grown(field,1)) + return E_SYSTEM_ERROR; - winsch(form->w,(chtype)c); - } + winsch(form->w,(chtype)c); + } if ((result=Wrapping_Not_Necessary_Or_Wrapping_Ok(form))==E_OK) - { - bool End_Of_Field= (((field->drows-1)==form->currow) && - ((field->dcols-1)==form->curcol)); - form->status |= _WINDOW_MODIFIED; - if (End_Of_Field && !Growable(field) && (field->opts & O_AUTOSKIP)) - result = Inter_Field_Navigation(FN_Next_Field,form); - else - { - if (End_Of_Field && Growable(field) && !Field_Grown(field,1)) - result = E_SYSTEM_ERROR; - else - { - IFN_Next_Character(form); - result = E_OK; - } - } - } + { + bool End_Of_Field= (((field->drows-1)==form->currow) && + ((field->dcols-1)==form->curcol)); + form->status |= _WINDOW_MODIFIED; + if (End_Of_Field && !Growable(field) && (field->opts & O_AUTOSKIP)) + result = Inter_Field_Navigation(FN_Next_Field,form); + else + { + if (End_Of_Field && Growable(field) && !Field_Grown(field,1)) + result = E_SYSTEM_ERROR; + else + { + IFN_Next_Character(form); + result = E_OK; + } + } + } } return result; } @@ -3694,9 +3693,9 @@ int form_driver(FORM * form, int c) } assert(form->current && - form->current->buf && - (form->current->form == form) - ); + form->current->buf && + (form->current->form == form) + ); if ( form->status & _IN_DRIVER ) RETURN(E_BAD_STATE); @@ -3712,38 +3711,38 @@ int form_driver(FORM * form, int c) { typedef int (*Generic_Method)(int (* const)(FORM *),FORM *); static const Generic_Method Generic_Methods[] = - { - Page_Navigation, /* overloaded to call field&form hooks */ - Inter_Field_Navigation, /* overloaded to call field hooks */ - NULL, /* Intra-Field is generic */ - Vertical_Scrolling, /* Overloaded to check multi-line */ - Horizontal_Scrolling, /* Overloaded to check single-line */ - Field_Editing, /* Overloaded to mark modification */ - NULL, /* Edit Mode is generic */ - NULL, /* Field Validation is generic */ - NULL /* Choice Request is generic */ - }; + { + Page_Navigation, /* overloaded to call field&form hooks */ + Inter_Field_Navigation, /* overloaded to call field hooks */ + NULL, /* Intra-Field is generic */ + Vertical_Scrolling, /* Overloaded to check multi-line */ + Horizontal_Scrolling, /* Overloaded to check single-line */ + Field_Editing, /* Overloaded to mark modification */ + NULL, /* Edit Mode is generic */ + NULL, /* Field Validation is generic */ + NULL /* Choice Request is generic */ + }; size_t nMethods = (sizeof(Generic_Methods)/sizeof(Generic_Methods[0])); size_t method = ((BI->keycode & ID_Mask) >> ID_Shft) & 0xffff; if ( (method >= nMethods) || !(BI->cmd) ) - res = E_SYSTEM_ERROR; + res = E_SYSTEM_ERROR; else - { - Generic_Method fct = Generic_Methods[method]; - if (fct) - res = fct(BI->cmd,form); - else - res = (BI->cmd)(form); - } + { + Generic_Method fct = Generic_Methods[method]; + if (fct) + res = fct(BI->cmd,form); + else + res = (BI->cmd)(form); + } } else { if (!(c & (~(int)MAX_REGULAR_CHARACTER)) && - isprint((unsigned char)c) && - Check_Char(form->current->type,c, - (TypeArgument *)(form->current->arg))) - res = Data_Entry(form,c); + isprint((unsigned char)c) && + Check_Char(form->current->type,c, + (TypeArgument *)(form->current->arg))) + res = Data_Entry(form,c); } _nc_Refresh_Current_Field(form); RETURN(res); @@ -3790,36 +3789,36 @@ int set_field_buffer(FIELD * field, int buffer, const char * value) unsigned int i = 0; for(v=value; *v && (i<len); v++,i++) - { - if (!isprint((unsigned char)*v)) - RETURN(E_BAD_ARGUMENT); - } + { + if (!isprint((unsigned char)*v)) + RETURN(E_BAD_ARGUMENT); + } } if (Growable(field)) { /* for a growable field we must assume zero terminated strings, because - somehow we have to detect the length of what should be copied. + somehow we have to detect the length of what should be copied. */ unsigned int vlen = strlen(value); if (vlen > len) - { - if (!Field_Grown(field, - (int)(1 + (vlen-len)/((field->rows+field->nrow)*field->cols)))) - RETURN(E_SYSTEM_ERROR); - - /* in this case we also have to check, wether or not the remaining - characters in value are also printable for buffer 0. */ - if (buffer==0) - { - unsigned int i; - - for(i=len; i<vlen; i++) - if (!isprint((int)(value[i]))) - RETURN(E_BAD_ARGUMENT); - } - len = vlen; - } + { + if (!Field_Grown(field, + (int)(1 + (vlen-len)/((field->rows+field->nrow)*field->cols)))) + RETURN(E_SYSTEM_ERROR); + + /* in this case we also have to check, wether or not the remaining + characters in value are also printable for buffer 0. */ + if (buffer==0) + { + unsigned int i; + + for(i=len; i<vlen; i++) + if (!isprint((int)(value[i]))) + RETURN(E_BAD_ARGUMENT); + } + len = vlen; + } } p = Address_Of_Nth_Buffer(field,buffer); @@ -3841,26 +3840,26 @@ int set_field_buffer(FIELD * field, int buffer, const char * value) if (s) { /* this means, value was null terminated and not greater than the - buffer. We have to pad with blanks. Please note that due to memccpy - logic s points after the terminating null. */ + buffer. We have to pad with blanks. Please note that due to memccpy + logic s points after the terminating null. */ s--; /* now we point to the terminator. */ assert(len >= (unsigned int)(s-p)); if (len > (unsigned int)(s-p)) - memset(s,C_BLANK,len-(unsigned int)(s-p)); + memset(s,C_BLANK,len-(unsigned int)(s-p)); } if (buffer==0) { int syncres; if (((syncres=Synchronize_Field( field ))!=E_OK) && - (res==E_OK)) - res = syncres; + (res==E_OK)) + res = syncres; if (((syncres=Synchronize_Linked_Fields(field ))!=E_OK) && - (res==E_OK)) - res = syncres; + (res==E_OK)) + res = syncres; } RETURN(res); -} +} /*--------------------------------------------------------------------------- | Facility : libnform |