gstparse.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /* GStreamer
  2. * Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
  3. * 2000 Wim Taymans <wtay@chello.be>
  4. *
  5. * gstparse.h: get a pipeline from a text pipeline description
  6. *
  7. * This library is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Library General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2 of the License, or (at your option) any later version.
  11. *
  12. * This library is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Library General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Library General Public
  18. * License along with this library; if not, write to the
  19. * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
  20. * Boston, MA 02110-1301, USA.
  21. */
  22. #ifndef __GST_PARSE_H__
  23. #define __GST_PARSE_H__
  24. #include <gst/gstelement.h>
  25. G_BEGIN_DECLS
  26. GQuark gst_parse_error_quark (void);
  27. /**
  28. * GST_PARSE_ERROR:
  29. *
  30. * Get access to the error quark of the parse subsystem.
  31. */
  32. #define GST_PARSE_ERROR gst_parse_error_quark ()
  33. /* FIXME 2.0: rename to GstParseLaunchError, this is not only related to
  34. *parsing */
  35. /**
  36. * GstParseError:
  37. * @GST_PARSE_ERROR_SYNTAX: A syntax error occurred.
  38. * @GST_PARSE_ERROR_NO_SUCH_ELEMENT: The description contained an unknown element
  39. * @GST_PARSE_ERROR_NO_SUCH_PROPERTY: An element did not have a specified property
  40. * @GST_PARSE_ERROR_LINK: There was an error linking two pads.
  41. * @GST_PARSE_ERROR_COULD_NOT_SET_PROPERTY: There was an error setting a property
  42. * @GST_PARSE_ERROR_EMPTY_BIN: An empty bin was specified.
  43. * @GST_PARSE_ERROR_EMPTY: An empty description was specified
  44. * @GST_PARSE_ERROR_DELAYED_LINK: A delayed link did not get resolved.
  45. *
  46. * The different parsing errors that can occur.
  47. */
  48. typedef enum
  49. {
  50. GST_PARSE_ERROR_SYNTAX,
  51. GST_PARSE_ERROR_NO_SUCH_ELEMENT,
  52. GST_PARSE_ERROR_NO_SUCH_PROPERTY,
  53. GST_PARSE_ERROR_LINK,
  54. GST_PARSE_ERROR_COULD_NOT_SET_PROPERTY,
  55. GST_PARSE_ERROR_EMPTY_BIN,
  56. GST_PARSE_ERROR_EMPTY,
  57. GST_PARSE_ERROR_DELAYED_LINK
  58. } GstParseError;
  59. /**
  60. * GstParseFlags:
  61. * @GST_PARSE_FLAG_NONE: Do not use any special parsing options.
  62. * @GST_PARSE_FLAG_FATAL_ERRORS: Always return %NULL when an error occurs
  63. * (default behaviour is to return partially constructed bins or elements
  64. * in some cases)
  65. * @GST_PARSE_FLAG_NO_SINGLE_ELEMENT_BINS: If a bin only has a single element,
  66. * just return the element.
  67. *
  68. * Parsing options.
  69. */
  70. typedef enum
  71. {
  72. GST_PARSE_FLAG_NONE = 0,
  73. GST_PARSE_FLAG_FATAL_ERRORS = (1 << 0),
  74. GST_PARSE_FLAG_NO_SINGLE_ELEMENT_BINS = (1 << 1)
  75. } GstParseFlags;
  76. #define GST_TYPE_PARSE_CONTEXT (gst_parse_context_get_type())
  77. /**
  78. * GstParseContext:
  79. *
  80. * Opaque structure.
  81. */
  82. typedef struct _GstParseContext GstParseContext;
  83. /* create, process and free a parse context */
  84. GType gst_parse_context_get_type (void);
  85. GstParseContext * gst_parse_context_new (void) G_GNUC_MALLOC;
  86. gchar ** gst_parse_context_get_missing_elements (GstParseContext * context) G_GNUC_MALLOC;
  87. void gst_parse_context_free (GstParseContext * context);
  88. /* parse functions */
  89. GstElement * gst_parse_launch (const gchar * pipeline_description,
  90. GError ** error) G_GNUC_MALLOC;
  91. GstElement * gst_parse_launchv (const gchar ** argv,
  92. GError ** error) G_GNUC_MALLOC;
  93. GstElement * gst_parse_launch_full (const gchar * pipeline_description,
  94. GstParseContext * context,
  95. GstParseFlags flags,
  96. GError ** error) G_GNUC_MALLOC;
  97. GstElement * gst_parse_launchv_full (const gchar ** argv,
  98. GstParseContext * context,
  99. GstParseFlags flags,
  100. GError ** error) G_GNUC_MALLOC;
  101. #ifdef G_DEFINE_AUTOPTR_CLEANUP_FUNC
  102. G_DEFINE_AUTOPTR_CLEANUP_FUNC(GstParseContext, gst_parse_context_free)
  103. #endif
  104. G_END_DECLS
  105. #endif /* __GST_PARSE_H__ */