summary refs log blame commit diff stats
path: root/plugins/doat/doat.c
blob: a0b5707a47d6d9e8eea7b06335b11b11054f00c6 (plain) (tree)
































                                                                      
                                                  





                                                           









                                                                         









                                                                                          






                                                










                                                                    
                                   














                                                                                                                                                                
/* This program is free software. It comes without any warranty, to
 * the extent permitted by applicable law. You can redistribute it
 * and/or modify it under the terms of the Do What The Fuck You Want
 * To Public License, Version 2, as published by Sam Hocevar. See
 * http://sam.zoy.org/wtfpl/COPYING or http://lwsitu.com/xchat/COPYING
 * for more details. */

#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "xchat-plugin.h"

static xchat_plugin *ph;

static int
parse_command( char *word[], char *word_eol[], void *userdata ) {
	char *channel = NULL, *server = NULL, *token = NULL;
/*	char *save_ptr1 = NULL;*/
	char *str1 = NULL;
	char *delimiter = NULL;

	xchat_context *ctx = NULL;

	if( word[2] != NULL && word[3] != NULL ) {
		for( str1 = word[2]; ; str1 = NULL ) {
/*			token = strtok_r( str1, ",", &save_ptr1 );*/
			token = strtok( str1, "," );
/*			printf( "token: %s\n", token );*/

			if( token == NULL ) {
				break;
			}

			channel = strdup( token );
				
			delimiter = strchr( channel, '/' );

			server = NULL;
			if( delimiter != NULL ) {
				*delimiter = '\0';

				if( strlen( delimiter + 1 ) > 0 ) {
					server = strdup( delimiter + 1 );
				}
			}

			/* /Network form */
			if( strlen( channel ) == 0 ) {
				free( channel );
				channel = NULL;
			}

/*			printf( "channel[%s] server[%s]\n", channel, server );*/

			if( (ctx = xchat_find_context( ph, server, channel ) ) != NULL ) {
				if( xchat_set_context( ph, ctx ) ) {
					xchat_command( ph, word_eol[3] );
				}
			}

			if( channel != NULL ) {
				free( channel );
			}

			if( server != NULL ) {
				free( server );
			}
		}
	}
	return XCHAT_EAT_XCHAT;
}

int
xchat_plugin_init( xchat_plugin * plugin_handle, char **plugin_name,
	char **plugin_desc, char **plugin_version, char *arg ) {

	ph = plugin_handle;
	*plugin_name = "Do At";
	*plugin_version = "1.0001";
	*plugin_desc = "Perform an arbitrary command on multiple channels";

	xchat_hook_command( ph, "doat", XCHAT_PRI_NORM, parse_command, "DOAT [channel,list,/network] [command], perform a command on multiple contexts", NULL );

	xchat_print (ph, "Do At plugin loaded\n");

	return 1;
}

int
xchat_plugin_deinit (void)
{
	xchat_print (ph, "Do At plugin unloaded\n");
	return 1;
}
s="n">count); } *count = *count + 1; pos = strstr(model, ","); if (pos != NULL) *pos = '\0'; #endif #ifdef __alpha__ while(fgets(buffer, bsize, fp) != NULL) { find_match_char(buffer, "cpu model", model); find_match_char(buffer, "system type", vendor); find_match_double(buffer, "cycle frequency [Hz]", freq); find_match_char(buffer, "L2 cache", cache); find_match_int(buffer, "cpus detected", count); } *freq = *freq / 1000000; #endif #ifdef __ia64__ while(fgets(buffer, bsize, fp) != NULL) { find_match_char(buffer, "model", model); find_match_char(buffer, "vendor", vendor); find_match_double(buffer, "cpu MHz", freq); find_match_int(buffer, "processor", count); } *count = *count + 1; #endif #ifdef __parisc__ while(fgets(buffer, bsize, fp) != NULL) { find_match_char(buffer, "cpu ", model); find_match_char(buffer, "cpu family", vendor); find_match_char(buffer, "D-cache", cache); find_match_double(buffer, "cpu MHz", freq); find_match_int(buffer, "processor", count); } *count = *count + 1; #endif #ifdef __sparc__ DIR *dir; struct dirent *entry; FILE *fp2; while(fgets(buffer, bsize, fp) != NULL) { find_match_char(buffer, "cpu ", model); find_match_char(buffer, "type ", vendor); find_match_int(buffer, "ncpus active", count); find_match_double_hex(buffer, "Cpu0ClkTck", freq); } /* Cache is tricky, only implemented for sparc64 */ if ((dir = opendir("/proc/openprom")) != NULL) while ((entry = readdir(dir)) != NULL) if (strncmp(entry->d_name,"SUNW,UltraSPARC",15) == 0) { g_snprintf(buffer,bsize,"/proc/openprom/%s/ecache-size",entry->d_name); fp2 = fopen(buffer, "r"); if (fp2 == NULL) break; fscanf(fp2,"%16s",cache); fclose(fp2); sprintf(buffer,"0x%s",cache); sprintf(cache,"%0.0f KB",strtod(buffer,NULL)/1024); } *freq = *freq / 1000000; #endif fclose(fp); return 0; } int xs_parse_uptime(int *weeks, int *days, int *hours, int *minutes, int *seconds) { char buffer[bsize]; long long uptime = 0; FILE *fp = fopen("/proc/uptime", "r"); if(fp == NULL) return 1; if(fgets(buffer, bsize, fp) != NULL) uptime = strtol(buffer, NULL, 0); *seconds = uptime%60; *minutes = (uptime/60)%60; *hours = (uptime/3600)%24; *days = (uptime/86400)%7; *weeks = uptime/604800; fclose(fp); return 0; } int xs_parse_os(char *user, char *host, char *kernel) { struct utsname osinfo; char hostn[bsize], *usern = getenv("USER"); if(uname(&osinfo)<0) return 1; if(gethostname(hostn, bsize)<0) return 1; strncpy(user, usern, bsize); strcpy(host, hostn); g_snprintf(kernel, bsize, "%s %s %s", osinfo.sysname, osinfo.release, osinfo.machine); return 0; } int xs_parse_sound(char *snd_card) { char buffer[bsize], cards[bsize] = "\0", vendor[7] = "\0", device[7] = "\0", *pos; u16 class = PCI_CLASS_MULTIMEDIA_AUDIO; FILE *fp = NULL; if((fp = fopen("/proc/asound/cards", "r"))== NULL) { if (pci_find_by_class(&class, vendor, device) == 0) { pci_find_fullname(snd_card, vendor, device); return 0; } else return 1; } while(fgets(buffer, bsize, fp) != NULL) { if(isdigit(buffer[0]) || isdigit(buffer[1])) { char card_buf[bsize]; long card_id = 0; pos = strstr(buffer, ":"); card_id = strtoll(buffer, NULL, 0); if (card_id == 0) g_snprintf(card_buf, bsize, "%s", pos+2); else g_snprintf(card_buf, bsize, "%ld: %s", card_id, pos+2); pos = strstr(card_buf, "\n"); *pos = '\0'; strcat(cards, card_buf); } } strcpy(snd_card, cards); fclose(fp); return 0; } int xs_parse_video(char *vid_card) { char vendor[7] = "\0", device[7] = "\0"; u16 class = PCI_CLASS_DISPLAY_VGA; if (pci_find_by_class(&class, vendor, device)) return 1; else pci_find_fullname(vid_card, vendor, device); return 0; } int xs_parse_ether(char *ethernet_card) { char vendor[7] = "\0", device[7] = "\0"; u16 class = PCI_CLASS_NETWORK_ETHERNET; if (pci_find_by_class(&class, vendor, device)) return 1; else pci_find_fullname(ethernet_card, vendor, device); return 0; } int xs_parse_agpbridge(char *agp_bridge) { char vendor[7] = "\0", device[7] = "\0"; u16 class = PCI_CLASS_BRIDGE_HOST; if (pci_find_by_class(&class, vendor, device)) return 1; else pci_find_fullname(agp_bridge, vendor, device); return 0; } int xs_parse_netdev(const char *device, unsigned long long *bytes_recv, unsigned long long *bytes_sent) { FILE *fp; char buffer[bsize], *pos; int i; fp=fopen("/proc/net/dev", "r"); if(fp==NULL) return 1; while(fgets(buffer, bsize, fp) != NULL) { for(i=0; isspace(buffer[i]); i++); if(strncmp(device, &buffer[i], strlen(device)) == 0) break; } fclose(fp); pos = strstr(buffer, ":"); pos++; *bytes_recv = g_ascii_strtoull (pos, &pos, 0); for(i=0;i<7;i++) g_ascii_strtoull (pos, &pos, 0); *bytes_sent = g_ascii_strtoull (pos, NULL, 0); return 0; } int xs_parse_df(const char *mount_point, char *result) { FILE *pipe; char buffer[bsize], *pos; unsigned long long total_k=0, free_k=0; int i=0; pipe = popen("df -k -l -P", "r"); if(pipe==NULL) return 1; while(fgets(buffer, bsize, pipe) != NULL) { /* Skip over pseudo-filesystems and description line */ if(isalpha(buffer[0])) continue; for(pos=buffer; !isspace(*pos); pos++); for(;isspace(*pos);pos++); if(mount_point == NULL) { total_k += g_ascii_strtoull (pos, &pos, 0); g_ascii_strtoull(pos, &pos, 0); free_k += g_ascii_strtoull (pos, &pos, 0); continue; } total_k = g_ascii_strtoull (pos, &pos, 0); g_ascii_strtoull(pos, &pos, 0); free_k = g_ascii_strtoull (pos, &pos, 0); g_ascii_strtoull (pos, &pos, 0); for(;isspace(*pos);pos++); for(;*pos!='/';pos++); for(i=0;*(buffer+i)!='\n';i++); *(buffer+i)='\0'; if(strncasecmp(mount_point, "ALL", 3)==0) { char *tmp_buf = pretty_freespace(pos, &free_k, &total_k); strcat(tmp_buf, " | "); strcat(result, tmp_buf); g_free(tmp_buf); } else if(strncmp(mount_point, pos, strlen(mount_point)) == 0) { char *tmp_buf = pretty_freespace(mount_point, &free_k, &total_k); strncpy(result, tmp_buf, bsize); g_free(tmp_buf); break; } else g_snprintf(result, bsize, "Mount point %s not found!", mount_point); } if(mount_point != NULL && strncasecmp(mount_point, "ALL", 3)==0) *(result+strlen(result)-3) = '\0'; if(mount_point == NULL) { char *tmp_buf = pretty_freespace("Total", &free_k, &total_k); strncpy(result, tmp_buf, bsize); g_free(tmp_buf); } pclose(pipe); return 0; } int xs_parse_meminfo(unsigned long long *mem_tot, unsigned long long *mem_free, int swap) { FILE *fp; char buffer[bsize]; unsigned long long freemem = 0, buffers = 0, cache = 0; *mem_tot = 0; *mem_free = 0; if((fp = fopen("/proc/meminfo", "r")) == NULL) return 1; while(fgets(buffer, bsize, fp) != NULL) { if(!swap) { find_match_ll(buffer, "MemTotal:", mem_tot); find_match_ll(buffer, "MemFree:", &freemem); find_match_ll(buffer, "Buffers:", &buffers); find_match_ll(buffer, "Cached:", &cache); } else { find_match_ll(buffer, "SwapTotal:", mem_tot); find_match_ll(buffer, "SwapFree:", mem_free); } } if (!swap) { *mem_free = freemem + buffers + cache; } fclose(fp); return 0; } int xs_parse_distro(char *name) { FILE *fp = NULL; char buffer[bsize], *pos = NULL; if((fp = fopen("/etc/portage/make.conf", "r")) != NULL || (fp = fopen("/etc/make.conf", "r")) != NULL) { char keywords[bsize]; while(fgets(buffer, bsize, fp) != NULL) find_match_char(buffer, "ACCEPT_KEYWORDS", keywords); /* cppcheck-suppress uninitvar */ if (strstr(keywords, "\"") == NULL) g_snprintf(buffer, bsize, "Gentoo Linux (stable)"); else g_snprintf(buffer, bsize, "Gentoo Linux %s", keywords); } else if((fp = fopen("/etc/redhat-release", "r")) != NULL) fgets(buffer, bsize, fp); else if((fp = fopen("/etc/mageia-release", "r")) != NULL) fgets(buffer, bsize, fp); else if((fp = fopen("/etc/slackware-version", "r")) != NULL) fgets(buffer, bsize, fp); else if((fp = fopen("/etc/mandrake-release", "r")) != NULL) fgets(buffer, bsize, fp); else if((fp = fopen("/etc/SuSE-release", "r")) != NULL) fgets(buffer, bsize, fp); else if((fp = fopen("/etc/turbolinux-release", "r")) != NULL) fgets(buffer, bsize, fp); else if((fp = fopen("/etc/arch-release", "r")) != NULL) g_snprintf(buffer, bsize, "ArchLinux"); else if((fp = fopen("/etc/lsb-release", "r")) != NULL) { char id[bsize], codename[bsize], release[bsize]; strcpy(id, "?"); strcpy(codename, "?"); strcpy(release, "?"); while(fgets(buffer, bsize, fp) != NULL) { find_match_char(buffer, "DISTRIB_ID", id); find_match_char(buffer, "DISTRIB_CODENAME", codename); find_match_char(buffer, "DISTRIB_RELEASE", release); } g_snprintf(buffer, bsize, "%s \"%s\" %s", id, codename, release); } else if((fp = fopen("/etc/debian_version", "r")) != NULL) { char release[bsize]; fgets(release, bsize, fp); g_snprintf(buffer, bsize, "Debian %s", release); } else g_snprintf(buffer, bsize, "Unknown Distro"); if(fp != NULL) fclose(fp); pos=strchr(buffer, '\n'); if(pos != NULL) *pos = '\0'; strcpy(name, buffer); return 0; }