void NLXmms::update() { //look for running xmms if ( xmms_remote_get_version( 0 ) ) { QString newTrack; // see if it's playing if ( xmms_remote_is_playing( 0 ) && !xmms_remote_is_paused( 0 ) ) { m_playing = true; // get the artist and album title // get the song title newTrack = xmms_remote_get_playlist_title( 0, xmms_remote_get_playlist_pos( 0 ) ); //kdDebug( 14307 ) << "NLXmms::update() - track is: " << m_track << endl; m_artist = newTrack.section( " - ", 0, 0 ); newTrack = newTrack.section( " - ", -1, -1 ); } else m_playing = false; // check if it's a new song if ( newTrack != m_track ) { m_newTrack = true; m_track = newTrack; } else m_newTrack = false; kdDebug( 14307 ) << k_funcinfo << " - found xmms - " << m_track << endl; } else kdDebug( 14307 ) << k_funcinfo << " - xmms not found" << endl; }
int main(int argc, char *argv[]) { int session = 0; int pos; char *text; if (argc > 1) { if (isdigit(argv[1][0])) { session = atoi(argv[1]); } else { /* translators: this is the logjam-xmms-client command line. */ fprintf(stderr, _("usage: %s [session_number]\n"), argv[0]); return -1; } } pos = xmms_remote_get_playlist_pos(session); text = xmms_remote_get_playlist_title(session, pos); if (!text) { fprintf(stderr, _("XMMS error. Is XMMS running?\n")); return -1; } printf("%s\n", text); return 0; }
Uint32 get_xmms_title(Uint32 something, void *somethingelse) { static char check_title = 1; static int last_pos; static char *last_title = NULL; int pos; char *title = NULL; //Nice optimization, but we want the title no matter what so I can display it when the song changes #if 0 if(!(globalPM->showtitle%2)) { /* Repeat less often when not showing title */ return 1000; } #endif pos = xmms_remote_get_playlist_pos(projectM_vtable.xmms_session); /* Only check every 1 second for title change, otherwise check pos */ if(check_title || pos != last_pos) { title = xmms_remote_get_playlist_title( projectM_vtable.xmms_session, pos); if(title && (!last_title || strcmp(last_title,title))) { //globalPM->renderer->title = title; //globalPM->renderer->drawtitle = 1; std::string titlepp(title); globalPM->projectM_setTitle(titlepp); g_free(last_title); last_title = title; } else if(title && last_title != title) { /* New copy of last title */ g_free(title); } check_title = !check_title; } last_pos = pos; /* Repeat every 500ms */ return 500; }
/* do_command(): do @cmd after replacing the format codes @cmd: command to run @current_file: file name of current song @pos: playlist_pos */ void do_command(char *cmd, const char *current_file, int pos) { int length, rate, freq, nch; char *str, *shstring = NULL, *temp, numbuf[16]; gboolean playing; Formatter *formatter; if (cmd && strlen(cmd) > 0) { formatter = xmms_formatter_new(); str = xmms_remote_get_playlist_title(sc_gp.xmms_session, pos); if (str) { temp = escape_shell_chars(str); xmms_formatter_associate(formatter, 's', temp); xmms_formatter_associate(formatter, 'n', temp); g_free(str); g_free(temp); } else { xmms_formatter_associate(formatter, 's', ""); xmms_formatter_associate(formatter, 'n', ""); } if (current_file) { temp = escape_shell_chars(current_file); xmms_formatter_associate(formatter, 'f', temp); g_free(temp); } else xmms_formatter_associate(formatter, 'f', ""); sprintf(numbuf, "%02d", pos + 1); xmms_formatter_associate(formatter, 't', numbuf); length = xmms_remote_get_playlist_time(sc_gp.xmms_session, pos); if (length != -1) { sprintf(numbuf, "%d", length); xmms_formatter_associate(formatter, 'l', numbuf); } else xmms_formatter_associate(formatter, 'l', "0"); xmms_remote_get_info(sc_gp.xmms_session, &rate, &freq, &nch); sprintf(numbuf, "%d", rate); xmms_formatter_associate(formatter, 'r', numbuf); sprintf(numbuf, "%d", freq); xmms_formatter_associate(formatter, 'F', numbuf); sprintf(numbuf, "%d", nch); xmms_formatter_associate(formatter, 'c', numbuf); playing = xmms_remote_is_playing(sc_gp.xmms_session); sprintf(numbuf, "%d", playing); xmms_formatter_associate(formatter, 'p', numbuf); shstring = xmms_formatter_format(formatter, cmd); xmms_formatter_destroy(formatter); if (shstring) { execute_command(shstring); /* FIXME: This can possibly be freed too early */ g_free(shstring); } } }
void XMMSSensor::update() { QString format; SensorParams *sp; Meter *meter; QObjectListIt it( *objList ); #ifdef HAVE_XMMS int pos; QString title; int songLength = 0; int currentTime = 0; bool isPlaying = false; bool isRunning = xmms_remote_is_running(0); if( isRunning ) { isPlaying = xmms_remote_is_playing(0); pos = xmms_remote_get_playlist_pos(0); qDebug("unicode start"); title = codec->toUnicode( QCString( xmms_remote_get_playlist_title( 0, pos ) ) ); qDebug("unicode end"); if( title.isEmpty() ) title = "XMMS"; qDebug("Title: %s", title.ascii()); songLength = xmms_remote_get_playlist_time( 0, pos ); currentTime = xmms_remote_get_output_time( 0 ); } #endif // HAVE_XMMS while (it != 0) { sp = (SensorParams*)(*it); meter = sp->getMeter(); #ifdef HAVE_XMMS if( isRunning ) { format = sp->getParam("FORMAT"); if (format.length() == 0 ) { format = "%title %time / %length"; } if( format == "%ms" ) { meter->setMax( songLength ); meter->setValue( currentTime ); } else if ( format == "%full" ) { meter->setValue( 1 ); } else { format.replace( QRegExp("%title", false), title ); format.replace( QRegExp("%length", false), QTime( 0,0,0 ). addMSecs( songLength ) .toString( "h:mm:ss" ) ); format.replace( QRegExp("%time", false), QTime( 0,0,0 ). addMSecs( currentTime ) .toString( "h:mm:ss" ) ); if( isPlaying ) { format.replace( QRegExp("%remain", false), QTime( 0,0,0 ). addMSecs( songLength ) .addMSecs(-currentTime ) .toString( "h:mm:ss" ) ); } else { format.replace( QRegExp("%remain", false), QTime( 0,0,0 ).toString("h:mm:ss" ) ); } meter->setValue(format); } } else #endif // HAVE_XMMS { meter->setValue(""); } ++it; } }
/* * Callback funtion to handle delayed display. */ static gint timeout_func(gpointer data) { gint pos, volume, balance; gboolean playing, paused, repeat, shuffle; gchar *text; if (!osd) return FALSE; GDK_THREADS_ENTER(); pos = xmms_remote_get_playlist_pos (gp.xmms_session); playing = xmms_remote_is_playing (gp.xmms_session); paused = xmms_remote_is_paused (gp.xmms_session); volume = xmms_remote_get_main_volume (gp.xmms_session); shuffle = xmms_remote_is_shuffle (gp.xmms_session); repeat = xmms_remote_is_repeat (gp.xmms_session); balance = (xmms_remote_get_balance(gp.xmms_session) + 100) / 2; /** * Check if the position of the current song has changed. * DTM: bugfix * 1) 'get_playlist_time' seems "variable" for a song, don't use it * 2) we must free the titles we download */ if (pos != previous_song) { if (xmms_remote_get_playlist_length (gp.xmms_session)) /* otherwise it'll crash */ { text = xmms_remote_get_playlist_title (gp.xmms_session, pos); if (text) replace_hexcodes (text); /** * Check to see if the title of the song has changed. */ if ( !previous_title || g_strcasecmp(text, previous_title) != 0 ) { if (show_stop) { xosd_display (osd, 0, XOSD_string, playing ? "Play" : "Stopped"); xosd_display (osd, 1, XOSD_string, text); } save_previous_title( text ); } } else { /** No song titles available. */ if (show_stop) { xosd_display (osd, 0, XOSD_string, playing ? "Play" : "Stopped"); } save_previous_title( 0 ); } previous_song = pos; } else if (playing != previous_playing ) { if (playing && show_trackname) { xosd_display (osd, 0, XOSD_string, "Play"); text = xmms_remote_get_playlist_title (gp.xmms_session, pos); if (text) { replace_hexcodes (text); xosd_display (osd, 1, XOSD_string, text); save_previous_title ( text ); } } else if (!playing && show_stop ) { xosd_display (osd, 0, XOSD_string, "Stop"); xosd_display (osd, 1, XOSD_string, ""); } previous_playing = playing; } else if (paused != previous_paused && show_pause) { if (paused) { xosd_display (osd, 0, XOSD_string, "Paused"); xosd_display (osd, 1, XOSD_string, ""); } else { xosd_display (osd, 0, XOSD_string, "Unpaused"); text = xmms_remote_get_playlist_title (gp.xmms_session, pos); if (text) { replace_hexcodes (text); xosd_display (osd, 1, XOSD_string, text); save_previous_title( text ); } } previous_paused = paused; } else if (volume != previous_volume && show_volume) { xosd_display (osd, 0, XOSD_string, "Volume"); xosd_display (osd, 1, XOSD_percentage, volume); previous_volume = volume; } else if (balance != previous_balance && show_balance) { xosd_display (osd, 0, XOSD_string, "Balance"); xosd_display (osd, 1, XOSD_slider, balance); previous_balance = balance; } else if (repeat != previous_repeat && show_repeat ) { xosd_display (osd, 0, XOSD_string, "Repeat"); xosd_display (osd, 1, XOSD_string, repeat ? "On" : "Off"); previous_repeat = repeat; } else if (shuffle != previous_shuffle && show_shuffle ) { xosd_display (osd, 0, XOSD_string, "Shuffle"); xosd_display (osd, 1, XOSD_string, shuffle ? "On" : "Off"); previous_shuffle = shuffle; } GDK_THREADS_LEAVE(); return TRUE; }