summaryrefslogtreecommitdiff
path: root/gst/playondemand/filter.func
diff options
context:
space:
mode:
Diffstat (limited to 'gst/playondemand/filter.func')
-rw-r--r--gst/playondemand/filter.func93
1 files changed, 40 insertions, 53 deletions
diff --git a/gst/playondemand/filter.func b/gst/playondemand/filter.func
index 2d77189fe..038ad119b 100644
--- a/gst/playondemand/filter.func
+++ b/gst/playondemand/filter.func
@@ -3,18 +3,19 @@
_TYPE_ *data_in, *data_out, *filter_data;
filter_data = (_TYPE_ *) filter->buffer;
-num_filter = filter->buffer_size / sizeof(_TYPE_);
-max_filter = (filter->play_from_beginning) ? num_filter : G_MAXUINT;
+num_filter = filter->buffer_bytes / sizeof(_TYPE_);
/******************************************************************************/
/* see if we've got any events coming through ... */
do {
- GST_DEBUG(0, "--- going to events");
-
- while (! filter->eos && GST_IS_EVENT(in)) {
+ while (GST_IS_EVENT(in)) {
if (GST_EVENT_TYPE(in) == GST_EVENT_EOS) {
filter->eos = TRUE;
+ } else if ((GST_EVENT_TYPE(in) == GST_EVENT_SEEK) ||
+ (GST_EVENT_TYPE(in) == GST_EVENT_FLUSH)) {
+ filter->eos = FALSE;
+ filter->write = 0;
} else {
gst_pad_push(filter->srcpad, in);
}
@@ -25,8 +26,6 @@ do {
/****************************************************************************/
/* first handle data from the input buffer. */
- GST_DEBUG(0, "--- done with events, going to input");
-
/* only update the input if there hasn't been an eos yet. */
if (! filter->eos) {
data_in = (_TYPE_ *) GST_BUFFER_DATA(in);
@@ -35,27 +34,13 @@ do {
w = filter->write;
/* copy the input data to the filter's internal buffer. */
- for (j = 0; (j < num_in) && ((w + j) < max_filter); j++) {
+ for (j = 0; (j < num_in) && ((w + j) < num_filter); j++)
filter_data[(w + j) % num_filter] = data_in[j];
- }
filter->write = (w + j) % num_filter;
- if ((w + j) >= num_filter) {
- filter->buffer_filled_once = TRUE;
-
- /* if we're not playing from the end of the stream, the buffer is not a
- ring buffer, so it has a fixed size. we need to set eos here because
- we've passed that limit. */
- if (filter->play_from_beginning) {
- filter->eos = TRUE;
- }
- }
-
- /* update the start pointer */
- if ((! filter->play_from_beginning) && filter->buffer_filled_once) {
- filter->start = (filter->write + 1) % num_filter;
- }
+ if ((w + j) >= num_filter)
+ filter->eos = TRUE;
out = in;
} else {
@@ -68,56 +53,58 @@ do {
/****************************************************************************/
/* check to see if we have to add a new play pointer. */
- GST_DEBUG(0, "--- done with input, checking clock before output");
-
- play_on_demand_update_plays_from_clock(filter);
+ if (filter->clock) {
+ current_tick = ((guint) (gst_clock_get_time(filter->clock) *
+ filter->clock_speed)) % filter->total_ticks;
+
+ if (current_tick != last_tick) {
+ /* now we go through the tick list and play samples */
+ tick_list = filter->tick_list;
+ while (tick_list) {
+ tick = GPOINTER_TO_UINT(tick_list->data);
+ if (current_tick == tick)
+ play_on_demand_add_play_pointer(filter, 0);
+ else if (GST_POD_TICK_ELAPSED(tick, current_tick, last_tick))
+ play_on_demand_add_play_pointer(filter, GST_POD_SAMPLE_OFFSET(filter, current_tick - tick));
+ tick_list = g_slist_next(tick_list);
+ }
+ last_tick = current_tick;
+ }
+ }
/****************************************************************************/
/* now handle output data. */
- GST_DEBUG(0, "--- done with clock, going to output");
-
data_out = (_TYPE_ *) GST_BUFFER_DATA(out);
num_out = GST_BUFFER_SIZE(out) / sizeof(_TYPE_);
- for (k = 0; k < num_out; k++) {
+ for (k = 0; k < num_out; k++)
data_out[k] = zero;
- }
/* output play pointer data. */
- for (t = 0; t < GST_POD_MAX_PLAY_PTRS; t++) {
- offset = filter->plays[t];
-
- if (offset != G_MAXUINT) {
- if (! filter->play_from_beginning) {
- for (k = 0; k < num_out; k++) {
- data_out[k] = CLAMP(data_out[k] + filter_data[(offset + k) % num_filter], min, max);
- }
- } else {
- for (k = 0; (k < num_out) && (k < (w + j - offset)); k++) {
+ if (! filter->mute)
+ for (t = 0; t < filter->max_plays; t++) {
+ offset = filter->plays[t];
+
+ if (offset != G_MAXUINT) {
+ for (k = 0; (k < num_out) && (offset + k < num_filter); k++)
data_out[k] = CLAMP(data_out[k] + filter_data[offset + k], min, max);
- }
- }
- if ((! filter->play_from_beginning) || ((offset + k) < (w + j))) {
- filter->plays[t] = (offset + k) % num_filter;
- } else {
- filter->plays[t] = G_MAXUINT;
+ if ((offset + k) == num_filter)
+ filter->plays[t] = G_MAXUINT;
+ else
+ filter->plays[t] = offset + k;
}
}
- }
/****************************************************************************/
/* push out the buffer. */
- GST_DEBUG(0, "--- done with output, pushing buffer %p", out);
-
gst_pad_push(filter->srcpad, out);
- if (! filter->eos) {
+ if (! filter->eos)
in = gst_pad_pull(filter->sinkpad);
- }
- gst_element_yield (GST_ELEMENT (filter));
+ gst_element_interrupt (GST_ELEMENT (filter));
} while (TRUE);