Files
@ e0b7e9dd5b54
Branch filter:
Location: DistRen/src/client/distren.h - annotation
e0b7e9dd5b54
2.5 KiB
text/plain
File uploads are now supported using DISTREN_REQUEST_FILE_POST and friends.
c59ea8d9c33e abcf8952747b c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e c59ea8d9c33e 3b998819751e 3b998819751e 3b998819751e 3b998819751e dba5ec867bf4 c59ea8d9c33e dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 da79b5082151 da79b5082151 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 e0b7e9dd5b54 e0b7e9dd5b54 e0b7e9dd5b54 e0b7e9dd5b54 e0b7e9dd5b54 e0b7e9dd5b54 e0b7e9dd5b54 e0b7e9dd5b54 e0b7e9dd5b54 60d3bb17d7d3 dba5ec867bf4 4c92a6a1bfd9 4c92a6a1bfd9 4c92a6a1bfd9 4c92a6a1bfd9 4c92a6a1bfd9 4c92a6a1bfd9 257ea2fc6baf 4c92a6a1bfd9 3fcf567f92be 3fcf567f92be 3fcf567f92be 3fcf567f92be 3fcf567f92be 3fcf567f92be dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 257ea2fc6baf dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 dba5ec867bf4 da79b5082151 da79b5082151 dba5ec867bf4 c59ea8d9c33e c59ea8d9c33e | /*
Copyright 2010 Nathan Phillip Brink, Ethan Zonca, Matt Orlando
This file is a part of DistRen.
DistRen is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
DistRen is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with DistRen. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef DISTREN_H
#define DISTREN_H 1
/*
Public API for DistRen
*/
#include <stddef.h> /* size_t */
typedef struct distren *distren_t;
typedef struct distren_job *distren_job_t;
/**
* Initializes a libdistren handle.
*/
int distren_init(distren_t *handle);
/**
* Submits a file to distren.
*
* Blocks.
*
* @param handle distren handle.
* @param job must not refer to a valid job.
* @param filename path to a tarball representing a job.
* @return 0 on success, 1 on error.
*/
int distren_submit_file(distren_t handle, distren_job_t *job, const char *filename);
/**
Retrieve a job-ID that can be used to refer to the job after the client's process has recycled. Currently, this will be the only way to retrieve a job handle (a distren_job_t) and, consequently, the only way to retrieve a finished render.
A job ID is representable using a character string. Hopefully, they will be kept at a reasonably small length. It should be made up of alphanumeric characters so as to be useful in most situations.
@param jobid This will be set to a string allocated by the specified malloc implementation
@param job The distren_job_t from which to retrieve a jobid
*/
int distren_job_geturi(distren_job_t job, char **joburi);
/**
Retrieves a tarball of a rendering's result.
@param outfile Filename to save the result to
*/
int distren_job_retrieve_file(distren_job_t job, const char *outfile);
/*
TODO: extraction of a job-ID, retrieving job handle by job-ID, getting information
for a job handle, retrieving results of a job, callbacks for progress (i.e., job_is_finished callback)
-- threads? -- noooo!
*/
/**
Destroys and frees a job handle
*/
int distren_job_free(distren_job_t job);
/**
* Destroys and frees a libdistren handle
*/
int distren_free(distren_t handle);
#endif
|