changeset 1690:75e0c0e13ed3

Branch merge.
author Matti Hamalainen <ccr@tnsp.org>
date Fri, 07 Sep 2007 06:58:36 +0300
parents 4dfc5a28d681 (current diff) e22d2f840d87 (diff)
children aa40f1404257
files src/sexypsf/plugin.c src/sid/xmms-sid.c
diffstat 2 files changed, 36 insertions(+), 34 deletions(-) [+]
line wrap: on
line diff
--- a/src/sexypsf/plugin.c	Fri Sep 07 00:06:49 2007 +0300
+++ b/src/sexypsf/plugin.c	Fri Sep 07 06:58:36 2007 +0300
@@ -123,7 +123,6 @@
 
     playback->output->close_audio();
     if (!(stop)) nextsong = TRUE;
-    g_thread_exit(NULL);
     return NULL;
 }
 
--- a/src/sid/xmms-sid.c	Fri Sep 07 00:06:49 2007 +0300
+++ b/src/sid/xmms-sid.c	Fri Sep 07 06:58:36 2007 +0300
@@ -277,15 +277,23 @@
 	return result;
 }
 
+static gchar * xs_has_tracknumber(gchar *pcFilename)
+{
+	gchar *tmpSep = xs_strrchr(pcFilename, '?');
+	if (tmpSep && g_ascii_isdigit(*(tmpSep + 1)))
+		return tmpSep;
+	else
+		return NULL;
+}
 
 gboolean xs_get_trackinfo(const gchar *pcFilename, gchar **pcResult, gint *pTrack)
 {
 	gchar *tmpSep;
 
 	*pcResult = g_strdup(pcFilename);
-	tmpSep = xs_strrchr(*pcResult, '?');
+	tmpSep = xs_has_tracknumber(*pcResult);
 
-	if (tmpSep && g_ascii_isdigit(*(tmpSep + 1))) {
+	if (tmpSep) {
 		*tmpSep = '\0';
 		*pTrack = atoi(tmpSep + 1);
 		return TRUE;
@@ -298,52 +306,47 @@
 
 gint xs_is_our_file_vfs(gchar *pcFilename, t_xs_file *f)
 {
-	gint tmpResult = 0;
+	gint tmpResult = 0, tmpDummy = 0;
 	assert(xs_status.sidPlayer);
 
 	/* Check the filename */
 	if (pcFilename == NULL)
 		return 0;
 	
+	if (xs_has_tracknumber(pcFilename) != NULL)
+		return 1;
+	
 	if (xs_status.sidPlayer->plrProbe(f)) {
-		gchar *tmpFilename = NULL;
-		gint tmpDummy = 0;
-
-		if (xs_get_trackinfo(pcFilename, &tmpFilename, &tmpDummy)) {
-			tmpResult = 1;
-		} else {
-			t_xs_tuneinfo *pInfo = xs_status.sidPlayer->plrGetSIDInfo(tmpFilename);
+		t_xs_tuneinfo *pInfo;
+		
+		pInfo = xs_status.sidPlayer->plrGetSIDInfo(pcFilename);
 		
-			if (pInfo->nsubTunes > 1) {
-				gint i;
-				
-				for (i = 1; i <= pInfo->nsubTunes; i++) {
-					gchar *tmpStr = g_strdup_printf("%s?%d", pcFilename, i);
-					gboolean doAdd = FALSE;
+		if (pInfo->nsubTunes > 1) {
+			gint i;
+			for (i = 1; i <= pInfo->nsubTunes; i++) {
+				gchar *tmpStr = g_strdup_printf("%s?%d", pcFilename, i);
+				gboolean doAdd = FALSE;
 					
-					if (xs_cfg.subAutoMinOnly) {
-						if (i == pInfo->startTune ||
-							pInfo->subTunes[i - 1].tuneLength >= xs_cfg.subAutoMinTime)
-							doAdd = TRUE;
-					} else
+				if (xs_cfg.subAutoMinOnly) {
+					if (i == pInfo->startTune ||
+						pInfo->subTunes[i - 1].tuneLength >= xs_cfg.subAutoMinTime)
 						doAdd = TRUE;
+				} else
+					doAdd = TRUE;
 					
-					if (doAdd)
-						playlist_add_url(playlist_get_active(), tmpStr);
+				if (doAdd)
+					playlist_add_url(playlist_get_active(), tmpStr);
 
-					g_free(tmpStr);
-				}
+				g_free(tmpStr);
+			}
 
-				tmpResult = -1;
-			} else
-				tmpResult = 1;
+			tmpResult = -1;
+		} else
+			tmpResult = 1;
 			
-			xs_tuneinfo_free(pInfo);
-		}
+		xs_tuneinfo_free(pInfo);
+	}
 		
-		g_free(tmpFilename);
-	}
-	
 	return tmpResult;
 }