File: probe.c

package info (click to toggle)
garlic 1.6-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster, sid, trixie
  • size: 4,516 kB
  • sloc: ansic: 52,465; makefile: 2,254
file content (118 lines) | stat: -rw-r--r-- 3,414 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/* Copyright (C) 2002-2003 Damir Zucic */

/*=============================================================================

				probe.c

Purpose:
	Execute probe command: change the radius of the bond probe, for
	all caught complexes.  Do not change default probe radius. This
	probe is used  to draw nice bonds.  It is  not used to generate
	molecular  surfaces:  each surface has its  own probe.  Default
	(hard-coded)  value is  0.80 angstroms.  Each structure has its
	own probe.

Input:
        (1) Pointer to MolComplexS structure.
        (2) The number of macromolecular complexes.
        (3) Pointer to RuntimeS structure.
        (4) Pointer to ConfigS structure.
        (5) Pointer to GUIS structure.
        (6) Pointer to NearestAtomS structure.
        (7) The number of pixels in the main window free area.
        (8) Pointer to refreshI.
        (9) Pointer to the remainder of the command string.

Output:
	(1) The bond probe radius set.
	(2) Return value.

Return value:
	(1) Positive (command) code on success.
	(2) Negative (error) code on failure.

========includes:============================================================*/

#include <stdio.h>

#include <string.h>
#include <ctype.h>

#include <X11/Xlib.h>
#include <X11/Xutil.h>
#include <X11/Xos.h>
#include <X11/Xatom.h>

#include "defines.h"
#include "commands.h"
#include "typedefs.h"

/*======function prototypes:=================================================*/

size_t		MainRefresh_ (MolComplexS *, int,
			      RuntimeS *, ConfigS *, GUIS *,
			      NearestAtomS *, size_t, unsigned int);
int		ControlRefresh_ (MolComplexS *, ConfigS *, GUIS *);

/*======execute probe command:===============================================*/

int Probe_ (MolComplexS *mol_complexSP, int mol_complexesN,
	    RuntimeS *runtimeSP,
	    ConfigS *configSP, GUIS *guiSP,
	    NearestAtomS *nearest_atomSP, size_t pixelsN,
	    unsigned int *refreshIP, char *stringP)
{
char		*P;
int		n;
double		value;
int		mol_complexI;
MolComplexS	*curr_mol_complexSP;

/* Replace each non-numeric character (except */
/* minus sign and  decimal point) with space: */
P = stringP;
while ((n = *P++) != '\0')
	{
	if (!isdigit (n) && (n != '-') && (n != '.')) *(P - 1) = ' ';
	}

/* Try to extract the bond probe radius: */
if (sscanf (stringP, "%lf", &value) != 1)
	{
	strcpy (runtimeSP->messageA,
		"Failed to extract the bond probe radius!");
	runtimeSP->message_length = strlen (runtimeSP->messageA);
	return ERROR_PROBE;
	}

/* Check the bond probe radius (must be positive): */
if (value < 0.0)
	{
	strcpy (runtimeSP->messageA, "Positive value expected!");
	runtimeSP->message_length = strlen (runtimeSP->messageA);
	return ERROR_PROBE;
	}

/* On success, set the bond probe radius for each caught complex: */
for (mol_complexI = 0; mol_complexI < mol_complexesN; mol_complexI++)
	{
	curr_mol_complexSP = mol_complexSP + mol_complexI;
	if (curr_mol_complexSP->catchF == 0) continue;
	curr_mol_complexSP->bond_probe_radius = value;
	}

/* Refresh the main window: */
(*refreshIP)++;
MainRefresh_ (mol_complexSP, mol_complexesN, runtimeSP, configSP, guiSP,
	      nearest_atomSP, pixelsN, *refreshIP);

/* Refresh the control window: */
ControlRefresh_ (mol_complexSP + runtimeSP->default_complexI, configSP, guiSP);

/* Return the command code: */
return COMMAND_PROBE;
}

/*===========================================================================*/