fix stop the correct way
This commit is contained in:
parent
2ad0e71225
commit
30899013bc
|
@ -87,7 +87,6 @@ struct local_stream_source {
|
||||||
switch_thread_rwlock_t *rwlock;
|
switch_thread_rwlock_t *rwlock;
|
||||||
int ready;
|
int ready;
|
||||||
int stopped;
|
int stopped;
|
||||||
int stop_request;
|
|
||||||
int part_reload;
|
int part_reload;
|
||||||
int full_reload;
|
int full_reload;
|
||||||
int chime_freq;
|
int chime_freq;
|
||||||
|
@ -168,7 +167,7 @@ static void *SWITCH_THREAD_FUNC read_stream_thread(switch_thread_t *thread, void
|
||||||
|
|
||||||
switch_yield(1000000);
|
switch_yield(1000000);
|
||||||
|
|
||||||
while (RUNNING) {
|
while (RUNNING && !source->stopped) {
|
||||||
switch_size_t olen;
|
switch_size_t olen;
|
||||||
uint8_t abuf[SWITCH_RECOMMENDED_BUFFER_SIZE] = { 0 };
|
uint8_t abuf[SWITCH_RECOMMENDED_BUFFER_SIZE] = { 0 };
|
||||||
|
|
||||||
|
@ -223,7 +222,7 @@ static void *SWITCH_THREAD_FUNC read_stream_thread(switch_thread_t *thread, void
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (RUNNING) {
|
while (RUNNING && !source->stopped) {
|
||||||
int is_open;
|
int is_open;
|
||||||
switch_file_handle_t *use_fh = &fh;
|
switch_file_handle_t *use_fh = &fh;
|
||||||
|
|
||||||
|
@ -324,7 +323,7 @@ static void *SWITCH_THREAD_FUNC read_stream_thread(switch_thread_t *thread, void
|
||||||
switch_dir_close(source->dir_handle);
|
switch_dir_close(source->dir_handle);
|
||||||
source->dir_handle = NULL;
|
source->dir_handle = NULL;
|
||||||
|
|
||||||
if(source->stop_request||source->full_reload) {
|
if (source->full_reload) {
|
||||||
if (source->rwlock && switch_thread_rwlock_trywrlock(source->rwlock) != SWITCH_STATUS_SUCCESS) {
|
if (source->rwlock && switch_thread_rwlock_trywrlock(source->rwlock) != SWITCH_STATUS_SUCCESS) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Cannot stop local_stream://%s because it is in use.\n",source->name);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Cannot stop local_stream://%s because it is in use.\n",source->name);
|
||||||
if (source->part_reload) {
|
if (source->part_reload) {
|
||||||
|
@ -372,10 +371,6 @@ static void *SWITCH_THREAD_FUNC read_stream_thread(switch_thread_t *thread, void
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "local_stream://%s partially reloaded.\n",source->name);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "local_stream://%s partially reloaded.\n",source->name);
|
||||||
source->part_reload = 0;
|
source->part_reload = 0;
|
||||||
}
|
}
|
||||||
} else if(source->stop_request) {
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "local_stream://%s stopped.\n",source->name);
|
|
||||||
source->stopped = 1;
|
|
||||||
goto done;
|
|
||||||
} else {
|
} else {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "local_stream://%s fully reloaded.\n",source->name);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "local_stream://%s fully reloaded.\n",source->name);
|
||||||
launch_streams(source->name);
|
launch_streams(source->name);
|
||||||
|
@ -760,7 +755,7 @@ SWITCH_STANDARD_API(stop_local_stream_function)
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
source->stop_request = 1;
|
source->stopped = 1;
|
||||||
stream->write_function(stream, "+OK");
|
stream->write_function(stream, "+OK");
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
|
@ -839,7 +834,7 @@ SWITCH_STANDARD_API(show_local_stream_function)
|
||||||
stream->write_function(stream, " total: %d\n", source->total);
|
stream->write_function(stream, " total: %d\n", source->total);
|
||||||
stream->write_function(stream, " shuffle: %s\n", (source->shuffle) ? "true" : "false");
|
stream->write_function(stream, " shuffle: %s\n", (source->shuffle) ? "true" : "false");
|
||||||
stream->write_function(stream, " ready: %s\n", (source->ready) ? "true" : "false");
|
stream->write_function(stream, " ready: %s\n", (source->ready) ? "true" : "false");
|
||||||
stream->write_function(stream, " stopping: %s\n", (source->stop_request) ? "true" : "false");
|
stream->write_function(stream, " stopped: %s\n", (source->stopped) ? "true" : "false");
|
||||||
stream->write_function(stream, " reloading: %s\n", (source->full_reload) ? "true" : "false");
|
stream->write_function(stream, " reloading: %s\n", (source->full_reload) ? "true" : "false");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -888,7 +883,6 @@ SWITCH_STANDARD_API(start_local_stream_function)
|
||||||
switch_mutex_unlock(globals.mutex);
|
switch_mutex_unlock(globals.mutex);
|
||||||
if (source) {
|
if (source) {
|
||||||
source->stopped = 0;
|
source->stopped = 0;
|
||||||
source->stop_request = 0;
|
|
||||||
stream->write_function(stream, "+OK stream: %s", source->name);
|
stream->write_function(stream, "+OK stream: %s", source->name);
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue