pop3.c: Code policing and tidy up
Corrected character and line spacing and re-ordered list and retr functions based on the order of their state machines.
This commit is contained in:
122
lib/pop3.c
122
lib/pop3.c
@@ -127,7 +127,6 @@ const struct Curl_handler Curl_handler_pop3 = {
|
|||||||
PROTOPT_CLOSEACTION | PROTOPT_NOURLQUERY /* flags */
|
PROTOPT_CLOSEACTION | PROTOPT_NOURLQUERY /* flags */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#ifdef USE_SSL
|
#ifdef USE_SSL
|
||||||
/*
|
/*
|
||||||
* POP3S protocol handler.
|
* POP3S protocol handler.
|
||||||
@@ -180,7 +179,6 @@ static const struct Curl_handler Curl_handler_pop3_proxy = {
|
|||||||
PROTOPT_NONE /* flags */
|
PROTOPT_NONE /* flags */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#ifdef USE_SSL
|
#ifdef USE_SSL
|
||||||
/*
|
/*
|
||||||
* HTTP-proxyed POP3S protocol handler.
|
* HTTP-proxyed POP3S protocol handler.
|
||||||
@@ -208,7 +206,6 @@ static const struct Curl_handler Curl_handler_pop3s_proxy = {
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* function that checks for a pop3 status code at the start of the given
|
/* function that checks for a pop3 status code at the start of the given
|
||||||
string */
|
string */
|
||||||
static int pop3_endofresp(struct pingpong *pp,
|
static int pop3_endofresp(struct pingpong *pp,
|
||||||
@@ -383,6 +380,7 @@ static CURLcode pop3_state_pass_resp(struct connectdata *conn,
|
|||||||
{
|
{
|
||||||
CURLcode result = CURLE_OK;
|
CURLcode result = CURLE_OK;
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
|
|
||||||
(void)instate; /* no use for this yet */
|
(void)instate; /* no use for this yet */
|
||||||
|
|
||||||
if(pop3code != 'O') {
|
if(pop3code != 'O') {
|
||||||
@@ -395,51 +393,6 @@ static CURLcode pop3_state_pass_resp(struct connectdata *conn,
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* for the retr response */
|
|
||||||
static CURLcode pop3_state_retr_resp(struct connectdata *conn,
|
|
||||||
int pop3code,
|
|
||||||
pop3state instate)
|
|
||||||
{
|
|
||||||
CURLcode result = CURLE_OK;
|
|
||||||
struct SessionHandle *data = conn->data;
|
|
||||||
struct FTP *pop3 = data->state.proto.pop3;
|
|
||||||
struct pop3_conn *pop3c = &conn->proto.pop3c;
|
|
||||||
struct pingpong *pp = &pop3c->pp;
|
|
||||||
|
|
||||||
(void)instate; /* no use for this yet */
|
|
||||||
|
|
||||||
if('O' != pop3code) {
|
|
||||||
state(conn, POP3_STOP);
|
|
||||||
return CURLE_RECV_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* POP3 download */
|
|
||||||
Curl_setup_transfer(conn, FIRSTSOCKET, -1, FALSE, pop3->bytecountp,
|
|
||||||
-1, NULL); /* no upload here */
|
|
||||||
|
|
||||||
if(pp->cache) {
|
|
||||||
/* The header "cache" contains a bunch of data that is actually body
|
|
||||||
content so send it as such. Note that there may even be additional
|
|
||||||
"headers" after the body */
|
|
||||||
|
|
||||||
if(!data->set.opt_no_body) {
|
|
||||||
result = Curl_pop3_write(conn, pp->cache, pp->cache_size);
|
|
||||||
if(result)
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Free the cache */
|
|
||||||
Curl_safefree(pp->cache);
|
|
||||||
|
|
||||||
/* Reset the cache size */
|
|
||||||
pp->cache_size = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
state(conn, POP3_STOP);
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* for the list response */
|
/* for the list response */
|
||||||
static CURLcode pop3_state_list_resp(struct connectdata *conn,
|
static CURLcode pop3_state_list_resp(struct connectdata *conn,
|
||||||
int pop3code,
|
int pop3code,
|
||||||
@@ -501,6 +454,7 @@ static CURLcode pop3_state_list_single_resp(struct connectdata *conn,
|
|||||||
{
|
{
|
||||||
CURLcode result = CURLE_OK;
|
CURLcode result = CURLE_OK;
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
|
|
||||||
(void)instate; /* no use for this yet */
|
(void)instate; /* no use for this yet */
|
||||||
|
|
||||||
if(pop3code != 'O') {
|
if(pop3code != 'O') {
|
||||||
@@ -509,20 +463,52 @@ static CURLcode pop3_state_list_single_resp(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
state(conn, POP3_STOP);
|
state(conn, POP3_STOP);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* start the DO phase for RETR */
|
/* for the retr response */
|
||||||
static CURLcode pop3_retr(struct connectdata *conn)
|
static CURLcode pop3_state_retr_resp(struct connectdata *conn,
|
||||||
|
int pop3code,
|
||||||
|
pop3state instate)
|
||||||
{
|
{
|
||||||
CURLcode result = CURLE_OK;
|
CURLcode result = CURLE_OK;
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
struct FTP *pop3 = data->state.proto.pop3;
|
||||||
struct pop3_conn *pop3c = &conn->proto.pop3c;
|
struct pop3_conn *pop3c = &conn->proto.pop3c;
|
||||||
|
struct pingpong *pp = &pop3c->pp;
|
||||||
|
|
||||||
result = Curl_pp_sendf(&conn->proto.pop3c.pp, "RETR %s", pop3c->mailbox);
|
(void)instate; /* no use for this yet */
|
||||||
|
|
||||||
|
if('O' != pop3code) {
|
||||||
|
state(conn, POP3_STOP);
|
||||||
|
return CURLE_RECV_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* POP3 download */
|
||||||
|
Curl_setup_transfer(conn, FIRSTSOCKET, -1, FALSE, pop3->bytecountp,
|
||||||
|
-1, NULL); /* no upload here */
|
||||||
|
|
||||||
|
if(pp->cache) {
|
||||||
|
/* The header "cache" contains a bunch of data that is actually body
|
||||||
|
content so send it as such. Note that there may even be additional
|
||||||
|
"headers" after the body */
|
||||||
|
|
||||||
|
if(!data->set.opt_no_body) {
|
||||||
|
result = Curl_pop3_write(conn, pp->cache, pp->cache_size);
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Free the cache */
|
||||||
|
Curl_safefree(pp->cache);
|
||||||
|
|
||||||
|
/* Reset the cache size */
|
||||||
|
pp->cache_size = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
state(conn, POP3_STOP);
|
||||||
|
|
||||||
state(conn, POP3_RETR);
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -543,6 +529,22 @@ static CURLcode pop3_list(struct connectdata *conn)
|
|||||||
state(conn, POP3_LIST_SINGLE);
|
state(conn, POP3_LIST_SINGLE);
|
||||||
else
|
else
|
||||||
state(conn, POP3_LIST);
|
state(conn, POP3_LIST);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* start the DO phase for RETR */
|
||||||
|
static CURLcode pop3_retr(struct connectdata *conn)
|
||||||
|
{
|
||||||
|
CURLcode result = CURLE_OK;
|
||||||
|
struct pop3_conn *pop3c = &conn->proto.pop3c;
|
||||||
|
|
||||||
|
result = Curl_pp_sendf(&conn->proto.pop3c.pp, "RETR %s", pop3c->mailbox);
|
||||||
|
if(result)
|
||||||
|
return result;
|
||||||
|
|
||||||
|
state(conn, POP3_RETR);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -582,10 +584,6 @@ static CURLcode pop3_statemach_act(struct connectdata *conn)
|
|||||||
result = pop3_state_starttls_resp(conn, pop3code, pop3c->state);
|
result = pop3_state_starttls_resp(conn, pop3code, pop3c->state);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case POP3_RETR:
|
|
||||||
result = pop3_state_retr_resp(conn, pop3code, pop3c->state);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case POP3_LIST:
|
case POP3_LIST:
|
||||||
result = pop3_state_list_resp(conn, pop3code, pop3c->state);
|
result = pop3_state_list_resp(conn, pop3code, pop3c->state);
|
||||||
break;
|
break;
|
||||||
@@ -594,6 +592,10 @@ static CURLcode pop3_statemach_act(struct connectdata *conn)
|
|||||||
result = pop3_state_list_single_resp(conn, pop3code, pop3c->state);
|
result = pop3_state_list_single_resp(conn, pop3code, pop3c->state);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case POP3_RETR:
|
||||||
|
result = pop3_state_retr_resp(conn, pop3code, pop3c->state);
|
||||||
|
break;
|
||||||
|
|
||||||
case POP3_QUIT:
|
case POP3_QUIT:
|
||||||
/* fallthrough, just stop! */
|
/* fallthrough, just stop! */
|
||||||
default:
|
default:
|
||||||
@@ -733,6 +735,7 @@ static CURLcode pop3_done(struct connectdata *conn, CURLcode status,
|
|||||||
struct FTP *pop3 = data->state.proto.pop3;
|
struct FTP *pop3 = data->state.proto.pop3;
|
||||||
struct pop3_conn *pop3c = &conn->proto.pop3c;
|
struct pop3_conn *pop3c = &conn->proto.pop3c;
|
||||||
CURLcode result = CURLE_OK;
|
CURLcode result = CURLE_OK;
|
||||||
|
|
||||||
(void)premature;
|
(void)premature;
|
||||||
|
|
||||||
if(!pop3)
|
if(!pop3)
|
||||||
@@ -749,7 +752,6 @@ static CURLcode pop3_done(struct connectdata *conn, CURLcode status,
|
|||||||
}
|
}
|
||||||
|
|
||||||
Curl_safefree(pop3c->mailbox);
|
Curl_safefree(pop3c->mailbox);
|
||||||
pop3c->mailbox = NULL;
|
|
||||||
|
|
||||||
/* Clear the transfer mode for the next connection */
|
/* Clear the transfer mode for the next connection */
|
||||||
pop3->transfer = FTPTRANSFER_BODY;
|
pop3->transfer = FTPTRANSFER_BODY;
|
||||||
@@ -861,6 +863,7 @@ static CURLcode pop3_quit(struct connectdata *conn)
|
|||||||
result = Curl_pp_sendf(&conn->proto.pop3c.pp, "QUIT", NULL);
|
result = Curl_pp_sendf(&conn->proto.pop3c.pp, "QUIT", NULL);
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
state(conn, POP3_QUIT);
|
state(conn, POP3_QUIT);
|
||||||
|
|
||||||
result = pop3_easy_statemach(conn);
|
result = pop3_easy_statemach(conn);
|
||||||
@@ -889,7 +892,6 @@ static CURLcode pop3_disconnect(struct connectdata *conn, bool dead_connection)
|
|||||||
if(!dead_connection && pop3c->pp.conn)
|
if(!dead_connection && pop3c->pp.conn)
|
||||||
(void)pop3_quit(conn); /* ignore errors on the LOGOUT */
|
(void)pop3_quit(conn); /* ignore errors on the LOGOUT */
|
||||||
|
|
||||||
|
|
||||||
Curl_pp_disconnect(&pop3c->pp);
|
Curl_pp_disconnect(&pop3c->pp);
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
@@ -939,6 +941,7 @@ static CURLcode pop3_doing(struct connectdata *conn,
|
|||||||
|
|
||||||
DEBUGF(infof(conn->data, "DO phase is complete\n"));
|
DEBUGF(infof(conn->data, "DO phase is complete\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -952,8 +955,7 @@ static CURLcode pop3_doing(struct connectdata *conn,
|
|||||||
* remote host.
|
* remote host.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static
|
static CURLcode pop3_regular_transfer(struct connectdata *conn,
|
||||||
CURLcode pop3_regular_transfer(struct connectdata *conn,
|
|
||||||
bool *dophase_done)
|
bool *dophase_done)
|
||||||
{
|
{
|
||||||
CURLcode result=CURLE_OK;
|
CURLcode result=CURLE_OK;
|
||||||
|
Reference in New Issue
Block a user