Port MatrixFileInfo to C

This commit is contained in:
Gergely Polonkai 2017-11-03 13:29:50 +01:00
parent f6f6f78cdc
commit 668bedb816
4 changed files with 233 additions and 50 deletions

View File

@ -16,6 +16,7 @@
* <http://www.gnu.org/licenses/>.
*/
#include "config.h"
#include "matrix-c-types.h"
/**
@ -292,3 +293,205 @@ G_DEFINE_QUARK(matrix-error-quark, matrix_error);
*
* Call answer types
*/
/**
* MatrixFileInfo: (ref-func matrix_file_info_ref) (unref-func matrix_file_info_unref)
*
* Information about the file referred to in a URL.
*/
struct _MatrixFileInfo {
gssize size;
gchar *mimetype;
volatile int refcount;
};
G_DEFINE_BOXED_TYPE(MatrixFileInfo, matrix_file_info, (GBoxedCopyFunc)matrix_file_info_ref, (GBoxedFreeFunc)matrix_file_info_unref);
/**
* matrix_file_info_new:
*
* Create a new #MatrixFileInfo object with a reference count of 1.
*
* Returns: (transfer full): A new #MatrixFileInfo object.
*/
MatrixFileInfo *
matrix_file_info_new(void)
{
MatrixFileInfo *ret = g_new0(MatrixFileInfo, 1);
ret->refcount = 1;
ret->size = -1;
return ret;
}
static void
matrix_file_info_destroy(MatrixFileInfo *file_info)
{
g_free(file_info->mimetype);
}
/**
* matrix_file_info_ref:
* @file_info: (nullable): a #MatrixFileInfo object
*
* Increment reference count on @file_info.
*
* Returns: (transfer full): @file_info
*/
MatrixFileInfo *
matrix_file_info_ref(MatrixFileInfo *file_info)
{
g_return_val_if_fail(file_info != NULL, NULL);
file_info->refcount++;
return file_info;
}
/**
* matrix_file_info_unref:
* @file_info: (nullable) (transfer full): a #MatrixFileInfo object
*
* Decrement reference count on @file_info. If reference count reaches zero, destroy the whole
* object.
*/
void
matrix_file_info_unref(MatrixFileInfo *matrix_file_info)
{
g_return_if_fail(matrix_file_info != NULL);
if (--(matrix_file_info->refcount) == 0) {
matrix_file_info_destroy(matrix_file_info);
g_free(matrix_file_info);
}
}
/**
* matrix_file_info_set_size:
* @file_info: (nullable): a #MatrixFileInfo object
* @size: the size to set
*
* Set the size of the file described by @file_info.
*/
void
matrix_file_info_set_size(MatrixFileInfo *matrix_file_info, gssize size)
{
g_return_if_fail(matrix_file_info != NULL);
matrix_file_info->size = size;
}
/**
* matrix_file_info_get_size:
* @file_info: (nullable): A #MatrixFileInfo object
*
* Get the size of the file described by @file_info.
*
* Returns: the file size.
*/
gssize
matrix_file_info_get_size(MatrixFileInfo *matrix_file_info)
{
g_return_val_if_fail(matrix_file_info != NULL, -1);
return matrix_file_info->size;
}
/**
* matrix_file_info_set_mimetype:
* @file_info: (nullable): A #MatrixFileInfo object
* @mimetype: the MIME type to set
*
* Set the MIME type of the file described by @file_info.
*/
void
matrix_file_info_set_mimetype(MatrixFileInfo *matrix_file_info, const gchar *mimetype)
{
g_return_if_fail(matrix_file_info != NULL);
g_free(matrix_file_info->mimetype);
matrix_file_info->mimetype = g_strdup(mimetype);
}
/**
* matrix_file_info_get_mimetype:
* @file_info: (nullable): A #MatrixFileInfo object
*
* Get the MIME type of the file described by @file_info.
*
* Returns: (nullable) (transfer none): the MIME type. The value is owned by @file_info and
* shouldnt be freed.
*/
const gchar *
matrix_file_info_get_mimetype(MatrixFileInfo *matrix_file_info)
{
g_return_val_if_fail(matrix_file_info != NULL, NULL);
return matrix_file_info->mimetype;
}
/**
* matrix_file_info_set_from_json:
* @file_info: (nullable): A #MatrixFileInfo object
* @json_data: (nullable): a #JsonNode object
*
* Load the data in @json_data into the fields of @file_info. @json_data must hold a valid Matrix
* file info object with a size and mimetype fields.
*/
void
matrix_file_info_set_from_json(MatrixFileInfo *file_info, JsonNode *json_data)
{
JsonNode *node;
JsonObject *root;
g_return_if_fail(file_info != NULL);
g_return_if_fail(json_data != NULL);
root = json_node_get_object(json_data);
if ((node = json_object_get_member(root, "size"))) {
file_info->size = json_node_get_int(node);
} else if (DEBUG) {
g_warning("size is missing from a FileInfo");
}
if ((node = json_object_get_member(root, "mimetype"))) {
g_free(file_info->mimetype);
file_info->mimetype = g_strdup(json_node_get_string(node));
} else if (DEBUG) {
g_warning("mimetype is missing from a FileInfo");
}
}
/**
* matrix_file_info_get_json_node:
* @file_info: (nullable): a #MatrixFileInfo object
* @error: (nullable): a #GError, or NULL to ignore
*
* Convert @file_info to a #JsonNode. If the file size is negative or the MIME type is not set,
* this function returns NULL and @error is set to #MATRIX_ERROR_INCOMPLETE.
*
* Returns: (transfer full) (nullable): a #JsonNode with a valid Matrix file info object
*/
JsonNode *
matrix_file_info_get_json_node(MatrixFileInfo *file_info, GError **error)
{
JsonNode *node;
JsonObject *obj;
if ((file_info->size == -1) || (file_info->mimetype == NULL)) {
g_set_error(error, MATRIX_ERROR, MATRIX_ERROR_INCOMPLETE,
"Won't generate a FileInfo without all fields set.");
return NULL;
}
node = json_node_new(JSON_NODE_OBJECT);
obj = json_object_new();
json_node_set_object(node, obj);
json_object_set_int_member(obj, "size", file_info->size);
json_object_set_string_member(obj, "mimetype", file_info->mimetype);
return node;
}

View File

@ -20,6 +20,7 @@
# define __MATRIX_TYPE_H__
# include <glib-object.h>
# include <json-glib/json-glib.h>
typedef enum {
MATRIX_ERROR_NONE,
@ -195,4 +196,19 @@ typedef enum {
MATRIX_CALL_ANSWER_TYPE_ANSWER
} MatrixCallAnswerType;
typedef struct _MatrixFileInfo MatrixFileInfo;
GType matrix_file_info_get_type(void);
# define MATRIX_TYPE_FILE_INFO matrix_file_info_get_type()
MatrixFileInfo *matrix_file_info_new(void);
MatrixFileInfo *matrix_file_info_ref(MatrixFileInfo *file_info);
void matrix_file_info_unref(MatrixFileInfo *file_info);
void matrix_file_info_set_size(MatrixFileInfo *file_info, gssize size);
gssize matrix_file_info_get_size(MatrixFileInfo *file_info);
void matrix_file_info_set_mimetype(MatrixFileInfo *file_info, const gchar *mimetype);
const gchar *matrix_file_info_get_mimetype(MatrixFileInfo *file_info);
void matrix_file_info_set_from_json(MatrixFileInfo *file_info, JsonNode *json_data);
JsonNode *matrix_file_info_get_json_node(MatrixFileInfo *file_info, GError **error);
#endif /* __MATRIX_TYPE_H__ */

View File

@ -17,56 +17,6 @@
*/
namespace Matrix {
/**
* Information about the file referred to in a URL.
*/
public struct FileInfo {
int? size;
string? mimetype;
public void
set_from_json(Json.Node json_data)
{
size = null;
mimetype = null;
var root = json_data.get_object();
Json.Node? node;
if ((node = root.get_member("size")) != null) {
size = (int)node.get_int();
} else if (Config.DEBUG) {
warning("size is missing from a FileInfo");
}
if ((node = root.get_member("mimetype")) != null) {
mimetype = node.get_string();
} else if (Config.DEBUG) {
warning("mimetype is missing from a FileInfo");
}
}
public Json.Node
get_json_node()
throws Matrix.Error
{
if ((size == null)
|| (mimetype == null)) {
throw new Matrix.Error.INCOMPLETE(
"Won't generate a FileInfo without all fields set.");
}
var node = new Json.Node(Json.NodeType.OBJECT);
var obj = new Json.Object();
node.set_object(obj);
obj.set_int_member("size", size);
obj.set_string_member("mimetype", mimetype);
return node;
}
}
public struct ImageInfo {
int? size;
int? height;

View File

@ -204,6 +204,20 @@ namespace Matrix {
ANSWER;
}
[CCode (cheader_filename = "matrix-c-types.h")]
public struct FileInfo {
public void set_size(ssize size);
public ssize get_size();
public void set_mimetype(string? mimetype);
public string? get_mimetype();
public void set_from_json(Json.Node json_data);
public Json.Node get_json_node()
throws Matrix.Error;
}
/* Utilities */
[CCode (cheader_filename = "utils.h", cname = "_matrix_g_enum_to_string")]
public string? _g_enum_value_to_nick(GLib.Type enum_type, int value, bool convert_dashes = true);