Skip to content
This repository has been archived by the owner on Jan 5, 2018. It is now read-only.

Commit

Permalink
spaces back to tabs
Browse files Browse the repository at this point in the history
  • Loading branch information
Unia committed Mar 28, 2013
1 parent 3ce0a50 commit 6b1214b
Show file tree
Hide file tree
Showing 3 changed files with 166 additions and 168 deletions.
2 changes: 1 addition & 1 deletion PKGBUILD
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
pkgname=dwm-status
pkgver=20130316
pkgver=20130328
pkgrel=1
pkgdesc='A hardcoded statusbar for DWM'
arch=(any)
Expand Down
329 changes: 164 additions & 165 deletions dwmst.c
Original file line number Diff line number Diff line change
@@ -1,188 +1,187 @@
#include "dwmst.h"

int main() {
dpy = XOpenDisplay(NULL);
if (dpy == NULL) {
fprintf(stderr, "ERROR: could not open display\n");
exit(1);
}
root = XRootWindow(dpy, DefaultScreen(dpy));
winfo = (struct wireless_info *) calloc(1, sizeof(struct wireless_info));
dpy = XOpenDisplay(NULL);
if (dpy == NULL) {
fprintf(stderr, "ERROR: could not open display\n");
exit(1);
}
root = XRootWindow(dpy, DefaultScreen(dpy));
winfo = (struct wireless_info *) calloc(1, sizeof(struct wireless_info));
#ifdef CLK
setlocale(LC_ALL, "");
setlocale(LC_ALL, "");
#endif
#ifdef AUD
g_type_init();
g_type_init();
#endif
/* MAIN LOOP STARTS HERE */
for (;;) {
status[0]='\0';
/* MUSIC */
for (;;) {
status[0]='\0';
/* MUSIC */
#ifdef MPD
if (++musicloops > 10) {
musicloops = 0;
struct mpd_connection *conn = mpd_connection_new(NULL, 0, 30000);
if (mpd_connection_get_error(conn))
sprintf(musicstring, NO_MPD_STR);
mpd_command_list_begin(conn, true);
mpd_send_status(conn);
mpd_send_current_song(conn);
mpd_command_list_end(conn);
struct mpd_status* theStatus = mpd_recv_status(conn);
if (!theStatus)
sprintf(musicstring, NO_MPD_STR);
else {
if (mpd_status_get_state(theStatus) == MPD_STATE_PLAY) {
mpd_response_next(conn);
song = mpd_recv_song(conn);
title = mpd_song_get_tag(song, MPD_TAG_TITLE, 0);
artist = mpd_song_get_tag(song, MPD_TAG_ARTIST, 0);
sprintf(musicstring, MPD_STR, title, artist);
mpd_song_free(song);
} else if (mpd_status_get_state(theStatus) == MPD_STATE_PAUSE) {
mpd_response_next(conn);
song = mpd_recv_song(conn);
title = mpd_song_get_tag(song, MPD_TAG_TITLE, 0);
artist = mpd_song_get_tag(song, MPD_TAG_ARTIST, 0);
sprintf(musicstring, MPD_P_STR, title, artist);
mpd_song_free(song);
} else if (mpd_status_get_state(theStatus) == MPD_STATE_STOP)
sprintf(musicstring, MPD_S_STR);
}
mpd_response_finish(conn);
mpd_connection_free(conn);
}
strcat(status, musicstring);
if (++musicloops > 10) {
musicloops = 0;
struct mpd_connection *conn = mpd_connection_new(NULL, 0, 30000);
if (mpd_connection_get_error(conn))
sprintf(musicstring, NO_MPD_STR);
mpd_command_list_begin(conn, true);
mpd_send_status(conn);
mpd_send_current_song(conn);
mpd_command_list_end(conn);
struct mpd_status* theStatus = mpd_recv_status(conn);
if (!theStatus)
sprintf(musicstring, NO_MPD_STR);
else {
if (mpd_status_get_state(theStatus) == MPD_STATE_PLAY) {
mpd_response_next(conn);
song = mpd_recv_song(conn);
title = mpd_song_get_tag(song, MPD_TAG_TITLE, 0);
artist = mpd_song_get_tag(song, MPD_TAG_ARTIST, 0);
sprintf(musicstring, MPD_STR, title, artist);
mpd_song_free(song);
} else if (mpd_status_get_state(theStatus) == MPD_STATE_PAUSE) {
mpd_response_next(conn);
song = mpd_recv_song(conn);
title = mpd_song_get_tag(song, MPD_TAG_TITLE, 0);
artist = mpd_song_get_tag(song, MPD_TAG_ARTIST, 0);
sprintf(musicstring, MPD_P_STR, title, artist);
mpd_song_free(song);
} else if (mpd_status_get_state(theStatus) == MPD_STATE_STOP)
sprintf(musicstring, MPD_S_STR);
}
mpd_response_finish(conn);
mpd_connection_free(conn);
}
strcat(status, musicstring);
#endif
#ifdef AUD
if (++musicloops > 10) {
musicloops = 0;
connection = dbus_g_bus_get(DBUS_BUS_SESSION, NULL);
session = dbus_g_proxy_new_for_name(connection, AUDACIOUS_DBUS_SERVICE, AUDACIOUS_DBUS_PATH, AUDACIOUS_DBUS_INTERFACE);
playpos = audacious_remote_get_playlist_pos(session);
psong = audacious_remote_get_playlist_title(session, playpos);
if (psong) {
if (audacious_remote_is_paused(session)) {
sprintf(musicstring, MUSIC_P_STR, psong);
free(psong);
} else if (audacious_remote_is_playing(session)) {
sprintf(musicstring, MUSIC_STR, psong);
free(psong);
} else
sprintf(musicstring, MUSIC_S_STR);
} else
sprintf(musicstring, MUSIC_S_STR);
g_object_unref(session);
}
strcat(status, musicstring);
if (++musicloops > 10) {
musicloops = 0;
connection = dbus_g_bus_get(DBUS_BUS_SESSION, NULL);
session = dbus_g_proxy_new_for_name(connection, AUDACIOUS_DBUS_SERVICE, AUDACIOUS_DBUS_PATH, AUDACIOUS_DBUS_INTERFACE);
playpos = audacious_remote_get_playlist_pos(session);
psong = audacious_remote_get_playlist_title(session, playpos);
if (psong) {
if (audacious_remote_is_paused(session)) {
sprintf(musicstring, MUSIC_P_STR, psong);
free(psong);
} else if (audacious_remote_is_playing(session)) {
sprintf(musicstring, MUSIC_STR, psong);
free(psong);
} else
sprintf(musicstring, MUSIC_S_STR);
} else
sprintf(musicstring, MUSIC_S_STR);
g_object_unref(session);
}
strcat(status, musicstring);
#endif
/* SKYPE */
infile = fopen(SKYPE_FILE, "r");
if (infile) {
sprintf(statnext, SKYPE_STR);
fclose(infile);
}
else
sprintf(statnext, NO_SKYPE_STR);
strcat(status, statnext);
/* WIFI */
if (++wifiloops > 60) {
wifiloops = 0;
skfd = iw_sockets_open();
if (iw_get_basic_config(skfd, WIFI, &(winfo->b)) > -1) {
if (iw_get_stats(skfd, WIFI, &(winfo->stats), &winfo->range, winfo->has_range) >= 0)
winfo->has_stats = 1;
if (iw_get_range_info(skfd, WIFI, &(winfo->range)) >= 0)
winfo->has_range = 1;
if (winfo->b.has_essid) {
if (winfo->b.essid_on)
sprintf(wifistring, WIFI_STR, winfo->b.essid, (winfo->stats.qual.qual * 100) / winfo->range.max_qual.qual);
else
sprintf(wifistring, NO_WIFI_STR);
}
}
iw_sockets_close(skfd);
memset(winfo, 0, sizeof(struct wireless_info));
}
strcat(status,wifistring);
/* Audio volume */
snd_mixer_open(&handle, 0);
snd_mixer_attach(handle, "default");
snd_mixer_selem_register(handle, NULL, NULL);
snd_mixer_load(handle);
snd_mixer_selem_id_malloc(&vol_info);
snd_mixer_selem_id_set_name(vol_info, VOL_CH);
pcm_mixer = snd_mixer_find_selem(handle, vol_info);
snd_mixer_selem_get_playback_volume_range(pcm_mixer, &min, &max); /* get volume */
snd_mixer_selem_get_playback_volume(pcm_mixer, SND_MIXER_SCHN_MONO, &vol);
snd_mixer_selem_id_malloc(&mute_info);
snd_mixer_selem_id_set_name(mute_info, VOL_CH);
mas_mixer = snd_mixer_find_selem(handle, mute_info);
snd_mixer_selem_get_playback_switch(mas_mixer, SND_MIXER_SCHN_MONO, &mute); /* get mute state */
if(mute == 0)
sprintf(statnext, VOL_MUTE_STR);
else {
realvol = (vol * 100) / max;
sprintf(statnext, VOL_STR, realvol);
}
if(vol_info)
snd_mixer_selem_id_free(vol_info);
if (mute_info)
snd_mixer_selem_id_free(mute_info);
if (handle)
snd_mixer_close(handle);
strcat(status,statnext);
/* Power / Battery */
infile = fopen(BATT_NOW, "r");
fscanf(infile, "%ld\n", &now); fclose(infile);
infile = fopen(BATT_FULL, "r");
fscanf(infile, "%ld\n", &full); fclose(infile);
infile = fopen(BATT_STAT, "r");
fscanf(infile, "%s\n", state); fclose(infile);
infile = fopen(BATT_VOLT, "r");
fscanf(infile, "%ld\n", &voltage); fclose(infile);
infile = fopen(BATT_CNOW, "r");
fscanf(infile, "%ld\n", &rate); fclose(infile);
now = ((float)voltage / 1000) * ((float)now / 1000);
full = ((float)voltage / 1000) * ((float)full / 1000);
rate = ((float)voltage / 1000) * ((float)rate / 1000);
perc = (now * 100) / full;
if (strncmp(state, "Full", 8) == 0)
sprintf(statnext, BAT_FULL_STR, perc);
else if(strncmp(state, "Unknown", 8) == 0)
sprintf(statnext, BAT_UNK_STR);
else if (strncmp(state, "Charging", 8) == 0) {
/* SKYPE */
infile = fopen(SKYPE_FILE, "r");
if (infile) {
sprintf(statnext, SKYPE_STR);
fclose(infile);
} else
sprintf(statnext, NO_SKYPE_STR);
strcat(status, statnext);
/* WIFI */
if (++wifiloops > 60) {
wifiloops = 0;
skfd = iw_sockets_open();
if (iw_get_basic_config(skfd, WIFI, &(winfo->b)) > -1) {
if (iw_get_stats(skfd, WIFI, &(winfo->stats), &winfo->range, winfo->has_range) >= 0)
winfo->has_stats = 1;
if (iw_get_range_info(skfd, WIFI, &(winfo->range)) >= 0)
winfo->has_range = 1;
if (winfo->b.has_essid) {
if (winfo->b.essid_on)
sprintf(wifistring, WIFI_STR, winfo->b.essid, (winfo->stats.qual.qual * 100) / winfo->range.max_qual.qual);
else
sprintf(wifistring, NO_WIFI_STR);
}
}
iw_sockets_close(skfd);
memset(winfo, 0, sizeof(struct wireless_info));
}
strcat(status,wifistring);
/* Audio volume */
snd_mixer_open(&handle, 0);
snd_mixer_attach(handle, "default");
snd_mixer_selem_register(handle, NULL, NULL);
snd_mixer_load(handle);
snd_mixer_selem_id_malloc(&vol_info);
snd_mixer_selem_id_set_name(vol_info, VOL_CH);
pcm_mixer = snd_mixer_find_selem(handle, vol_info);
snd_mixer_selem_get_playback_volume_range(pcm_mixer, &min, &max); /* get volume */
snd_mixer_selem_get_playback_volume(pcm_mixer, SND_MIXER_SCHN_MONO, &vol);
snd_mixer_selem_id_malloc(&mute_info);
snd_mixer_selem_id_set_name(mute_info, VOL_CH);
mas_mixer = snd_mixer_find_selem(handle, mute_info);
snd_mixer_selem_get_playback_switch(mas_mixer, SND_MIXER_SCHN_MONO, &mute); /* get mute state */
if(mute == 0)
sprintf(statnext, VOL_MUTE_STR);
else {
realvol = (vol * 100) / max;
sprintf(statnext, VOL_STR, realvol);
}
if(vol_info)
snd_mixer_selem_id_free(vol_info);
if (mute_info)
snd_mixer_selem_id_free(mute_info);
if (handle)
snd_mixer_close(handle);
strcat(status,statnext);
/* Power / Battery */
infile = fopen(BATT_NOW, "r");
fscanf(infile, "%ld\n", &now); fclose(infile);
infile = fopen(BATT_FULL, "r");
fscanf(infile, "%ld\n", &full); fclose(infile);
infile = fopen(BATT_STAT, "r");
fscanf(infile, "%s\n", state); fclose(infile);
infile = fopen(BATT_VOLT, "r");
fscanf(infile, "%ld\n", &voltage); fclose(infile);
infile = fopen(BATT_CNOW, "r");
fscanf(infile, "%ld\n", &rate); fclose(infile);
now = ((float)voltage / 1000) * ((float)now / 1000);
full = ((float)voltage / 1000) * ((float)full / 1000);
rate = ((float)voltage / 1000) * ((float)rate / 1000);
perc = (now * 100) / full;
if (strncmp(state, "Full", 8) == 0)
sprintf(statnext, BAT_FULL_STR, perc);
else if(strncmp(state, "Unknown", 8) == 0)
sprintf(statnext, BAT_UNK_STR);
else if (strncmp(state, "Charging", 8) == 0) {
seconds = 3600 * (((float)full - (float)now) / (float)rate);
hours = seconds / 3600;
seconds -= 3600 * hours;
minutes = seconds / 60;
seconds -= 60 * minutes;
sprintf(statnext, BAT_CHRG_STR, perc, hours, minutes);
} else {
seconds = 3600 * ((float)now / (float)rate);
hours = seconds / 3600;
seconds -= 3600 * hours;
minutes = seconds / 60;
seconds -= 60 * minutes;
if (perc < BATT_LOW_P || minutes < BATT_LOW_T)
sprintf(statnext, BAT_LOW_STR, perc, hours, minutes);
else
sprintf(statnext, BAT_STR, perc, hours, minutes);
}
hours = minutes = seconds = 0;
strcat(status, statnext);
/* Time */
seconds = 3600 * ((float)now / (float)rate);
hours = seconds / 3600;
seconds -= 3600 * hours;
minutes = seconds / 60;
seconds -= 60 * minutes;
if (perc < BATT_LOW_P || minutes < BATT_LOW_T)
sprintf(statnext, BAT_LOW_STR, perc, hours, minutes);
else
sprintf(statnext, BAT_STR, perc, hours, minutes);
}
hours = minutes = seconds = 0;
strcat(status, statnext);
/* Time */
#ifdef CLK
time(&current);
strftime(statnext, 38, DATE_TIME_STR, localtime(&current));
strcat(status, statnext);
time(&current);
strftime(statnext, 38, DATE_TIME_STR, localtime(&current));
strcat(status, statnext);
#endif
/* Set root name */
XStoreName(dpy, root, status);
XFlush(dpy);
sleep(INTERVAL);
}
/* Set root name */
XStoreName(dpy, root, status);
XFlush(dpy);
sleep(INTERVAL);
}
/* NEXT LINES SHOULD NEVER EXECUTE, only here to satisfy Trilby's O.C.D. ;) */
XCloseDisplay(dpy);
return 0;
XCloseDisplay(dpy);
return 0;
}
3 changes: 1 addition & 2 deletions dwmst.h
Original file line number Diff line number Diff line change
Expand Up @@ -71,8 +71,7 @@ time_t current;
#endif
#ifdef MPD
struct mpd_song *song = NULL;
const char *title = NULL;
const char *artist = NULL;
const char *title = NULL, *artist = NULL;
#endif
#ifdef AUD
int playpos;
Expand Down

0 comments on commit 6b1214b

Please sign in to comment.