[gtk+/wip/otte/shader: 51/69] gsksltype: Turn void into a custom type class
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/otte/shader: 51/69] gsksltype: Turn void into a custom type class
- Date: Wed, 4 Oct 2017 00:41:29 +0000 (UTC)
commit 5d701bd93c799b7720ea29b8df910630da0661f7
Author: Benjamin Otte <otte redhat com>
Date: Sun Oct 1 04:31:18 2017 +0200
gsksltype: Turn void into a custom type class
Previously, void was a scalar type. It's not anymore.
On the plus side, we now got a gsk_sl_type_is_void() function that's
kinda useful in places.
gsk/gskslpointertype.c | 3 +-
gsk/gskslstatement.c | 4 +-
gsk/gsksltype.c | 141 ++++++++++++++++++++++++++++++++++++++++++++++--
gsk/gsksltypeprivate.h | 2 +
4 files changed, 142 insertions(+), 8 deletions(-)
---
diff --git a/gsk/gskslpointertype.c b/gsk/gskslpointertype.c
index 5833ca0..9c2b08a 100644
--- a/gsk/gskslpointertype.c
+++ b/gsk/gskslpointertype.c
@@ -186,7 +186,6 @@ gsk_sl_decoration_list_parse_layout (GskSlPreprocessor *preproc,
{
gsk_sl_preprocessor_error (preproc, SYNTAX, "Expected layout identifier.");
gsk_sl_preprocessor_consume (preproc, NULL);
- continue;
}
token = gsk_sl_preprocessor_get (preproc);
@@ -332,7 +331,7 @@ gsk_sl_decoration_list_parse (GskSlScope *scope,
gsk_sl_decoration_list_parse_layout (preproc, scope, list);
token = gsk_sl_preprocessor_get (preproc);
- if (gsk_sl_token_is (token, GSK_SL_TOKEN_RIGHT_PAREN))
+ if (!gsk_sl_token_is (token, GSK_SL_TOKEN_RIGHT_PAREN))
{
gsk_sl_preprocessor_error (preproc, SYNTAX, "Expected closing \")\" at end of layout
specifier");
gsk_sl_preprocessor_sync (preproc, GSK_SL_TOKEN_RIGHT_PAREN);
diff --git a/gsk/gskslstatement.c b/gsk/gskslstatement.c
index 68450be..a3b5eb7 100644
--- a/gsk/gskslstatement.c
+++ b/gsk/gskslstatement.c
@@ -743,14 +743,14 @@ its_a_type:
}
else if (return_statement->value == NULL)
{
- if (!gsk_sl_type_equal (return_type, gsk_sl_type_get_scalar (GSK_SL_VOID)))
+ if (!gsk_sl_type_is_void (return_type))
{
gsk_sl_preprocessor_error (preproc, TYPE_MISMATCH,"Functions expectes a return value of type
%s", gsk_sl_type_get_name (return_type));
}
}
else
{
- if (gsk_sl_type_equal (return_type, gsk_sl_type_get_scalar (GSK_SL_VOID)))
+ if (gsk_sl_type_is_void (return_type))
{
gsk_sl_preprocessor_error (preproc, TYPE_MISMATCH, "Cannot return a value from a void
function.");
}
diff --git a/gsk/gsksltype.c b/gsk/gsksltype.c
index 4665399..f2009e4 100644
--- a/gsk/gsksltype.c
+++ b/gsk/gsksltype.c
@@ -328,6 +328,125 @@ gsk_sl_type_alloc (const GskSlTypeClass *klass,
}
#define gsk_sl_type_new(_name, _klass) ((_name *) gsk_sl_type_alloc ((_klass), sizeof (_name)))
+/* VOID */
+
+typedef struct _GskSlTypeVoid GskSlTypeVoid;
+
+struct _GskSlTypeVoid {
+ GskSlType parent;
+};
+
+static void
+gsk_sl_type_void_free (GskSlType *type)
+{
+ g_assert_not_reached ();
+}
+
+static const char *
+gsk_sl_type_void_get_name (GskSlType *type)
+{
+ return "void";
+}
+
+static GskSlScalarType
+gsk_sl_type_void_get_scalar_type (GskSlType *type)
+{
+ return GSK_SL_VOID;
+}
+
+static GskSlType *
+gsk_sl_type_void_get_index_type (GskSlType *type)
+{
+ return NULL;
+}
+
+static gsize
+gsk_sl_type_void_get_index_stride (GskSlType *type)
+{
+ return 0;
+}
+
+static guint
+gsk_sl_type_void_get_length (GskSlType *type)
+{
+ return 0;
+}
+
+static gsize
+gsk_sl_type_void_get_size (GskSlType *type)
+{
+ return 0;
+}
+
+static guint
+gsk_sl_type_void_get_n_members (GskSlType *type)
+{
+ return 0;
+}
+
+static const GskSlTypeMember *
+gsk_sl_type_void_get_member (GskSlType *type,
+ guint n)
+{
+ return NULL;
+}
+
+static gboolean
+gsk_sl_type_void_can_convert (GskSlType *target,
+ GskSlType *source)
+{
+ return FALSE;
+}
+
+static guint32
+gsk_sl_type_void_write_spv (const GskSlType *type,
+ GskSpvWriter *writer)
+{
+ guint32 result;
+
+ result = gsk_spv_writer_next_id (writer);
+ gsk_spv_writer_add (writer,
+ GSK_SPV_WRITER_SECTION_DECLARE,
+ 2, GSK_SPV_OP_TYPE_VOID,
+ (guint32[1]) { result });
+
+ return result;
+}
+
+static void
+gsk_sl_type_void_print_value (const GskSlType *type,
+ GskSlPrinter *printer,
+ gpointer value)
+{
+ g_assert_not_reached ();
+}
+
+static guint32
+gsk_sl_type_void_write_value_spv (GskSlType *type,
+ GskSpvWriter *writer,
+ gpointer value)
+{
+ g_assert_not_reached ();
+
+ return 0;
+}
+
+static const GskSlTypeClass GSK_SL_TYPE_VOID = {
+ gsk_sl_type_void_free,
+ gsk_sl_type_void_get_name,
+ gsk_sl_type_void_get_scalar_type,
+ gsk_sl_type_void_get_index_type,
+ gsk_sl_type_void_get_index_stride,
+ gsk_sl_type_void_get_length,
+ gsk_sl_type_void_get_size,
+ gsk_sl_type_void_get_n_members,
+ gsk_sl_type_void_get_member,
+ gsk_sl_type_void_can_convert,
+ gsk_sl_type_void_write_spv,
+ gsk_sl_type_void_print_value,
+ gsk_sl_type_void_write_value_spv
+};
+
/* SCALAR */
typedef struct _GskSlTypeScalar GskSlTypeScalar;
@@ -1200,7 +1319,7 @@ gsk_sl_type_get_builtin (GskSlBuiltinType builtin)
switch (builtin)
{
case GSK_SL_BUILTIN_VOID:
- return gsk_sl_type_ref (gsk_sl_type_get_scalar (GSK_SL_VOID));
+ return gsk_sl_type_ref (gsk_sl_type_get_void ());
case GSK_SL_BUILTIN_FLOAT:
return gsk_sl_type_ref (gsk_sl_type_get_scalar (GSK_SL_FLOAT));
case GSK_SL_BUILTIN_DOUBLE:
@@ -1279,7 +1398,7 @@ gsk_sl_type_get_builtin (GskSlBuiltinType builtin)
return gsk_sl_type_ref (gsk_sl_type_get_matrix (GSK_SL_DOUBLE, 4, 4));
default:
g_assert_not_reached ();
- return gsk_sl_type_get_scalar (GSK_SL_VOID);
+ return gsk_sl_type_get_void ();
}
}
@@ -1295,7 +1414,7 @@ gsk_sl_type_new_parse (GskSlScope *scope,
switch (token->type)
{
case GSK_SL_TOKEN_VOID:
- type = gsk_sl_type_ref (gsk_sl_type_get_scalar (GSK_SL_VOID));
+ type = gsk_sl_type_ref (gsk_sl_type_get_void ());
break;
case GSK_SL_TOKEN_FLOAT:
type = gsk_sl_type_ref (gsk_sl_type_get_scalar (GSK_SL_FLOAT));
@@ -1440,9 +1559,16 @@ gsk_sl_type_new_parse (GskSlScope *scope,
return type;
}
+static GskSlTypeVoid void_type = { { &GSK_SL_TYPE_VOID, 1 } };
+
+GskSlType *
+gsk_sl_type_get_void (void)
+{
+ return &void_type.parent;
+}
+
static GskSlTypeScalar
builtin_scalar_types[N_SCALAR_TYPES] = {
- [GSK_SL_VOID] = { { &GSK_SL_TYPE_SCALAR, 1 }, GSK_SL_VOID },
[GSK_SL_FLOAT] = { { &GSK_SL_TYPE_SCALAR, 1 }, GSK_SL_FLOAT },
[GSK_SL_DOUBLE] = { { &GSK_SL_TYPE_SCALAR, 1 }, GSK_SL_DOUBLE },
[GSK_SL_INT] = { { &GSK_SL_TYPE_SCALAR, 1 }, GSK_SL_INT },
@@ -1454,6 +1580,7 @@ GskSlType *
gsk_sl_type_get_scalar (GskSlScalarType scalar)
{
g_assert (scalar < N_SCALAR_TYPES);
+ g_return_val_if_fail (scalar != GSK_SL_VOID, &void_type.parent);
return &builtin_scalar_types[scalar].parent;
}
@@ -1582,6 +1709,12 @@ gsk_sl_type_get_name (const GskSlType *type)
}
gboolean
+gsk_sl_type_is_void (const GskSlType *type)
+{
+ return type->class == &GSK_SL_TYPE_VOID;
+}
+
+gboolean
gsk_sl_type_is_scalar (const GskSlType *type)
{
return type->class == &GSK_SL_TYPE_SCALAR;
diff --git a/gsk/gsksltypeprivate.h b/gsk/gsksltypeprivate.h
index d22902b..74bad33 100644
--- a/gsk/gsksltypeprivate.h
+++ b/gsk/gsksltypeprivate.h
@@ -29,6 +29,7 @@ typedef struct _GskSlTypeBuilder GskSlTypeBuilder;
GskSlType * gsk_sl_type_new_parse (GskSlScope *scope,
GskSlPreprocessor *preproc);
+GskSlType * gsk_sl_type_get_void (void);
GskSlType * gsk_sl_type_get_scalar (GskSlScalarType scalar);
GskSlType * gsk_sl_type_get_vector (GskSlScalarType scalar,
guint length);
@@ -40,6 +41,7 @@ GskSlType * gsk_sl_type_get_builtin (GskSlBuiltinTyp
GskSlType * gsk_sl_type_ref (GskSlType *type);
void gsk_sl_type_unref (GskSlType *type);
+gboolean gsk_sl_type_is_void (const GskSlType *type);
gboolean gsk_sl_type_is_scalar (const GskSlType *type);
gboolean gsk_sl_type_is_vector (const GskSlType *type);
gboolean gsk_sl_type_is_matrix (const GskSlType *type);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]