Objectively 1.0.0
Ultra-lightweight object oriented framework for GNU C.
Macros | Functions
URLSessionUploadTask.c File Reference
#include <assert.h>
#include <string.h>
#include <curl/curl.h>
#include "URLSessionUploadTask.h"

Go to the source code of this file.

Macros

#define _Class   _URLSessionUploadTask
 

Functions

Class_URLSessionUploadTask (void)
 
static void initialize (Class *clazz)
 
static size_t readFunction (char *data, size_t size, size_t count, ident self)
 The CURLOPT_READFUNCTION callback. More...
 
static void setup (URLSessionTask *self)
 

Macro Definition Documentation

◆ _Class

#define _Class   _URLSessionUploadTask

Definition at line 31 of file URLSessionUploadTask.c.

Function Documentation

◆ _URLSessionUploadTask()

Class * _URLSessionUploadTask ( void  )

Definition at line 87 of file URLSessionUploadTask.c.

87 {
88 static Class *clazz;
89 static Once once;
90
91 do_once(&once, {
92 clazz = _initialize(&(const ClassDef) {
93 .name = "URLSessionUploadTask",
94 .superclass = _URLSessionTask(),
95 .instanceSize = sizeof(URLSessionUploadTask),
96 .interfaceOffset = offsetof(URLSessionUploadTask, interface),
97 .interfaceSize = sizeof(URLSessionUploadTaskInterface),
99 });
100 });
101
102 return clazz;
103}
Class * _initialize(const ClassDef *def)
Initializes the given Class.
Definition: Class.c:91
static void initialize(Class *clazz)
long Once
The Once type.
Definition: Once.h:37
#define do_once(once, block)
Executes the given block at most one time.
Definition: Once.h:43
ClassDefs are passed to _initialize via an archetype to initialize a Class.
Definition: Class.h:41
The runtime representation of a Class.
Definition: Class.h:95
Class * _URLSessionTask(void)
The URLSessionTask archetype.
Use upload tasks to send files directly from disk.

◆ initialize()

static void initialize ( Class clazz)
static
See also
Class::initialize(Class *)

Definition at line 78 of file URLSessionUploadTask.c.

78 {
79
80 ((URLSessionTaskInterface *) clazz->interface)->setup = setup;
81}
ident interface
The interface of the Class.
Definition: Class.h:105
void setup(URLSessionTask *)
Sets up this task.

◆ readFunction()

static size_t readFunction ( char *  data,
size_t  size,
size_t  count,
ident  self 
)
static

The CURLOPT_READFUNCTION callback.

Definition at line 38 of file URLSessionUploadTask.c.

38 {
39
41
42 const size_t bytesRead = fread(data, size, count, this->file);
43 this->urlSessionTask.bytesSent += bytesRead;
44
45 return bytesRead;
46}
MutableData * data(void)
Returns a new MutableData.
Definition: MutableData.c:75

◆ setup()

static void setup ( URLSessionTask self)
static
See also
URLSessionTask::setup(URLSessionTask *)

Definition at line 51 of file URLSessionUploadTask.c.

51 {
52
54
56
57 assert(this->file);
58
59 int err = fseek(this->file, 0, SEEK_END);
60 assert(err == 0);
61
62 self->bytesExpectedToSend = ftell(this->file);
63
64 err = fseek(this->file, 0, SEEK_SET);
65 assert(err == 0);
66
67 curl_easy_setopt(self->locals.handle, CURLOPT_INFILESIZE_LARGE, self->bytesExpectedToSend);
68
69 curl_easy_setopt(self->locals.handle, CURLOPT_READFUNCTION, readFunction);
70 curl_easy_setopt(self->locals.handle, CURLOPT_READDATA, self);
71}
#define super(type, obj, method,...)
static size_t readFunction(char *data, size_t size, size_t count, ident self)
The CURLOPT_READFUNCTION callback.
URL session tasks are handles to pending URL operations.
ident handle
The backing libcurl handle.
size_t bytesExpectedToSend
The count of bytes this task expects to send.