4
/*****************************************************************************
4
/***************************************************************************
6
6
* Project ___| | | | _ \| |
7
7
* / __| | | | |_) | |
8
8
* | (__| |_| | _ <| |___
9
9
* \___|\___/|_| \_\_____|
11
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
13
* In order to be useful for every potential user, curl and libcurl are
14
* dual-licensed under the MPL and the MIT/X-derivate licenses.
11
* Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al.
13
* This software is licensed as described in the file COPYING, which
14
* you should have received as part of this distribution. The terms
15
* are also available at http://curl.haxx.se/docs/copyright.html.
16
17
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
17
18
* copies of the Software, and permit persons to whom the Software is
18
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
19
* licenses. You may pick one of these licenses.
19
* furnished to do so, under the terms of the COPYING file.
21
21
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
22
22
* KIND, either express or implied.
24
* $Id: formdata.h,v 1.9 2001/12/14 12:59:16 bagder Exp $
25
*****************************************************************************/
24
* $Id: formdata.h,v 1.20 2004/04/23 10:37:52 bagder Exp $
25
***************************************************************************/
26
26
/* plain and simple linked list with lines to send */
28
28
struct FormData *next;
34
34
struct FormData *data; /* current form line to send */
35
int sent; /* number of bytes of the current line that has already
36
been sent in a previous invoke */
35
unsigned int sent; /* number of bytes of the current line that has already
36
been sent in a previous invoke */
39
39
/* used by FormAdd for temporary storage */
40
40
typedef struct FormInfo {
44
size_t contentslength;
47
char *buffer; /* pointer to existing buffer used for file upload */
49
char *showfilename; /* The file name to show. If not set, the actual
50
file name will be used */
47
51
struct curl_slist* contentheader;
48
52
struct FormInfo *more;
51
55
int Curl_FormInit(struct Form *form, struct FormData *formdata );
53
struct FormData *Curl_getFormData(struct HttpPost *post,
58
Curl_getFormData(struct FormData **,
59
struct curl_httppost *post,
56
62
/* fread() emulation */
57
int Curl_FormReader(char *buffer,
63
size_t Curl_FormReader(char *buffer,
62
/* possible (old) fread() emulation that copies at most one line */
63
int Curl_FormReadOneLine(char *buffer,
69
* Curl_formpostheader() returns the first line of the formpost, the
70
* request-header part (which is not part of the request-body like the rest of
73
char *Curl_formpostheader(void *formp, size_t *len);
68
75
char *Curl_FormBoundary(void);