diff options
Diffstat (limited to 'src/arrow/c_glib/arrow-glib/expression.h')
-rw-r--r-- | src/arrow/c_glib/arrow-glib/expression.h | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/src/arrow/c_glib/arrow-glib/expression.h b/src/arrow/c_glib/arrow-glib/expression.h new file mode 100644 index 000000000..1c1a5fbab --- /dev/null +++ b/src/arrow/c_glib/arrow-glib/expression.h @@ -0,0 +1,96 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +#pragma once + +#include <arrow-glib/compute.h> + +G_BEGIN_DECLS + +#define GARROW_TYPE_EXPRESSION (garrow_expression_get_type()) +G_DECLARE_DERIVABLE_TYPE(GArrowExpression, + garrow_expression, + GARROW, + EXPRESSION, + GObject) +struct _GArrowExpressionClass +{ + GObjectClass parent_class; +}; + +GARROW_AVAILABLE_IN_6_0 +gchar * +garrow_expression_to_string(GArrowExpression *expression); +GARROW_AVAILABLE_IN_6_0 +gboolean +garrow_expression_equal(GArrowExpression *expression, + GArrowExpression *other_expression); + + +#define GARROW_TYPE_LITERAL_EXPRESSION (garrow_literal_expression_get_type()) +G_DECLARE_DERIVABLE_TYPE(GArrowLiteralExpression, + garrow_literal_expression, + GARROW, + LITERAL_EXPRESSION, + GArrowExpression) +struct _GArrowLiteralExpressionClass +{ + GArrowExpressionClass parent_class; +}; + +GARROW_AVAILABLE_IN_6_0 +GArrowLiteralExpression * +garrow_literal_expression_new(GArrowDatum *datum); + + +#define GARROW_TYPE_FIELD_EXPRESSION (garrow_field_expression_get_type()) +G_DECLARE_DERIVABLE_TYPE(GArrowFieldExpression, + garrow_field_expression, + GARROW, + FIELD_EXPRESSION, + GArrowExpression) +struct _GArrowFieldExpressionClass +{ + GArrowExpressionClass parent_class; +}; + +GARROW_AVAILABLE_IN_6_0 +GArrowFieldExpression * +garrow_field_expression_new(const gchar *reference, + GError **error); + + +#define GARROW_TYPE_CALL_EXPRESSION (garrow_call_expression_get_type()) +G_DECLARE_DERIVABLE_TYPE(GArrowCallExpression, + garrow_call_expression, + GARROW, + CALL_EXPRESSION, + GArrowExpression) +struct _GArrowCallExpressionClass +{ + GArrowExpressionClass parent_class; +}; + +GARROW_AVAILABLE_IN_6_0 +GArrowCallExpression * +garrow_call_expression_new(const gchar *function, + GList *arguments, + GArrowFunctionOptions *options); + +G_END_DECLS |