1 /*
2  * This file is part of gtkD.
3  *
4  * gtkD is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU Lesser General Public License
6  * as published by the Free Software Foundation; either version 3
7  * of the License, or (at your option) any later version, with
8  * some exceptions, please read the COPYING file.
9  *
10  * gtkD is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public License
16  * along with gtkD; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
18  */
19 
20 // generated automatically - do not change
21 // find conversion definition on APILookup.txt
22 // implement new conversion functionalities on the wrap.utils pakage
23 
24 
25 module gst.app.AppSrc;
26 
27 private import gobject.ObjectG;
28 private import gobject.Signals;
29 private import gst.app.c.functions;
30 public  import gst.app.c.types;
31 private import gst.base.BaseSrc;
32 private import gstreamer.Buffer;
33 private import gstreamer.BufferList;
34 private import gstreamer.Caps;
35 private import gstreamer.Sample;
36 private import gstreamer.URIHandlerIF;
37 private import gstreamer.URIHandlerT;
38 private import std.algorithm;
39 
40 
41 /**
42  * The appsrc element can be used by applications to insert data into a
43  * GStreamer pipeline. Unlike most GStreamer elements, appsrc provides
44  * external API functions.
45  * 
46  * appsrc can be used by linking with the libgstapp library to access the
47  * methods directly or by using the appsrc action signals.
48  * 
49  * Before operating appsrc, the caps property must be set to fixed caps
50  * describing the format of the data that will be pushed with appsrc. An
51  * exception to this is when pushing buffers with unknown caps, in which case no
52  * caps should be set. This is typically true of file-like sources that push raw
53  * byte buffers. If you don't want to explicitly set the caps, you can use
54  * gst_app_src_push_sample. This method gets the caps associated with the
55  * sample and sets them on the appsrc replacing any previously set caps (if
56  * different from sample's caps).
57  * 
58  * The main way of handing data to the appsrc element is by calling the
59  * gst_app_src_push_buffer() method or by emitting the push-buffer action signal.
60  * This will put the buffer onto a queue from which appsrc will read from in its
61  * streaming thread. It is important to note that data transport will not happen
62  * from the thread that performed the push-buffer call.
63  * 
64  * The "max-bytes" property controls how much data can be queued in appsrc
65  * before appsrc considers the queue full. A filled internal queue will always
66  * signal the "enough-data" signal, which signals the application that it should
67  * stop pushing data into appsrc. The "block" property will cause appsrc to
68  * block the push-buffer method until free data becomes available again.
69  * 
70  * When the internal queue is running out of data, the "need-data" signal is
71  * emitted, which signals the application that it should start pushing more data
72  * into appsrc.
73  * 
74  * In addition to the "need-data" and "enough-data" signals, appsrc can emit the
75  * "seek-data" signal when the "stream-mode" property is set to "seekable" or
76  * "random-access". The signal argument will contain the new desired position in
77  * the stream expressed in the unit set with the "format" property. After
78  * receiving the seek-data signal, the application should push-buffers from the
79  * new position.
80  * 
81  * These signals allow the application to operate the appsrc in two different
82  * ways:
83  * 
84  * The push mode, in which the application repeatedly calls the push-buffer/push-sample
85  * method with a new buffer/sample. Optionally, the queue size in the appsrc
86  * can be controlled with the enough-data and need-data signals by respectively
87  * stopping/starting the push-buffer/push-sample calls. This is a typical
88  * mode of operation for the stream-type "stream" and "seekable". Use this
89  * mode when implementing various network protocols or hardware devices.
90  * 
91  * The pull mode, in which the need-data signal triggers the next push-buffer call.
92  * This mode is typically used in the "random-access" stream-type. Use this
93  * mode for file access or other randomly accessible sources. In this mode, a
94  * buffer of exactly the amount of bytes given by the need-data signal should be
95  * pushed into appsrc.
96  * 
97  * In all modes, the size property on appsrc should contain the total stream
98  * size in bytes. Setting this property is mandatory in the random-access mode.
99  * For the stream and seekable modes, setting this property is optional but
100  * recommended.
101  * 
102  * When the application has finished pushing data into appsrc, it should call
103  * gst_app_src_end_of_stream() or emit the end-of-stream action signal. After
104  * this call, no more buffers can be pushed into appsrc until a flushing seek
105  * occurs or the state of the appsrc has gone through READY.
106  */
107 public class AppSrc : BaseSrc, URIHandlerIF
108 {
109 	/** the main Gtk struct */
110 	protected GstAppSrc* gstAppSrc;
111 
112 	/** Get the main Gtk struct */
113 	public GstAppSrc* getAppSrcStruct(bool transferOwnership = false)
114 	{
115 		if (transferOwnership)
116 			ownedRef = false;
117 		return gstAppSrc;
118 	}
119 
120 	/** the main Gtk struct as a void* */
121 	protected override void* getStruct()
122 	{
123 		return cast(void*)gstAppSrc;
124 	}
125 
126 	/**
127 	 * Sets our main struct and passes it to the parent class.
128 	 */
129 	public this (GstAppSrc* gstAppSrc, bool ownedRef = false)
130 	{
131 		this.gstAppSrc = gstAppSrc;
132 		super(cast(GstBaseSrc*)gstAppSrc, ownedRef);
133 	}
134 
135 	// add the URIHandler capabilities
136 	mixin URIHandlerT!(GstAppSrc);
137 
138 
139 	/** */
140 	public static GType getType()
141 	{
142 		return gst_app_src_get_type();
143 	}
144 
145 	/**
146 	 * Indicates to the appsrc element that the last buffer queued in the
147 	 * element is the last buffer of the stream.
148 	 *
149 	 * Returns: #GST_FLOW_OK when the EOS was successfully queued.
150 	 *     #GST_FLOW_FLUSHING when @appsrc is not PAUSED or PLAYING.
151 	 */
152 	public GstFlowReturn endOfStream()
153 	{
154 		return gst_app_src_end_of_stream(gstAppSrc);
155 	}
156 
157 	/**
158 	 * Get the configured caps on @appsrc.
159 	 *
160 	 * Returns: the #GstCaps produced by the source. gst_caps_unref() after usage.
161 	 */
162 	public Caps getCaps()
163 	{
164 		auto __p = gst_app_src_get_caps(gstAppSrc);
165 
166 		if(__p is null)
167 		{
168 			return null;
169 		}
170 
171 		return ObjectG.getDObject!(Caps)(cast(GstCaps*) __p, true);
172 	}
173 
174 	/**
175 	 * Get the number of currently queued bytes inside @appsrc.
176 	 *
177 	 * Returns: The number of currently queued bytes.
178 	 *
179 	 * Since: 1.2
180 	 */
181 	public ulong getCurrentLevelBytes()
182 	{
183 		return gst_app_src_get_current_level_bytes(gstAppSrc);
184 	}
185 
186 	/**
187 	 * Get the duration of the stream in nanoseconds. A value of GST_CLOCK_TIME_NONE means that the duration is
188 	 * not known.
189 	 *
190 	 * Returns: the duration of the stream previously set with gst_app_src_set_duration();
191 	 *
192 	 * Since: 1.10
193 	 */
194 	public GstClockTime getDuration()
195 	{
196 		return gst_app_src_get_duration(gstAppSrc);
197 	}
198 
199 	/**
200 	 * Check if appsrc will emit the "new-preroll" and "new-buffer" signals.
201 	 *
202 	 * Returns: %TRUE if @appsrc is emitting the "new-preroll" and "new-buffer"
203 	 *     signals.
204 	 */
205 	public bool getEmitSignals()
206 	{
207 		return gst_app_src_get_emit_signals(gstAppSrc) != 0;
208 	}
209 
210 	/**
211 	 * Retrieve the min and max latencies in @min and @max respectively.
212 	 *
213 	 * Params:
214 	 *     min = the min latency
215 	 *     max = the max latency
216 	 */
217 	public void getLatency(out ulong min, out ulong max)
218 	{
219 		gst_app_src_get_latency(gstAppSrc, &min, &max);
220 	}
221 
222 	/**
223 	 * Get the maximum amount of bytes that can be queued in @appsrc.
224 	 *
225 	 * Returns: The maximum amount of bytes that can be queued.
226 	 */
227 	public ulong getMaxBytes()
228 	{
229 		return gst_app_src_get_max_bytes(gstAppSrc);
230 	}
231 
232 	/**
233 	 * Get the size of the stream in bytes. A value of -1 means that the size is
234 	 * not known.
235 	 *
236 	 * Returns: the size of the stream previously set with gst_app_src_set_size();
237 	 */
238 	public long getSize()
239 	{
240 		return gst_app_src_get_size(gstAppSrc);
241 	}
242 
243 	/**
244 	 * Get the stream type. Control the stream type of @appsrc
245 	 * with gst_app_src_set_stream_type().
246 	 *
247 	 * Returns: the stream type.
248 	 */
249 	public GstAppStreamType getStreamType()
250 	{
251 		return gst_app_src_get_stream_type(gstAppSrc);
252 	}
253 
254 	/**
255 	 * Adds a buffer to the queue of buffers that the appsrc element will
256 	 * push to its source pad.  This function takes ownership of the buffer.
257 	 *
258 	 * When the block property is TRUE, this function can block until free
259 	 * space becomes available in the queue.
260 	 *
261 	 * Params:
262 	 *     buffer = a #GstBuffer to push
263 	 *
264 	 * Returns: #GST_FLOW_OK when the buffer was successfully queued.
265 	 *     #GST_FLOW_FLUSHING when @appsrc is not PAUSED or PLAYING.
266 	 *     #GST_FLOW_EOS when EOS occurred.
267 	 */
268 	public GstFlowReturn pushBuffer(Buffer buffer)
269 	{
270 		return gst_app_src_push_buffer(gstAppSrc, (buffer is null) ? null : buffer.getBufferStruct());
271 	}
272 
273 	/**
274 	 * Adds a buffer list to the queue of buffers and buffer lists that the
275 	 * appsrc element will push to its source pad.  This function takes ownership
276 	 * of @buffer_list.
277 	 *
278 	 * When the block property is TRUE, this function can block until free
279 	 * space becomes available in the queue.
280 	 *
281 	 * Params:
282 	 *     bufferList = a #GstBufferList to push
283 	 *
284 	 * Returns: #GST_FLOW_OK when the buffer list was successfully queued.
285 	 *     #GST_FLOW_FLUSHING when @appsrc is not PAUSED or PLAYING.
286 	 *     #GST_FLOW_EOS when EOS occurred.
287 	 *
288 	 * Since: 1.14
289 	 */
290 	public GstFlowReturn pushBufferList(BufferList bufferList)
291 	{
292 		return gst_app_src_push_buffer_list(gstAppSrc, (bufferList is null) ? null : bufferList.getBufferListStruct());
293 	}
294 
295 	/**
296 	 * Extract a buffer from the provided sample and adds it to the queue of
297 	 * buffers that the appsrc element will push to its source pad. Any
298 	 * previous caps that were set on appsrc will be replaced by the caps
299 	 * associated with the sample if not equal.
300 	 *
301 	 * This function does not take ownership of the
302 	 * sample so the sample needs to be unreffed after calling this function.
303 	 *
304 	 * When the block property is TRUE, this function can block until free
305 	 * space becomes available in the queue.
306 	 *
307 	 * Params:
308 	 *     sample = a #GstSample from which buffer and caps may be
309 	 *         extracted
310 	 *
311 	 * Returns: #GST_FLOW_OK when the buffer was successfully queued.
312 	 *     #GST_FLOW_FLUSHING when @appsrc is not PAUSED or PLAYING.
313 	 *     #GST_FLOW_EOS when EOS occurred.
314 	 *
315 	 * Since: 1.6
316 	 */
317 	public GstFlowReturn pushSample(Sample sample)
318 	{
319 		return gst_app_src_push_sample(gstAppSrc, (sample is null) ? null : sample.getSampleStruct());
320 	}
321 
322 	/**
323 	 * Set callbacks which will be executed when data is needed, enough data has
324 	 * been collected or when a seek should be performed.
325 	 * This is an alternative to using the signals, it has lower overhead and is thus
326 	 * less expensive, but also less flexible.
327 	 *
328 	 * If callbacks are installed, no signals will be emitted for performance
329 	 * reasons.
330 	 *
331 	 * Before 1.16.3 it was not possible to change the callbacks in a thread-safe
332 	 * way.
333 	 *
334 	 * Params:
335 	 *     callbacks = the callbacks
336 	 *     userData = a user_data argument for the callbacks
337 	 *     notify = a destroy notify function
338 	 */
339 	public void setCallbacks(GstAppSrcCallbacks* callbacks, void* userData, GDestroyNotify notify)
340 	{
341 		gst_app_src_set_callbacks(gstAppSrc, callbacks, userData, notify);
342 	}
343 
344 	/**
345 	 * Set the duration of the stream in nanoseconds. A value of GST_CLOCK_TIME_NONE means that the duration is
346 	 * not known.
347 	 *
348 	 * Params:
349 	 *     duration = the duration to set
350 	 *
351 	 * Since: 1.10
352 	 */
353 	public void setDuration(GstClockTime duration)
354 	{
355 		gst_app_src_set_duration(gstAppSrc, duration);
356 	}
357 
358 	/**
359 	 * Make appsrc emit the "new-preroll" and "new-buffer" signals. This option is
360 	 * by default disabled because signal emission is expensive and unneeded when
361 	 * the application prefers to operate in pull mode.
362 	 *
363 	 * Params:
364 	 *     emit = the new state
365 	 */
366 	public void setEmitSignals(bool emit)
367 	{
368 		gst_app_src_set_emit_signals(gstAppSrc, emit);
369 	}
370 
371 	/**
372 	 * Configure the @min and @max latency in @src. If @min is set to -1, the
373 	 * default latency calculations for pseudo-live sources will be used.
374 	 *
375 	 * Params:
376 	 *     min = the min latency
377 	 *     max = the max latency
378 	 */
379 	public void setLatency(ulong min, ulong max)
380 	{
381 		gst_app_src_set_latency(gstAppSrc, min, max);
382 	}
383 
384 	/**
385 	 * Set the maximum amount of bytes that can be queued in @appsrc.
386 	 * After the maximum amount of bytes are queued, @appsrc will emit the
387 	 * "enough-data" signal.
388 	 *
389 	 * Params:
390 	 *     max = the maximum number of bytes to queue
391 	 */
392 	public void setMaxBytes(ulong max)
393 	{
394 		gst_app_src_set_max_bytes(gstAppSrc, max);
395 	}
396 
397 	/**
398 	 * Set the size of the stream in bytes. A value of -1 means that the size is
399 	 * not known.
400 	 *
401 	 * Params:
402 	 *     size = the size to set
403 	 */
404 	public void setSize(long size)
405 	{
406 		gst_app_src_set_size(gstAppSrc, size);
407 	}
408 
409 	/**
410 	 * Set the stream type on @appsrc. For seekable streams, the "seek" signal must
411 	 * be connected to.
412 	 *
413 	 * A stream_type stream
414 	 *
415 	 * Params:
416 	 *     type = the new state
417 	 */
418 	public void setStreamType(GstAppStreamType type)
419 	{
420 		gst_app_src_set_stream_type(gstAppSrc, type);
421 	}
422 
423 	/**
424 	 * Notify @appsrc that no more buffer are available.
425 	 */
426 	gulong addOnEndOfStream(GstFlowReturn delegate(AppSrc) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
427 	{
428 		return Signals.connect(this, "end-of-stream", dlg, connectFlags ^ ConnectFlags.SWAPPED);
429 	}
430 
431 	/**
432 	 * Signal that the source has enough data. It is recommended that the
433 	 * application stops calling push-buffer until the need-data signal is
434 	 * emitted again to avoid excessive buffer queueing.
435 	 */
436 	gulong addOnEnoughData(void delegate(AppSrc) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
437 	{
438 		return Signals.connect(this, "enough-data", dlg, connectFlags ^ ConnectFlags.SWAPPED);
439 	}
440 
441 	/**
442 	 * Signal that the source needs more data. In the callback or from another
443 	 * thread you should call push-buffer or end-of-stream.
444 	 *
445 	 * @length is just a hint and when it is set to -1, any number of bytes can be
446 	 * pushed into @appsrc.
447 	 *
448 	 * You can call push-buffer multiple times until the enough-data signal is
449 	 * fired.
450 	 *
451 	 * Params:
452 	 *     length = the amount of bytes needed.
453 	 */
454 	gulong addOnNeedData(void delegate(uint, AppSrc) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
455 	{
456 		return Signals.connect(this, "need-data", dlg, connectFlags ^ ConnectFlags.SWAPPED);
457 	}
458 
459 	/**
460 	 * Adds a buffer to the queue of buffers that the appsrc element will
461 	 * push to its source pad. This function does not take ownership of the
462 	 * buffer so the buffer needs to be unreffed after calling this function.
463 	 *
464 	 * When the block property is TRUE, this function can block until free space
465 	 * becomes available in the queue.
466 	 *
467 	 * Params:
468 	 *     buffer = a buffer to push
469 	 */
470 	gulong addOnPushBuffer(GstFlowReturn delegate(Buffer, AppSrc) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
471 	{
472 		return Signals.connect(this, "push-buffer", dlg, connectFlags ^ ConnectFlags.SWAPPED);
473 	}
474 
475 	/**
476 	 * Adds a buffer list to the queue of buffers and buffer lists that the
477 	 * appsrc element will push to its source pad. This function does not take
478 	 * ownership of the buffer list so the buffer list needs to be unreffed
479 	 * after calling this function.
480 	 *
481 	 * When the block property is TRUE, this function can block until free space
482 	 * becomes available in the queue.
483 	 *
484 	 * Params:
485 	 *     bufferList = a buffer list to push
486 	 *
487 	 * Since: 1.14
488 	 */
489 	gulong addOnPushBufferList(GstFlowReturn delegate(BufferList, AppSrc) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
490 	{
491 		return Signals.connect(this, "push-buffer-list", dlg, connectFlags ^ ConnectFlags.SWAPPED);
492 	}
493 
494 	/**
495 	 * Extract a buffer from the provided sample and adds the extracted buffer
496 	 * to the queue of buffers that the appsrc element will
497 	 * push to its source pad. This function set the appsrc caps based on the caps
498 	 * in the sample and reset the caps if they change.
499 	 * Only the caps and the buffer of the provided sample are used and not
500 	 * for example the segment in the sample.
501 	 * This function does not take ownership of the
502 	 * sample so the sample needs to be unreffed after calling this function.
503 	 *
504 	 * When the block property is TRUE, this function can block until free space
505 	 * becomes available in the queue.
506 	 *
507 	 * Params:
508 	 *     sample = a sample from which extract buffer to push
509 	 *
510 	 * Since: 1.6
511 	 */
512 	gulong addOnPushSample(GstFlowReturn delegate(Sample, AppSrc) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
513 	{
514 		return Signals.connect(this, "push-sample", dlg, connectFlags ^ ConnectFlags.SWAPPED);
515 	}
516 
517 	/**
518 	 * Seek to the given offset. The next push-buffer should produce buffers from
519 	 * the new @offset.
520 	 * This callback is only called for seekable stream types.
521 	 *
522 	 * Params:
523 	 *     offset = the offset to seek to
524 	 *
525 	 * Returns: %TRUE if the seek succeeded.
526 	 */
527 	gulong addOnSeekData(bool delegate(ulong, AppSrc) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
528 	{
529 		return Signals.connect(this, "seek-data", dlg, connectFlags ^ ConnectFlags.SWAPPED);
530 	}
531 
532 	/**
533 	 * Set the capabilities on the appsrc element.  This function takes
534 	 * a copy of the caps structure. After calling this method, the source will
535 	 * only produce caps that match @caps. @caps must be fixed and the caps on the
536 	 * buffers must match the caps or left NULL.
537 	 *
538 	 * Params:
539 	 *     caps = caps to set
540 	 */
541 	public void appSrcSetCaps(Caps caps)
542 	{
543 		gst_app_src_set_caps(gstAppSrc, (caps is null) ? null : caps.getCapsStruct());
544 	}
545 }