~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

Linux Cross Reference
Tina6/tina-tools/tinatool/wdgts/gtk2/wdgtsGtk_tw_sglobal.c

Version: ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /**********
  2  * 
  3  * Copyright (c) 2003, Division of Imaging Science and Biomedical Engineering,
  4  * University of Manchester, UK.  All rights reserved.
  5  * 
  6  * Redistribution and use in source and binary forms, with or without modification, 
  7  * are permitted provided that the following conditions are met:
  8  * 
  9  *   . Redistributions of source code must retain the above copyright notice, 
 10  *     this list of conditions and the following disclaimer.
 11  *    
 12  *   . Redistributions in binary form must reproduce the above copyright notice,
 13  *     this list of conditions and the following disclaimer in the documentation 
 14  *     and/or other materials provided with the distribution.
 15  * 
 16  *   . Neither the name of the University of Manchester nor the names of its
 17  *     contributors may be used to endorse or promote products derived from this 
 18  *     software without specific prior written permission.
 19  * 
 20  * 
 21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
 22  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
 23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 
 24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 
 25  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
 26  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
 27  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 28  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
 29  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
 30  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
 31  * POSSIBILITY OF SUCH DAMAGE.
 32  *
 33  **********
 34  * 
 35  * Program :  TINA
 36  * File    :  $Source: /home/tina/cvs/tina-tools/tinatool/wdgts/gtk2/wdgtsGtk_tw_sglobal.c,v $
 37  * Date    :  $Date: 2007/02/15 01:55:50 $
 38  * Version :  $Revision: 1.2 $
 39  * CVS Id  :  $Id: wdgtsGtk_tw_sglobal.c,v 1.2 2007/02/15 01:55:50 paul Exp $
 40  *
 41  * Author  :  a.lacey@man.ac.uk, giob@man.ac.uk
 42  *
 43  *********
 44 */
 45 /** 
 46  *  @file  wdgtsGtk_tw_sglobal.c
 47  *  @brief Define and create GTK text entry field and its associated callbacks.
 48  *
 49  *  Functions to create a GTK text entry field and to define its use by linking it into 
 50  *  the TINA callback system using a Tw_callback struct.  Also defines the callback functions
 51  *  invoked when the entry field is used.  
 52  *
 53  *  Note that the functions in this file are duplicated for each widget set (xv, GTK, xm, etc ...).
 54  *
 55  */
 56 
 57 #include "wdgtsGtk_tw_sglobal.h"
 58 
 59 #if HAVE_CONFIG_H
 60 #   include <config.h>
 61 #endif
 62 
 63 #include <stdio.h>
 64 #include <sys/param.h>
 65 #include <string.h>
 66 #include <gtk/gtk.h>
 67 #include <tinatool/wdgts/gtk2/wdgts_GtkDef.h>
 68 #include <tinatool/wdgts/gtk2/wdgtsGtk_tw_command.h>
 69 #include <tinatool/wdgts/gtk2/wdgtsGtk_tw_tool.h>
 70 
 71 
 72 /**
 73  * @brief Copy text from entry widget to stored callback data field.  
 74  * @param twc Pointer to Tw_callback associated with this text entry widget.
 75  * 
 76  * Callback function for text entry widgets.  Each of these has an associated 
 77  * Tw_callback, and this function uses a setter function stored in the data field 
 78  * of the Tw_callback to copy the current widget text to the desired variable.
 79  *
 80  * Note that this callback is not invoked directly by the widget, but via a call
 81  * to tw_text_callback (in wdgtsGtk_tw_command.c).
 82  *
 83  */
 84 static void sglobal_call(Tw_callback * twc)
 85 {
 86   char   *ptr    = (char *) twc->data1;
 87   char   *string = (char *) gtk_entry_get_text(GTK_ENTRY(twc->widget));
 88 
 89   (void) strcpy(ptr, string);
 90 }
 91 
 92 /**
 93  * @brief   Replay text entry from current macro file.  
 94  * @param   twc   Pointer to Tw_callback associated with this widget.
 95  * @param   args  Pointer to required data, stored in the macro file.
 96  * 
 97  */
 98 static void sglobal_cmnd(Tw_callback * twc, char *args)
 99 {
100   char   *ptr = (char *) twc->data1;
101 
102   (void) sscanf(args, "%*s %s", ptr);
103   gtk_entry_set_text(GTK_ENTRY(twc->widget), (const gchar *) ptr);
104 }
105 
106 /**
107  * @brief  Record text entry in current macro file.  
108  * @param  fp   Pointer to current macro file.
109  * @param  twc  Pointer to Tw_callback associated with this widget.
110  *
111  */
112 static void sglobal_prnt(FILE *fp, Tw_callback *twc)
113 {
114     char   *ptr = (char *) twc->data1;
115 
116     (void) fprintf(fp, "%s %s\n", twc->name, ptr);
117 }
118 
119 /**
120  * @brief  Create new text entry field and its associated callback struct.  
121  * @param  name    String to be used as entry field identifier and label.
122  * @param  ptr     Pointer to storage for text entered in the field.
123  * @param  nchars  Maximum number of characters for input field.
124  * @return Tw_callback  Pointer to new Tw_callback associated with this entry field.
125  * 
126  * Creates new hbox for text entry field, and packs field and label in it.
127  *
128  * Invokes callback for each keypress, via call to tw_text_callback 
129  * (in wdgtsGtk_tw_command.c).
130  *
131  */
132 Tw_callback   *tw_sglobal(char *name, char *ptr, int nchars)
133 {
134   GtkWidget    *panel= tw_get_panel();
135   GtkWidget    *box;
136   GtkWidget    *stxlabel;
137   GtkWidget    *stxentry;
138 
139   Tw_callback  *twc;
140   char         *fullname = tw_extend_fullname(tw_get_toolname(), name);
141 
142   box = gtk_hbox_new(FALSE, 8);
143   gtk_container_add(GTK_CONTAINER(panel), box);
144   gtk_widget_show(box); 
145         
146   stxlabel = gtk_label_new(name);
147   stxentry = gtk_entry_new();
148   gtk_widget_set_usize(stxentry, (10+6*nchars), 22);
149   gtk_box_pack_start(GTK_BOX(box), stxlabel, FALSE, FALSE, 0);
150   gtk_box_pack_start(GTK_BOX(box), stxentry, FALSE, FALSE, 0);
151   gtk_widget_show(stxlabel);
152   gtk_widget_show(stxentry);
153 
154   twc = tw_callback_make(fullname, stxentry,
155                          sglobal_call, sglobal_cmnd, sglobal_prnt, (void (*) ()) NULL,
156                          (void *) ptr, NULL);
157 
158   /*  Invoke callback for GTK entry "changed" event (i.e. for each keypress) */
159   gtk_signal_connect(GTK_OBJECT(stxentry), "changed",
160                      GTK_SIGNAL_FUNC(tw_gtk_callback),
161                      (gpointer) twc);
162   
163   return (twc);
164 }
165 
166 /**
167  * @brief Reset text entry field when text has been altered.  
168  * @param twc  Pointer to Tw_callback associated with this text entry widget.
169  * 
170  * NOTE: NOT TESTED YET - GAB 9 Oct 2003.
171  * Fixed+tested+working - PAB 12/03/2010.
172  *
173  */
174 void tw_sglobal_reset(Tw_callback * twc)
175 {
176   char *pstring=NULL;
177   char string[MAXPATHLEN];
178  
179   if (twc == NULL) return;
180 
181   pstring = (char *) twc->data1;
182   (void) sprintf(string, "%s", pstring);
183   gtk_entry_set_text(GTK_ENTRY(twc->widget), string);
184 }
185 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

This page was automatically generated by the LXR engine.
Visit the LXR main site for more information.