Changelog
+Daniel S (16 Jan 2008)
+- Calls to Curl_failf() are not supposed to provide a trailing newline as the
+ function itself adds that. Fixed on 50 or something strings!
+
Daniel S (15 Jan 2008)
- I made the torture test on test 530 go through. This was actually due to
silly code left from when we switched to let the multi handle "hold" the dns
o curl-config --libs skips /usr/lib64
o range support for file:// transfers
o libcurl hang with huge POST request and request-body read from callback
+ o removed extra newlines from many error messages
This release includes the following known bugs:
rc = getnameinfo((struct sockaddr *)&ss, sslen, hbuf, sizeof(hbuf), NULL,
0, NIFLAGS);
if(rc) {
- failf(data, "getnameinfo() returned %d \n", rc);
+ failf(data, "getnameinfo() returned %d", rc);
return CURLE_FTP_PORT_FAILED;
}
host = hbuf; /* use this host name */
ftpc->count1 = 1;
break;
default:
- failf(data, "unsupported parameter to CURLOPT_FTPSSLAUTH: %d\n",
+ failf(data, "unsupported parameter to CURLOPT_FTPSSLAUTH: %d",
data->set.ftpsslauth);
return CURLE_FAILED_INIT; /* we don't know what to do */
}
*
* Copyright (c) 1995, 1996, 1997, 1998, 1999 Kungliga Tekniska Högskolan
* (Royal Institute of Technology, Stockholm, Sweden).
- * Copyright (c) 2004 - 2007 Daniel Stenberg
+ * Copyright (c) 2004 - 2008 Daniel Stenberg
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
tmp=0;
}
if(!tmp || !ptr) {
- Curl_failf(conn->data, "Failed to decode base64 in reply.\n");
+ Curl_failf(conn->data, "Failed to decode base64 in reply");
Curl_set_command_prot(conn, save);
return CURLE_FTP_WEIRD_SERVER_REPLY;
}
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
- * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al.
+ * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al.
*
* This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
{
switch(err) {
case SEC_ERROR_BAD_PASSWORD:
- failf(conn->data, "Unable to load client key: Incorrect password\n");
+ failf(conn->data, "Unable to load client key: Incorrect password");
return 1;
case SEC_ERROR_UNKNOWN_CERT:
- failf(conn->data, "Unable to load certificate %s\n", filename);
+ failf(conn->data, "Unable to load certificate %s", filename);
return 1;
default:
break;
if(PK11_NeedLogin(slot) && PK11_NeedUserInit(slot)) {
if(slot == PK11_GetInternalKeySlot()) {
- failf(conn->data, "The NSS database has not been initialized.\n");
+ failf(conn->data, "The NSS database has not been initialized");
}
else {
- failf(conn->data, "The token %s has not been initialized.",
+ failf(conn->data, "The token %s has not been initialized",
PK11_GetTokenName(slot));
}
PK11_FreeSlot(slot);
return CURLE_OPERATION_TIMEDOUT;
}
- failf(conn->data, "SSL write: error %d\n", err);
+ failf(conn->data, "SSL write: error %d", err);
return -1;
}
return rc; /* number of bytes */
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
- * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al.
+ * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al.
*
* This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
break;
case SSL_ERROR_IO:
- failf(data, "SSL_Init() I/O error: %s\n", strerror(errno));
+ failf(data, "SSL_Init() I/O error: %s", strerror(errno));
return CURLE_SSL_CONNECT_ERROR;
case SSL_ERROR_BAD_CIPHER_SUITE:
return CURLE_SSL_CERTPROBLEM;
default:
- failf(data, "SSL_Init(): %s\n", SSL_Strerror(rc, NULL));
+ failf(data, "SSL_Init(): %s", SSL_Strerror(rc, NULL));
return CURLE_SSL_CONNECT_ERROR;
}
h = SSL_Create(conn->sock[sockindex], SSL_ENCRYPT);
if(!h) {
- failf(conn->data, "SSL_Create() I/O error: %s\n", strerror(errno));
+ failf(conn->data, "SSL_Create() I/O error: %s", strerror(errno));
return CURLE_SSL_CONNECT_ERROR;
- }
+ }
connssl->handle = h;
return CURLE_OK;
return CURLE_SSL_CERTPROBLEM;
case SSL_ERROR_IO:
- failf(data, "SSL_Handshake(): %s\n", SSL_Strerror(rc, NULL));
+ failf(data, "SSL_Handshake(): %s", SSL_Strerror(rc, NULL));
return CURLE_SSL_CONNECT_ERROR;
default:
- failf(data, "SSL_Init(): %s\n", SSL_Strerror(rc, NULL));
+ failf(data, "SSL_Init(): %s", SSL_Strerror(rc, NULL));
return CURLE_SSL_CONNECT_ERROR;
}
if(rc) {
if(rc == SSL_ERROR_IO) {
- failf(data, "SSL_Destroy() I/O error: %s\n", strerror(errno));
+ failf(data, "SSL_Destroy() I/O error: %s", strerror(errno));
return -1;
}
/* An SSL error. */
- failf(data, "SSL_Destroy() returned error %d\n", SSL_Strerror(rc, NULL));
+ failf(data, "SSL_Destroy() returned error %d", SSL_Strerror(rc, NULL));
return -1;
}
nread = read(conn->sock[sockindex], buf, sizeof(buf));
if(nread < 0) {
- failf(data, "read: %s\n", strerror(errno));
+ failf(data, "read: %s", strerror(errno));
rc = -1;
}
return 0;
}
- failf(conn->data, "SSL_Write() I/O error: %s\n", strerror(errno));
+ failf(conn->data, "SSL_Write() I/O error: %s", strerror(errno));
return -1;
}
/* An SSL error. */
- failf(conn->data, "SSL_Write() returned error %d\n",
+ failf(conn->data, "SSL_Write() returned error %d",
SSL_Strerror(rc, NULL));
return -1;
}
return -1;
}
- failf(conn->data, "SSL_Read() I/O error: %s\n", strerror(errno));
+ failf(conn->data, "SSL_Read() I/O error: %s", strerror(errno));
return -1;
default:
- failf(conn->data, "SSL read error: %s\n", SSL_Strerror(nread, NULL));
+ failf(conn->data, "SSL read error: %s", SSL_Strerror(nread, NULL));
return -1;
}
}
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
- * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al.
+ * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al.
*
* This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
break;
}
else {
- failf(data, "Failure initialising sftp session\n");
+ failf(data, "Failure initialising sftp session");
state(conn, SSH_SESSION_FREE);
sshc->actualcode = CURLE_FAILED_INIT;
break;
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
- * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al.
+ * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al.
*
* This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
key_file=cert_file;
case SSL_FILETYPE_ASN1:
if(SSL_CTX_use_PrivateKey_file(ctx, key_file, file_type) != 1) {
- failf(data, "unable to set private key file: '%s' type %s\n",
+ failf(data, "unable to set private key file: '%s' type %s",
key_file, key_type?key_type:"PEM");
return 0;
}
UI_METHOD *ui_method = UI_OpenSSL();
#endif
if(!key_file || !key_file[0]) {
- failf(data, "no key set to load from crypto engine\n");
+ failf(data, "no key set to load from crypto engine");
return 0;
}
/* the typecast below was added to please mingw32 */
#endif
data->set.str[STRING_KEY_PASSWD]);
if(!priv_key) {
- failf(data, "failed to load private key from crypto engine\n");
+ failf(data, "failed to load private key from crypto engine");
return 0;
}
if(SSL_CTX_use_PrivateKey(ctx, priv_key) != 1) {
- failf(data, "unable to set private key\n");
+ failf(data, "unable to set private key");
EVP_PKEY_free(priv_key);
return 0;
}
EVP_PKEY_free(priv_key); /* we don't need the handle any more... */
}
else {
- failf(data, "crypto engine not set, can't load private key\n");
+ failf(data, "crypto engine not set, can't load private key");
return 0;
}
}
break;
#else
- failf(data, "file type ENG for private key not supported\n");
+ failf(data, "file type ENG for private key not supported");
return 0;
#endif
case SSL_FILETYPE_PKCS12:
if(!cert_done) {
- failf(data, "file type P12 for private key not supported\n");
+ failf(data, "file type P12 for private key not supported");
return 0;
}
break;
default:
- failf(data, "not supported file type for private key\n");
+ failf(data, "not supported file type for private key");
return 0;
}
ssl=SSL_new(ctx);
if(NULL == ssl) {
- failf(data,"unable to create an SSL structure\n");
+ failf(data,"unable to create an SSL structure");
return 0;
}
equivalent. */
return 0;
case SSL_ERROR_SYSCALL:
- failf(conn->data, "SSL_write() returned SYSCALL, errno = %d\n",
+ failf(conn->data, "SSL_write() returned SYSCALL, errno = %d",
SOCKERRNO);
return -1;
case SSL_ERROR_SSL:
/* A failure in the SSL library occurred, usually a protocol error.
The OpenSSL error queue contains more information on the error. */
sslerror = ERR_get_error();
- failf(conn->data, "SSL_write() error: %s\n",
+ failf(conn->data, "SSL_write() error: %s",
ERR_error_string(sslerror, error_buffer));
return -1;
}
/* a true error */
- failf(conn->data, "SSL_write() return error %d\n", err);
+ failf(conn->data, "SSL_write() return error %d", err);
return -1;
}
return (ssize_t)rc; /* number of bytes */
state->conn->ip_addr->ai_addr,
state->conn->ip_addr->ai_addrlen);
if(sbytes < 0) {
- failf(data, "%s\n", Curl_strerror(state->conn, SOCKERRNO));
+ failf(data, "%s", Curl_strerror(state->conn, SOCKERRNO));
}
Curl_safefree(filename);
break;
break;
default:
- failf(state->conn->data, "tftp_send_first: internal error\n");
+ failf(state->conn->data, "tftp_send_first: internal error");
break;
}
return res;
"Received unexpected DATA packet block %d\n", rblock);
state->retries++;
if(state->retries>state->retry_max) {
- failf(data, "tftp_rx: giving up waiting for block %d\n",
+ failf(data, "tftp_rx: giving up waiting for block %d",
state->block+1);
return CURLE_TFTP_ILLEGAL;
}
(struct sockaddr *)&state->remote_addr,
state->remote_addrlen);
if(sbytes < 0) {
- failf(data, "%s\n", Curl_strerror(state->conn, SOCKERRNO));
+ failf(data, "%s", Curl_strerror(state->conn, SOCKERRNO));
return CURLE_SEND_ERROR;
}
state->remote_addrlen);
/* Check all sbytes were sent */
if(sbytes<0) {
- failf(data, "%s\n", Curl_strerror(state->conn, SOCKERRNO));
+ failf(data, "%s", Curl_strerror(state->conn, SOCKERRNO));
return CURLE_SEND_ERROR;
}
}
break;
default:
- failf(data, "%s\n", "tftp_rx: internal error");
+ failf(data, "%s", "tftp_rx: internal error");
return CURLE_TFTP_ILLEGAL; /* not really the perfect return code for
this */
}
state->remote_addrlen);
/* Check all sbytes were sent */
if(sbytes<0) {
- failf(data, "%s\n", Curl_strerror(state->conn, SOCKERRNO));
+ failf(data, "%s", Curl_strerror(state->conn, SOCKERRNO));
res = CURLE_SEND_ERROR;
}
}
state->remote_addrlen);
/* Check all sbytes were sent */
if(sbytes<0) {
- failf(data, "%s\n", Curl_strerror(state->conn, SOCKERRNO));
+ failf(data, "%s", Curl_strerror(state->conn, SOCKERRNO));
return CURLE_SEND_ERROR;
}
/* Update the progress meter */
state->remote_addrlen);
/* Check all sbytes were sent */
if(sbytes<0) {
- failf(data, "%s\n", Curl_strerror(state->conn, SOCKERRNO));
+ failf(data, "%s", Curl_strerror(state->conn, SOCKERRNO));
return CURLE_SEND_ERROR;
}
/* since this was a re-send, we remain at the still byte position */
break;
default:
- failf(data, "%s\n", "tftp_tx: internal error");
+ failf(data, "%s", "tftp_tx: internal error");
break;
}
break;
default:
DEBUGF(infof(data, "STATE: %d\n", state->state));
- failf(data, "%s\n", "Internal state machine error");
+ failf(data, "%s", "Internal state machine error");
res = CURLE_TFTP_ILLEGAL;
break;
}
rc = bind(state->sockfd, (struct sockaddr *)&state->local_addr,
conn->ip_addr->ai_addrlen);
if(rc) {
- failf(conn->data, "bind() failed; %s\n",
+ failf(conn->data, "bind() failed; %s",
Curl_strerror(conn, SOCKERRNO));
return CURLE_COULDNT_CONNECT;
}
if(rc == -1) {
/* bail out */
int error = SOCKERRNO;
- failf(data, "%s\n", Curl_strerror(conn, error));
+ failf(data, "%s", Curl_strerror(conn, error));
event = TFTP_EVENT_ERROR;
}
else if(rc==0) {
/* Sanity check packet length */
if(state->rbytes < 4) {
- failf(data, "Received too short packet\n");
+ failf(data, "Received too short packet");
/* Not a timeout, but how best to handle it? */
event = TFTP_EVENT_TIMEOUT;
}
case TFTP_EVENT_RRQ:
case TFTP_EVENT_WRQ:
default:
- failf(data, "%s\n", "Internal error: Unexpected packet");
+ failf(data, "%s", "Internal error: Unexpected packet");
break;
}
buffersize, conn->fread_in);
if(nread == CURL_READFUNC_ABORT) {
- failf(data, "operation aborted by callback\n");
+ failf(data, "operation aborted by callback");
return CURLE_ABORTED_BY_CALLBACK;
}
else if(nread == CURL_READFUNC_PAUSE) {
err = (data->set.seek_func)(data->set.seek_client, 0, SEEK_SET);
if(err) {
- failf(data, "seek callback returned error %d\n", (int)err);
+ failf(data, "seek callback returned error %d", (int)err);
return CURLE_SEND_FAIL_REWIND;
}
}
if(err) {
/* FIXME: convert to a human readable error message */
- failf(data, "ioctl callback returned error %d\n", (int)err);
+ failf(data, "ioctl callback returned error %d", (int)err);
return CURLE_SEND_FAIL_REWIND;
}
}
}
/* no callback set or failure aboe, makes us fail at once */
- failf(data, "necessary data rewind wasn't possible\n");
+ failf(data, "necessary data rewind wasn't possible");
return CURLE_SEND_FAIL_REWIND;
}
}
CURLcode res;
if(!data->change.url) {
/* we can't do anything wihout URL */
- failf(data, "No URL set!\n");
+ failf(data, "No URL set!");
return CURLE_URL_MALFORMAT;
}