]> granicus.if.org Git - curl/commitdiff
Chris Combes added description of his newly added options
authorDaniel Stenberg <daniel@haxx.se>
Sat, 15 Jun 2002 11:17:42 +0000 (11:17 +0000)
committerDaniel Stenberg <daniel@haxx.se>
Sat, 15 Jun 2002 11:17:42 +0000 (11:17 +0000)
docs/libcurl/curl_formadd.3

index 93bed079d095209ec6b32e5d6e42dc9d61544394..2c522c90a6bc9c5386437263efa026619fe383ea 100644 (file)
@@ -2,7 +2,7 @@
 .\" nroff -man [file]
 .\" $Id$
 .\"
-.TH curl_formadd 3 "21 May 2002" "libcurl 7.9.8" "libcurl Manual"
+.TH curl_formadd 3 "15 June 2002" "libcurl 7.9.8" "libcurl Manual"
 .SH NAME
 curl_formadd - add a section to a multipart/formdata HTTP POST
 .SH SYNOPSIS
@@ -29,9 +29,10 @@ name). All options that use the word COPY in their names copy the given
 contents, while the ones with PTR in their names simply points to the (static)
 data you must make sure remain until curl no longer needs it.
 
-The four options for providing values are: \fBCURLFORM_COPYCONTENTS\fP,
-\fBCURLFORM_PTRCONTENTS\fP, \fBCURLFORM_FILE\fP, or \fBCURLFORM_FILECONTENT\fP
-followed by a char or void pointer (allowed for PTRCONTENTS).
+The options for providing values are: \fBCURLFORM_COPYCONTENTS\fP,
+\fBCURLFORM_PTRCONTENTS\fP, \fBCURLFORM_FILE\fP, \fBCURLFORM_BUFFER\fP,
+or \fBCURLFORM_FILECONTENT\fP followed by a char or void pointer
+(allowed for PTRCONTENTS).
 
 \fBCURLFORM_FILECONTENT\fP does a normal post like \fBCURLFORM_COPYCONTENTS\fP
 but the actual value is read from the filename given as a string.
@@ -48,6 +49,20 @@ For \fBCURLFORM_FILE\fP the user may send multiple files in one section by
 providing multiple \fBCURLFORM_FILE\fP arguments each followed by the filename
 (and each FILE is allowed to have a CONTENTTYPE).
 
+\fBCURLFORM_BUFFER\fP 
+tells libcurl that a buffer is to be used to upload data instead of using a
+file. The value of the next parameter is used as the value of the "filename"
+parameter in the content header.
+
+\fBCURLFORM_BUFFERPTR\fP
+tells libcurl that the address of the next parameter is a pointer to the buffer
+containing data to upload. The buffer containing this data must not be freed
+until after curl_easy_cleanup is called.
+
+\fBCURLFORM_BUFFERLENGTH\fP
+tells libcurl that the length of the buffer to upload is the value of the
+next parameter.
+
 Another possibility to send single or multiple files in one section is to use
 \fBCURLFORM_ARRAY\fP that gets a struct curl_forms array pointer as its
 value. Each structure element has a CURLformoption and a char pointer. For the
@@ -149,6 +164,13 @@ defines.
  forms[1].value  = file2;
  forms[2].option  = CURLFORM_END;
 
+ /* Add a buffer to upload */
+ curl_formadd(&post, &last,
+              CURLFORM_BUFFER, "data",
+              CURLFORM_BUFFERPTR, record,
+              CURLFORM_BUFFERLENGTH, record_length,
+              CURLFORM_END);
+
  /* no option needed for the end marker */
  curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures",
               CURLFORM_ARRAY, forms, CURLFORM_END);