8
8
*
9
9
*
10
10
* IDENTIFICATION
11
- * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.194 2002/08/18 01:35:39 momjian Exp $
11
+ * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.195 2002/08/27 14:49:52 momjian Exp $
12
12
*
13
13
*-------------------------------------------------------------------------
14
14
*/
@@ -1063,34 +1063,33 @@ connectDBComplete(PGconn *conn)
1063
1063
if (conn == NULL || conn -> status == CONNECTION_BAD )
1064
1064
return 0 ;
1065
1065
1066
- /*
1067
- * Prepare to time calculations, if connect_timeout isn't zero.
1068
- */
1069
- if (conn -> connect_timeout != NULL )
1066
+ /*
1067
+ * Prepare to time calculations, if connect_timeout isn't zero.
1068
+ */
1069
+ if (conn -> connect_timeout != NULL )
1070
1070
{
1071
- remains .tv_sec = atoi (conn -> connect_timeout );
1072
- if (!remains .tv_sec )
1073
- {
1074
- conn -> status = CONNECTION_BAD ;
1075
- return 0 ;
1076
- }
1077
- remains .tv_usec = 0 ;
1078
- rp = & remains ;
1079
- }
1071
+ remains .tv_sec = atoi (conn -> connect_timeout );
1072
+ if (!remains .tv_sec )
1073
+ {
1074
+ conn -> status = CONNECTION_BAD ;
1075
+ return 0 ;
1076
+ }
1077
+ remains .tv_usec = 0 ;
1078
+ rp = & remains ;
1079
+ }
1080
1080
1081
+ while (rp == NULL || remains .tv_sec > 0 || (remains .tv_sec == 0 && remains .tv_usec > 0 ))
1082
+ {
1083
+ /*
1084
+ * If connecting timeout is set, get current time.
1085
+ */
1086
+ if (rp != NULL && gettimeofday (& start_time , NULL ) == -1 )
1087
+ {
1088
+ conn -> status = CONNECTION_BAD ;
1089
+ return 0 ;
1090
+ }
1081
1091
1082
- while (rp == NULL || remains .tv_sec > 0 || (remains .tv_sec == 0 && remains .tv_usec > 0 ))
1083
- {
1084
1092
/*
1085
- * If connecting timeout is set, get current time.
1086
- */
1087
- if (rp != NULL && gettimeofday (& start_time , NULL ) == -1 )
1088
- {
1089
- conn -> status = CONNECTION_BAD ;
1090
- return 0 ;
1091
- }
1092
-
1093
- /*
1094
1093
* Wait, if necessary. Note that the initial state (just after
1095
1094
* PQconnectStart) is to wait for the socket to select for
1096
1095
* writing.
@@ -1104,7 +1103,7 @@ connectDBComplete(PGconn *conn)
1104
1103
return 1 ; /* success! */
1105
1104
1106
1105
case PGRES_POLLING_READING :
1107
- if (pqWaitTimed (1 , 0 , conn , rp ))
1106
+ if (pqWaitTimed (1 , 0 , conn , rp ))
1108
1107
{
1109
1108
conn -> status = CONNECTION_BAD ;
1110
1109
return 0 ;
@@ -1130,27 +1129,28 @@ connectDBComplete(PGconn *conn)
1130
1129
*/
1131
1130
flag = PQconnectPoll (conn );
1132
1131
1133
- /*
1134
- * If connecting timeout is set, calculate remain time.
1135
- */
1136
- if (NULL != rp ) {
1137
- if (-1 == gettimeofday (& finish_time , NULL ))
1138
- {
1139
- conn -> status = CONNECTION_BAD ;
1140
- return 0 ;
1141
- }
1142
- if (0 > (finish_time .tv_usec -= start_time .tv_usec ))
1143
- {
1144
- remains .tv_sec ++ ;
1145
- finish_time .tv_usec += 1000000 ;
1146
- }
1147
- if (0 > (remains .tv_usec -= finish_time .tv_usec ))
1148
- {
1149
- remains .tv_sec -- ;
1150
- remains .tv_usec += 1000000 ;
1151
- }
1152
- remains .tv_sec -= finish_time .tv_sec - start_time .tv_sec ;
1153
- }
1132
+ /*
1133
+ * If connecting timeout is set, calculate remain time.
1134
+ */
1135
+ if (NULL != rp )
1136
+ {
1137
+ if (gettimeofday (& finish_time , NULL ) == -1 )
1138
+ {
1139
+ conn -> status = CONNECTION_BAD ;
1140
+ return 0 ;
1141
+ }
1142
+ if ((finish_time .tv_usec -= start_time .tv_usec ) < 0 )
1143
+ {
1144
+ remains .tv_sec ++ ;
1145
+ finish_time .tv_usec += 1000000 ;
1146
+ }
1147
+ if ((remains .tv_usec -= finish_time .tv_usec ) < 0 )
1148
+ {
1149
+ remains .tv_sec -- ;
1150
+ remains .tv_usec += 1000000 ;
1151
+ }
1152
+ remains .tv_sec -= finish_time .tv_sec - start_time .tv_sec ;
1153
+ }
1154
1154
}
1155
1155
conn -> status = CONNECTION_BAD ;
1156
1156
return 0 ;
0 commit comments