Blame gst/gstpromise.h

Packit a6ee4b
/* GStreamer
Packit a6ee4b
 * Copyright (C) 2017 Matthew Waters <matthew@centricular.com>
Packit a6ee4b
 *
Packit a6ee4b
 * This library is free software; you can redistribute it and/or
Packit a6ee4b
 * modify it under the terms of the GNU Library General Public
Packit a6ee4b
 * License as published by the Free Software Foundation; either
Packit a6ee4b
 * version 2 of the License, or (at your option) any later version.
Packit a6ee4b
 *
Packit a6ee4b
 * This library is distributed in the hope that it will be useful,
Packit a6ee4b
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit a6ee4b
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit a6ee4b
 * Library General Public License for more details.
Packit a6ee4b
 *
Packit a6ee4b
 * You should have received a copy of the GNU Library General Public
Packit a6ee4b
 * License along with this library; if not, write to the
Packit a6ee4b
 * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
Packit a6ee4b
 * Boston, MA 02110-1301, USA.
Packit a6ee4b
 */
Packit a6ee4b
Packit a6ee4b
#ifndef __GST_PROMISE_H__
Packit a6ee4b
#define __GST_PROMISE_H__
Packit a6ee4b
Packit a6ee4b
#include <gst/gst.h>
Packit a6ee4b
Packit a6ee4b
G_BEGIN_DECLS
Packit a6ee4b
Packit a6ee4b
GST_API
Packit a6ee4b
GType gst_promise_get_type(void);
Packit a6ee4b
#define GST_TYPE_PROMISE            (gst_promise_get_type())
Packit a6ee4b
#define GST_PROMISE(obj)            ((GstPromise *) obj)
Packit a6ee4b
Packit a6ee4b
typedef struct _GstPromise GstPromise;
Packit a6ee4b
Packit a6ee4b
/**
Packit a6ee4b
 * GstPromiseResult:
Packit a6ee4b
 * @GST_PROMISE_RESULT_PENDING: Initial state. Waiting for transition to any
Packit a6ee4b
 * 	other state.
Packit a6ee4b
 * @GST_PROMISE_RESULT_INTERRUPTED: Interrupted by the consumer as it doesn't
Packit a6ee4b
 * 	want the value anymore.
Packit a6ee4b
 * @GST_PROMISE_RESULT_REPLIED: A producer marked a reply
Packit a6ee4b
 * @GST_PROMISE_RESULT_EXPIRED: The promise expired (the carrying object
Packit a6ee4b
 * 	lost all refs) and the promise will never be fulfilled.
Packit a6ee4b
 *
Packit a6ee4b
 * The result of a #GstPromise
Packit a6ee4b
 *
Packit a6ee4b
 * Since: 1.14
Packit a6ee4b
 */
Packit a6ee4b
typedef enum
Packit a6ee4b
{
Packit a6ee4b
  GST_PROMISE_RESULT_PENDING,
Packit a6ee4b
  GST_PROMISE_RESULT_INTERRUPTED,
Packit a6ee4b
  GST_PROMISE_RESULT_REPLIED,
Packit a6ee4b
  GST_PROMISE_RESULT_EXPIRED,
Packit a6ee4b
} GstPromiseResult;
Packit a6ee4b
Packit a6ee4b
/**
Packit a6ee4b
 * GstPromiseChangeFunc:
Packit a6ee4b
 * @promise: a #GstPromise
Packit a6ee4b
 * @user_data: (closure): user data
Packit a6ee4b
 *
Packit a6ee4b
 * Since: 1.14
Packit a6ee4b
 */
Packit a6ee4b
typedef void (*GstPromiseChangeFunc) (GstPromise * promise, gpointer user_data);
Packit a6ee4b
Packit a6ee4b
/**
Packit a6ee4b
 * GstPromise:
Packit a6ee4b
 * @parent: parent #GstMiniObject
Packit a6ee4b
 *
Packit a6ee4b
 * Since: 1.14
Packit a6ee4b
 */
Packit a6ee4b
struct _GstPromise
Packit a6ee4b
{
Packit a6ee4b
  GstMiniObject         parent;
Packit a6ee4b
};
Packit a6ee4b
Packit a6ee4b
GST_API
Packit a6ee4b
GstPromise *            gst_promise_new                     (void);
Packit a6ee4b
GST_API
Packit a6ee4b
GstPromise *            gst_promise_new_with_change_func    (GstPromiseChangeFunc func,
Packit a6ee4b
                                                             gpointer user_data,
Packit a6ee4b
                                                             GDestroyNotify notify);
Packit a6ee4b
Packit a6ee4b
GST_API
Packit a6ee4b
GstPromiseResult        gst_promise_wait                    (GstPromise * promise);
Packit a6ee4b
GST_API
Packit a6ee4b
void                    gst_promise_reply                   (GstPromise * promise,
Packit a6ee4b
                                                             GstStructure * s);
Packit a6ee4b
GST_API
Packit a6ee4b
void                    gst_promise_interrupt               (GstPromise * promise);
Packit a6ee4b
GST_API
Packit a6ee4b
void                    gst_promise_expire                  (GstPromise * promise);
Packit a6ee4b
Packit a6ee4b
GST_API
Packit a6ee4b
const GstStructure *    gst_promise_get_reply               (GstPromise * promise);
Packit a6ee4b
Packit a6ee4b
/**
Packit a6ee4b
 * gst_promise_ref:
Packit a6ee4b
 * @promise: a #GstPromise.
Packit a6ee4b
 *
Packit a6ee4b
 * Increases the refcount of the given @promise by one.
Packit a6ee4b
 *
Packit a6ee4b
 * Returns: (transfer full): @promise
Packit a6ee4b
 *
Packit a6ee4b
 * Since: 1.14
Packit a6ee4b
 */
Packit a6ee4b
static inline GstPromise *
Packit a6ee4b
gst_promise_ref (GstPromise * promise)
Packit a6ee4b
{
Packit a6ee4b
  return (GstPromise *) gst_mini_object_ref (GST_MINI_OBJECT_CAST (promise));
Packit a6ee4b
}
Packit a6ee4b
Packit a6ee4b
/**
Packit a6ee4b
 * gst_promise_unref:
Packit a6ee4b
 * @promise: (transfer full): a #GstPromise.
Packit a6ee4b
 *
Packit a6ee4b
 * Decreases the refcount of the promise. If the refcount reaches 0, the
Packit a6ee4b
 * promise will be freed.
Packit a6ee4b
 *
Packit a6ee4b
 * Since: 1.14
Packit a6ee4b
 */
Packit a6ee4b
static inline void
Packit a6ee4b
gst_promise_unref (GstPromise * promise)
Packit a6ee4b
{
Packit a6ee4b
  gst_mini_object_unref (GST_MINI_OBJECT_CAST (promise));
Packit a6ee4b
}
Packit a6ee4b
Packit a6ee4b
#ifdef G_DEFINE_AUTOPTR_CLEANUP_FUNC
Packit a6ee4b
G_DEFINE_AUTOPTR_CLEANUP_FUNC(GstPromise, gst_promise_unref)
Packit a6ee4b
#endif
Packit a6ee4b
Packit a6ee4b
G_END_DECLS
Packit a6ee4b
Packit a6ee4b
#endif /* __GST_PROMISE_H__ */