I’m trying to interface with the Google Contact API, and in order to update a contact on the remote side, I need to use a PUT request instead of POST.
Since the data I want to PUT is already in memory, I really don’t want to deal with file pointers, which seems to be the default behavior of CURLOPT_READDATA. Thus, I understand I need to use CURLOPT_READFUNCTION in addition to that but I’m failing to understand the logic.
Here is the relevant doc: http://curl.haxx.se/libcurl/c/curl_easy_setopt.html#CURLOPTREADFUNCTION
Printing the variables passed in, I see nmemb=16372 and size=1. If my data is going to be of size 100K, for example, what is the logic that I need to implement?
Thank you.
You will still want to use
CURLOPT_READDATA, however if you useCURLOPT_READFUNCTION, it can be any user-specified pointer. You can create a simple structure like:where
datais the PUT data andlenis the length (remaining).Then, set
CURLOPT_READDATAto a pointer to an initialized instance of that structure. You will be passed it inCURLOPT_READFUNCTIONasuserdata. In that function, do something like:This basically figures out the amount to copy, copies it, then updates the length and pointer. On the
to_copyline, we calculate the minimum because were are bounded by both the amount remaining and the size of curl’s buffer. Finally, we return the number of bytes copied, as required by curl. When you’re at the end of contentuser_data->len(and thusto_copy) will be 0. Nothing will be copied and returning 0 ends the transfer.