4 * This source code is part of
8 * GROningen MAchine for Chemical Simulations
12 * Copyright (c) 1991-2001
13 * BIOSON Research Institute, Dept. of Biophysical Chemistry
14 * University of Groningen, The Netherlands
16 * This program is free software; you can redistribute it and/or
17 * modify it under the terms of the GNU General Public License
18 * as published by the Free Software Foundation; either version 2
19 * of the License, or (at your option) any later version.
21 * If you want to redistribute modifications, please consider that
22 * scientific software is very special. Version control is crucial -
23 * bugs must be traceable. We will be happy to consider code for
24 * inclusion in the official distribution, but derived work must not
25 * be called official GROMACS. Details are found in the README & COPYING
26 * files - if they are missing, get the official version at www.gromacs.org.
28 * To help us fund GROMACS development, we humbly ask that you cite
29 * the papers on the package - you can find them in the top README file.
31 * Do check out http://www.gromacs.org , or mail us at gromacs@gromacs.org .
34 * Giving Russians Opium May Alter Current Situation
36 static char *SRCID_dialogs_c = "$Id$";
49 #define MBFLAGS /* MB_APPLMODAL | */ MB_DONTSHOW
51 void write_gmx(t_x11 *x11,t_gmx *gmx,int mess)
55 letter.type=ClientMessage;
56 letter.xclient.display=x11->disp;
57 letter.xclient.window=gmx->wd->self;
58 letter.xclient.message_type=0;
59 letter.xclient.format=32;
60 letter.xclient.data.l[0]=mess;
61 letter.xclient.data.l[1]=Button1;
62 XSendEvent(x11->disp,letter.xclient.window,True,0,&letter);
65 static void shell_comm(char *title,char *script,int nsleep)
72 if ((tfil=fopen(tmp,"w"))==NULL) {
76 fprintf(tfil,"%s\n",script);
77 fprintf(tfil,"sleep %d\n",nsleep);
80 sprintf(command,"xterm -title %s -e sh %s",title,tmp);
82 fprintf(stderr,"command: %s\n",command);
90 void show_mb(t_gmx *gmx,int mb)
92 if (mb >=0 && mb < emNR) {
94 ShowDlg(gmx->mboxes[mb]);
98 static void hide_mb(t_gmx *gmx)
100 if (gmx->which_mb > 0 && gmx->which_mb < emNR)
101 HideDlg(gmx->mboxes[gmx->which_mb]);
104 static void MBCallback(t_x11 *x11,int dlg_mess,int item_id,
105 char *set,void *data)
110 if (dlg_mess==DLG_EXIT)
114 static t_dlg *about_mb(t_x11 *x11,t_gmx *gmx)
116 static char *lines[]={
118 " Machine for Simulating Chemistry",
119 " Copyright (c) 1992-2000",
120 " Dept. of Biophysical Chemistry",
121 " University of Groningen"
124 return MessageBox(x11,gmx->wd->self,gmx->wd->text,
125 asize(lines),lines,MB_OK | MB_ICONGMX | MBFLAGS,
129 static void QuitCB(t_x11 *x11,int dlg_mess,int item_id,
130 char *set,void *data)
135 if (dlg_mess==DLG_EXIT) {
137 if (strcasecmp("yes",set)==0)
138 write_gmx(x11,gmx,IDTERM);
142 static t_dlg *quit_mb(t_x11 *x11,t_gmx *gmx)
144 static char *lines[]={
145 " Do you really want to Quit ?"
148 return MessageBox(x11,gmx->wd->self,gmx->wd->text,
150 MB_YESNO | MB_ICONSTOP | MBFLAGS,
154 static t_dlg *help_mb(t_x11 *x11,t_gmx *gmx)
156 static char *lines[]={
157 " Help will soon be added"
160 return MessageBox(x11,gmx->wd->self,gmx->wd->text,
162 MB_OK | MB_ICONINFORMATION | MBFLAGS,
166 static t_dlg *ni_mb(t_x11 *x11,t_gmx *gmx)
168 static char *lines[]={
169 " This feature has not been",
173 return MessageBox(x11,gmx->wd->self,gmx->wd->text,
175 MB_OK | MB_ICONEXCLAMATION | MBFLAGS,
179 enum { eExE, eExGrom, eExPdb, eExConf, eExNR };
181 static void ExportCB(t_x11 *x11,int dlg_mess,int item_id,
182 char *set,void *data)
189 dlg=gmx->dlgs[edExport];
194 gmx->ExpMode=eExpGromos;
197 gmx->ExpMode=eExpPDB;
203 fprintf(stderr,"exportcb: item_id=%d\n",item_id);
207 if ((bOk=(strcasecmp("ok",set))==0))
208 strcpy(gmx->confout,EditText(dlg,eExConf));
211 write_gmx(x11,gmx,IDDOEXPORT);
216 enum { eg0, egTOPOL, egCONFIN, egPARAM, eg1, eg1PROC, eg32PROC };
218 static void Extract(t_dlg *dlg,int ID,char *buf)
227 enum bond_set { ebShowH=11, ebDPlus, ebRMPBC, ebCue, ebSkip, ebWait };
229 static void BondsCB(t_x11 *x11,int dlg_mess,int item_id,
230 char *set,void *data)
234 bool bOk,bBond=FALSE;
240 ebond = gmx->man->molw->bond_type;
241 ebox = gmx->man->molw->boxtype;
245 if (item_id <= eBNR) {
249 else if (item_id <= eBNR+esbNR+1) {
250 ebox = item_id-eBNR-2;
255 #define DO_NOT(b) (b) = (!(b))
259 toggle_hydrogen(x11,gmx->man->molw);
262 DO_NOT(gmx->man->bPlus);
264 fprintf(stderr,"gmx->man->bPlus=%s\n",bool_names[gmx->man->bPlus]);
268 set_box_type(x11,gmx->man->molw,ebond);
271 toggle_pbc(gmx->man);
274 DO_NOT(gmx->man->bSort);
276 fprintf(stderr,"gmx->man->bSort=%s\n",bool_names[gmx->man->bSort]);
280 sscanf(set,"%d",&nskip);
282 fprintf(stderr,"nskip: %d frames\n",nskip);
285 gmx->man->nSkip=nskip;
288 sscanf(set,"%d",&nwait);
290 fprintf(stderr,"wait: %d ms\n",nwait);
293 gmx->man->nWait=nwait;
296 fprintf(stderr,"item_id: %d, set: %s\n",item_id,set);
303 bOk=(strcasecmp("ok",set)==0);
304 HideDlg(gmx->dlgs[edBonds]);
309 write_gmx(x11,gmx,IDTHIN);
312 write_gmx(x11,gmx,IDFAT);
315 write_gmx(x11,gmx,IDVERYFAT);
318 write_gmx(x11,gmx,IDBALLS);
321 fatal_error(0,"Invalid bond type %d at %s, %d",
322 ebond,__FILE__,__LINE__);
328 write_gmx(x11,gmx,IDNOBOX);
331 write_gmx(x11,gmx,IDRECTBOX);
334 write_gmx(x11,gmx,IDTRIBOX);
337 write_gmx(x11,gmx,IDTOBOX);
340 fatal_error(0,"Invalid box type %d at %s, %d",
341 ebox,__FILE__,__LINE__);
349 enum { esFUNCT=1, esBSHOW, esINFIL, esINDEXFIL, esLSQ, esSHOW, esPLOTFIL };
351 static bool in_set(int i,int n,int set[])
360 typedef t_dlg *t_mmb(t_x11 *x11,t_gmx *gmx);
374 void init_dlgs(t_x11 *x11,t_gmx *gmx)
376 static t_dlginit di[] = {
377 { edExport, "export.dlg", ExportCB },
378 { edBonds, "bonds.dlg", BondsCB }
380 static t_mbinit mi[emNR] = {
381 { emQuit, quit_mb, QuitCB },
382 { emHelp, help_mb, MBCallback },
383 { emAbout, about_mb, MBCallback },
384 { emNotImplemented, ni_mb, MBCallback }
388 snew(gmx->dlgs,edNR);
389 for(i=0; (i<asize(di)); i++)
390 gmx->dlgs[i]=ReadDlg(x11,gmx->wd->self,di[i].dlgfile,
391 x11->fg,x11->bg,di[i].dlgfile,
392 0,0,TRUE,FALSE,di[i].cb,gmx);
394 gmx->dlgs[edFilter]=select_filter(x11,gmx);
396 snew(gmx->mboxes,emNR);
397 for(i=0; (i<emNR); i++)
398 gmx->mboxes[i]=mi[i].mmb(x11,gmx);
401 void done_dlgs(t_gmx *gmx)
405 for(i=0; (i<edNR); i++)
406 FreeDlg(gmx->dlgs[i]);
407 for(i=0; (i<emNR); i++)
408 FreeDlg(gmx->mboxes[i]);
411 void edit_file(char *fn)
416 sprintf(script,"vi %s",fn);
417 shell_comm(fn,script,0);