mirror of
https://github.com/moparisthebest/curl
synced 2024-12-22 16:18:48 -05:00
5b358603bd
https://bugzilla.novell.com/show_bug.cgi?id=332917 about a HTTP redirect to FTP that caused memory havoc. His work together with my efforts created two fixes: #1 - FTP::file was moved to struct ftp_conn, because is has to be dealt with at connection cleanup, at which time the struct HandleData could be used by another connection. Also, the unused char *urlpath member is removed from struct FTP. #2 - provide a Curl_reset_reqproto() function that frees data->reqdata.proto.* on connection setup if needed (that is if the SessionHandle was used by a different connection).
93 lines
3.8 KiB
C
93 lines
3.8 KiB
C
#ifndef __URL_H
|
|
#define __URL_H
|
|
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) 1998 - 2007, 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
|
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
|
*
|
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
* copies of the Software, and permit persons to whom the Software is
|
|
* furnished to do so, under the terms of the COPYING file.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
* $Id$
|
|
***************************************************************************/
|
|
|
|
#include <stdarg.h> /* to make sure we have ap_list */
|
|
|
|
/*
|
|
* Prototypes for library-wide functions provided by url.c
|
|
*/
|
|
|
|
CURLcode Curl_open(struct SessionHandle **curl);
|
|
CURLcode Curl_setopt(struct SessionHandle *data, CURLoption option,
|
|
va_list arg);
|
|
CURLcode Curl_dupset(struct SessionHandle * dst, struct SessionHandle * src);
|
|
void Curl_freeset(struct SessionHandle * data);
|
|
CURLcode Curl_close(struct SessionHandle *data); /* opposite of curl_open() */
|
|
CURLcode Curl_connect(struct SessionHandle *, struct connectdata **,
|
|
bool *async, bool *protocol_connect);
|
|
CURLcode Curl_async_resolved(struct connectdata *conn,
|
|
bool *protocol_connect);
|
|
CURLcode Curl_do(struct connectdata **, bool *done);
|
|
CURLcode Curl_do_more(struct connectdata *);
|
|
CURLcode Curl_done(struct connectdata **, CURLcode, bool premature);
|
|
CURLcode Curl_disconnect(struct connectdata *);
|
|
CURLcode Curl_protocol_connect(struct connectdata *conn, bool *done);
|
|
CURLcode Curl_protocol_connecting(struct connectdata *conn, bool *done);
|
|
CURLcode Curl_protocol_doing(struct connectdata *conn, bool *done);
|
|
void Curl_safefree(void *ptr);
|
|
|
|
/* create a connection cache */
|
|
struct conncache *Curl_mk_connc(int type, long amount);
|
|
/* free a connection cache */
|
|
void Curl_rm_connc(struct conncache *c);
|
|
/* Change number of entries of a connection cache */
|
|
CURLcode Curl_ch_connc(struct SessionHandle *data,
|
|
struct conncache *c,
|
|
long newamount);
|
|
|
|
int Curl_protocol_getsock(struct connectdata *conn,
|
|
curl_socket_t *socks,
|
|
int numsocks);
|
|
int Curl_doing_getsock(struct connectdata *conn,
|
|
curl_socket_t *socks,
|
|
int numsocks);
|
|
|
|
CURLcode Curl_addHandleToPipeline(struct SessionHandle *handle,
|
|
struct curl_llist *pipeline);
|
|
int Curl_removeHandleFromPipeline(struct SessionHandle *handle,
|
|
struct curl_llist *pipeline);
|
|
bool Curl_isHandleAtHead(struct SessionHandle *handle,
|
|
struct curl_llist *pipeline);
|
|
|
|
void Curl_close_connections(struct SessionHandle *data);
|
|
|
|
#if 0
|
|
CURLcode Curl_protocol_fdset(struct connectdata *conn,
|
|
fd_set *read_fd_set,
|
|
fd_set *write_fd_set,
|
|
int *max_fdp);
|
|
CURLcode Curl_doing_fdset(struct connectdata *conn,
|
|
fd_set *read_fd_set,
|
|
fd_set *write_fd_set,
|
|
int *max_fdp);
|
|
#endif
|
|
|
|
/* Called on connect, and if there's already a protocol-specific struct
|
|
allocated for a different connection, this frees it that it can be setup
|
|
properly later on. */
|
|
void Curl_reset_reqproto(struct connectdata *conn);
|
|
|
|
#endif
|