dockapps/wmppp.app/wmppp.c

1027 lines
24 KiB
C
Raw Normal View History

/*
Best viewed with vim5, using ts=4
This code was mainly put together by looking at the
following programs:
asclock
A neat piece of equip, used to display the date
and time on the screen.
Comes with every WindowMaker installation.
Source used:
How do I create a not so solid window?
How do I open a window?
How do I use pixmaps?
2014-09-14 17:57:14 +00:00
pppstats
A program that prints the amount of data that
is transferred over a ppp-line.
Source used:
How do I read the ppp device?
------------------------------------------------------------
Authors: Martijn Pieterse (pieterse@xs4all.nl)
Antoine Nulle (warp@xs4all.nl)
This program might be Y2K resistant. We shall see. :)
This program is distributed under the GPL license.
(as were asclock and pppstats)
Known Features: (or in non M$ talk, BUGS)
* none known so far in this release
2014-09-14 17:57:14 +00:00
----
Thanks
----
2014-09-14 17:57:14 +00:00
CCC (Constructive Code Criticism):
Marcelo E. Magallon
Thanks a LOT! It takes a while to get me convinced... :)
2014-09-14 17:57:14 +00:00
Minor bugs and ideas:
Marc De Scheemaecker / David Mihm / Chris Soghoian /
Alessandro Usseglio Viretta
2014-09-14 17:57:14 +00:00
and ofcourse numerous ppl who send us bug reports.
(numerous? hmm.. todo: rephrase this :) )
Make that numerous m8ey :)
----
Changes:
---
05/09/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added:
Speed-O-Meter (after 60 seconds)
Fixed Error reporting when pressing X
Removed the ugly kb lines
Stopped clearing on-line time when pressing X
Added createXBMfromXPM
08/05/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Removed some code from get_statistics
* Check if "ifdown" is empty before execCommanding it!
07/05/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Made the program use the xpm like warp wanted it to be :)
04/05/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added pppX support. (EXPERIMENTAL!)
Removed HARD_CODED_DEV. (that stayed in long! :) )
* Changed 33600 speed indication to 33k6
Bugs if larger than 115k2 (depends on how much 1's present)
Moved the speed ind. code to DrawSpeedInd
* Added 1k lines in the stats
* Moved all the "ppp0" references into HARD_CODED_DEV.
for easy change
03/05/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Removed the number after -t.
02/05/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Removed the heyho code :)
* Changed read_rc_file to parse_rcfile. suggested bt Marcelo E. Magallon
* Added some extra checks for the -t option.
If no number was given, it would core dump
30/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added execCommand code. (taken from windowmaker soure, as advised by Marcelo E. Magallon)
* Cleaned the source up a bit
* Decided to split op wmppp and wmifs
This is gonna be wmppp
* Used the DrawStats routine from wmifs in wmppp
* I decided to add a list in this source file
with name of ppl who helped me build this code better.
* I finally removed the /proc/net/route dependency
All of the connections are taken from /proc/net/dev.
/proc/net/route is still used for checking if it is on-line.
27/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* WMIFS: stats scrolled, while red led burning
* WMPPP: changed positions of line speed
25/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Changed the checknetdevs routine, a lot!
23/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added line speed detection. via separate exec. (this has to be suid root!)
Speed has to be no more than 99999
* Added speed and forcespeed in ~/.wmppprc and /etc/wmppprc
* wmifs: added on-line detection scheme, update the bitmap coordinates
* wmppp: the x-button now allways disconnects.
22/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added /etc/wmppprc support, including "forced" mode.
* Added /etc/wmifsrc support, including "forced" mode.
21/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Moved the stats one pixel down.
* Added status led in wmifs.
* Changed RX/TX leds of wmifs to resemble wmppp
* Added the "dot" between eth.0 ppp.0 etc.
* Changed to wmifs stats to match wmppp stats (only pppX changed)
* Made sure that when specified -t 1, it stayed that way, even
when longer than 100 minutes online
* With -t 1, jump from 59:59 to 01:00 instead of 99:59 to 01:40
16/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added "all" devices in wmifs
* Added "lo" support only if aked via -i
* Added on-line time detection (using /var/run/ppp0.pid)
* Added time-out for the orange led. (one minute)
15/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Another wmppp-master.xpm.
Line speed detection being the main problem here.. :(
* Moved START_COMMAND / STOP_COMMAND to ~/.wmppprc
Return 0, everything went ok.
Return 10, the command did not work.
Please note, these functions are ran in the background.
* Removed the ability to configure
* When "v" is clicked, an orange led will appear.
if the connect script fails (return value == 10)
it will become dark again. Else the on-line detection will
pick it up, and "green" it.
14/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added "-timer"
* Added "-display" support
* Changed pixmap to a no-name pixmap.
+ Changed LED positions
+ Changed Timer position
+ Changed Stats Size
05/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added ~/.wmifsrc support.
* Put some code in DrawStats
* Check devices when pressing "device change"
03/04/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added code for wmifs
28/03/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* forgot what i did.. :)
27/03/1998 (Martijn Pieterse, pieterse@xs4all.nl)
* Added on-line detection
Scan through /proc/net/route and check everye line
for "ppp".
* A bit of code clean-up.
*/
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#include <string.h>
#include <fcntl.h>
#include <unistd.h>
#include <ctype.h>
#include <sys/wait.h>
#include <sys/stat.h>
#include <sys/param.h>
#include <sys/types.h>
#include <sys/ioctl.h>
#include <sys/socket.h>
#include <net/ppp_defs.h>
#include <net/if_ppp.h>
#include <X11/Xlib.h>
#include <X11/xpm.h>
#include <X11/extensions/shape.h>
#include "wmgeneral/wmgeneral.h"
#include "wmgeneral/misc.h"
#include "wmppp-master.xpm"
/***********/
/* Defines */
/***********/
/* Fill in and uncomment the hardcoded actions. */
/* #define START_ACTION (NULL) */
/* #define STOP_ACTION (NULL) */
/* #define SPEED_ACTION (NULL) */
/* #define IFDOWN_ACTION (NULL) */
#define STAMP_FILE_PRE "/var/run/wmppp."
/* Defines voor alle coordinate */
#define LED_PPP_RX (1)
#define LED_PPP_TX (2)
#define LED_PPP_POWER (3)
#define BUT_V (1)
#define BUT_X (2)
#define TIMER_X (9)
#define TIMER_Y (14)
#define TIMER_SRC_Y (65)
#define TIMER_DES_Y (6)
#define TIMER_SZE_X (6)
#define WMPPP_VERSION "1.3.0"
#define ORANGE_LED_TIMEOUT (60)
/**********************/
/* External Variables */
/**********************/
extern char **environ;
/********************/
/* Global Variables */
/********************/
char *ProgName;
char *active_interface = "ppp0";
int TimerDivisor=60;
int updaterate = 5;
int wmppp_mask_width = 64;
int wmppp_mask_height = 64;
char wmppp_mask_bits[64*64];
/*****************/
/* PPP variables */
/*****************/
#define PPP_UNIT 0
int ppp_h = -1;
#define PPP_STATS_HIS 54
int pixels_per_byte;
int ppp_history[PPP_STATS_HIS+1][2];
/***********************/
/* Function Prototypes */
/***********************/
void usage(void);
void printversion(void);
void DrawTime(int, int);
void DrawStats(int *, int, int, int, int);
void DrawSpeedInd(char *);
void DrawLoadInd(int);
void SetOnLED(int);
void SetErrLED(int);
void SetWaitLED(int);
void SetOffLED(int);
void ButtonUp(int);
void ButtonDown(int);
void wmppp_routine(int, char **);
int get_statistics(char *, long *, long *, long *, long *);
void get_ppp_stats(struct ppp_stats *cur);
int stillonline(char *);
/********/
/* Main */
/********/
int main(int argc, char *argv[]) {
int i;
2014-09-14 17:57:14 +00:00
/* Parse Command Line */
ProgName = argv[0];
if (strlen(ProgName) >= 5)
ProgName += (strlen(ProgName) - 5);
2014-09-14 17:57:14 +00:00
for (i=1; i<argc; i++) {
char *arg = argv[i];
if (*arg=='-') {
switch (arg[1]) {
case 'd' :
if (strcmp(arg+1, "display")) {
usage();
exit(1);
}
break;
case 'g' :
if (strcmp(arg+1, "geometry")) {
usage();
exit(1);
}
break;
case 'i' :
if (!argv[i+1]) {
usage();
exit(1);
}
/* following removed to allow experiments with
* new devices, i.e. ippp
*/
#if 0
if (strncmp(argv[i+1], "ppp", 3)) {
usage();
exit(1);
}
#endif
active_interface = argv[i+1];
i++;
break;
case 't' :
TimerDivisor = 1;
break;
case 'u' :
i++;
if (!argv[i]) {
usage();
exit(1);
}
updaterate = atoi(argv[i]);
if (updaterate < 1 || updaterate > 10) {
usage();
exit(1);
}
break;
case 'v' :
printversion();
exit(0);
break;
default:
usage();
exit(0);
break;
}
}
}
wmppp_routine(argc, argv);
return 0;
}
/*****************/
/* wmppp_routine */
/*****************/
char *start_action = NULL;
char *stop_action = NULL;
char *speed_action = NULL;
char *ifdown_action = NULL;
char *stamp_file = NULL;
void wmppp_routine(int argc, char **argv) {
rckeys wmppp_keys[] = {
{ "start", &start_action },
{ "stop", &stop_action },
{ "speed", &speed_action },
{ "ifdown", &ifdown_action },
{ "stampfile", &stamp_file },
{ NULL, NULL }
};
int j;
int but_stat;
long starttime;
long currenttime;
long waittime;
long ppptime;
int hour,minute;
long ppp_send,ppp_sl=-1;
long ppp_recv,ppp_rl=-1;
long ppp_sbytes,ppp_rbytes;
long ppp_osbytes,ppp_orbytes;
struct stat st;
pid_t stop_child = 0;
pid_t start_child = 0;
int status;
XEvent Event;
char *p;
char temp[128];
int speed_ind=60;
/* Initialize some stuff */
get_statistics(active_interface, &ppp_rl, &ppp_sl, &ppp_orbytes, &ppp_osbytes);
/* Scan through ~/.wmifsrc for the mouse button actions. */
#ifdef START_ACTION
start_action = strdup(START_ACTION);
#endif
#ifdef STOP_ACTION
stop_action = strdup(STOP_ACTION);
#endif
#ifdef SPEED_ACTION
speed_action = strdup(SPEED_ACTION);
#endif
#ifdef IFDOWN_ACTION
ifdown_action = strdup(IFDOWN_ACTION);
#endif
#ifdef STAMP_FILE_PRE
sprintf (temp, "%s%s", STAMP_FILE_PRE, active_interface);
stamp_file = strdup (temp);
#endif
2014-09-14 17:57:14 +00:00
strcpy(temp, "/etc/wmppprc");
parse_rcfile(temp, wmppp_keys);
p = getenv("HOME");
strcpy(temp, p);
strcat(temp, "/.wmppprc");
parse_rcfile(temp, wmppp_keys);
strcpy(temp, "/etc/wmppprc.fixed");
parse_rcfile(temp, wmppp_keys);
/* Open the display */
createXBMfromXPM(wmppp_mask_bits, wmppp_master_xpm, wmppp_mask_width, wmppp_mask_height);
openXwindow(argc, argv, wmppp_master_xpm, wmppp_mask_bits, wmppp_mask_width, wmppp_mask_height);
/* V Button */
AddMouseRegion(0, 35, 48, 46, 58);
/* x Button */
AddMouseRegion(1, 47, 48, 58, 58);
starttime = 0;
currenttime = time(0);
ppptime = 0;
but_stat = -1;
waittime = 0;
copyXPMArea(28, 95, 25, 11, 5, 48);
/* wmppp main loop */
while (1) {
int i;
long lasttime;
lasttime = currenttime;
currenttime = time(0);
/* Check if any child has left the playground */
i = waitpid(0, &status, WNOHANG);
if (i == stop_child && stop_child != 0) {
starttime = 0;
SetOffLED(LED_PPP_POWER);
SetOffLED(LED_PPP_RX);
SetOffLED(LED_PPP_TX);
copyXPMArea(28, 95, 25, 11, 5, 48);
RedrawWindow();
stop_child = 0;
}
if (i == start_child && start_child != 0) {
if (WIFEXITED(status)) {
if (WEXITSTATUS(status) == 10) {
starttime = 0;
copyXPMArea(28, 95, 25, 11, 5, 48);
SetOffLED(LED_PPP_POWER);
DrawTime(0, 1);
RedrawWindow();
}
start_child = 0;
}
}
/* On-line detectie! 1x per second */
2014-09-14 17:57:14 +00:00
if (currenttime != lasttime) {
i = 0;
if (stillonline(active_interface)) {
i = 1;
if (!starttime) {
starttime = currenttime;
if (stat(stamp_file, &st) == 0)
starttime = st.st_mtime;
SetOnLED(LED_PPP_POWER);
waittime = 0;
2014-09-14 17:57:14 +00:00
copyXPMArea(28, 95, 25, 11, 5, 48);
2014-09-14 17:57:14 +00:00
if (speed_action)
DrawSpeedInd(speed_action);
speed_ind = currenttime + 60;
RedrawWindow();
}
}
if (!i && starttime) {
starttime = 0;
SetErrLED(LED_PPP_POWER);
copyXPMArea(0, 95, 26, 11, 5, 48);
if (ifdown_action)
execCommand(ifdown_action);
RedrawWindow();
}
}
2014-09-14 17:57:14 +00:00
if (waittime && waittime <= currenttime) {
SetOffLED(LED_PPP_POWER);
RedrawWindow();
waittime = 0;
}
/* If we are on-line. Print the time we are */
if (starttime) {
i = currenttime - starttime;
i /= TimerDivisor;
if (TimerDivisor == 1)
if (i > 59 * 60 + 59) i /= 60;
minute = i % 60;
hour = (i / 60) % 100;
i = hour * 100 + minute;
DrawTime(i, currenttime % 2);
/* We are online, so we can check for send/recv packets */
get_statistics(active_interface, &ppp_recv, &ppp_send, &ppp_rbytes, &ppp_sbytes);
if (ppp_send != ppp_sl) SetOnLED(LED_PPP_TX);
else SetOffLED(LED_PPP_TX);
if (ppp_recv != ppp_rl) SetOnLED(LED_PPP_RX);
else SetOffLED(LED_PPP_RX);
ppp_sl = ppp_send;
ppp_rl = ppp_recv;
/* Every five seconds we check to load on the line */
if ((currenttime - ppptime >= 0) || (ppptime == 0)) {
ppptime = currenttime + updaterate;
ppp_history[PPP_STATS_HIS][0] = ppp_rbytes - ppp_orbytes;
ppp_history[PPP_STATS_HIS][1] = ppp_sbytes - ppp_osbytes;
ppp_orbytes = ppp_rbytes;
ppp_osbytes = ppp_sbytes;
DrawStats(&ppp_history[0][0], 54, 25, 5, 43);
for (j=1; j<55; j++) {
ppp_history[j-1][0] = ppp_history[j][0];
ppp_history[j-1][1] = ppp_history[j][1];
}
if (currenttime > speed_ind) {
DrawLoadInd((ppp_history[54][0] + ppp_history[54][1]) / updaterate);
}
}
RedrawWindow();
}
while (XPending(display)) {
XNextEvent(display, &Event);
switch (Event.type) {
case Expose:
RedrawWindow();
break;
case DestroyNotify:
XCloseDisplay(display);
while (start_child | stop_child) {
i = waitpid(0, &status, WNOHANG);
if (i == stop_child) stop_child = 0;
if (i == start_child) start_child = 0;
usleep(50000l);
}
exit(0);
break;
case ButtonPress:
i = CheckMouseRegion(Event.xbutton.x, Event.xbutton.y);
switch (i) {
case 0:
ButtonDown(BUT_V);
break;
case 1:
ButtonDown(BUT_X);
break;
}
but_stat = i;
RedrawWindow();
break;
case ButtonRelease:
i = CheckMouseRegion(Event.xbutton.x, Event.xbutton.y);
// Button but_stat omhoogdoen!
switch (but_stat) {
case 0:
ButtonUp(BUT_V);
break;
case 1:
ButtonUp(BUT_X);
break;
}
if (i == but_stat && but_stat >= 0) {
switch (i) {
case 0:
if (!starttime) {
copyXPMArea(28, 95, 25, 11, 5, 48);
DrawTime(0, 1);
start_child = execCommand(start_action);
SetWaitLED(LED_PPP_POWER);
waittime = ORANGE_LED_TIMEOUT + currenttime;
}
break;
case 1:
if (stop_child == 0) {
stop_child = execCommand(stop_action);
}
break;
}
}
RedrawWindow();
2014-09-14 17:57:14 +00:00
but_stat = -1;
break;
default:
break;
}
}
usleep(50000L);
}
}
/*******************************************************************************\
|* get_statistics *|
\*******************************************************************************/
int get_statistics(char *devname, long *ip, long *op, long *is, long *os) {
struct ppp_stats ppp_cur;
static int ppp_opened = 0;
2014-09-14 17:57:14 +00:00
if (!ppp_opened) {
/* Open the ppp device. */
memset(&ppp_cur, 0, sizeof(ppp_cur));
2014-09-14 17:57:14 +00:00
if ((ppp_h = socket(AF_INET, SOCK_DGRAM, 0)) < 0)
return -1;
ppp_opened = 1;
}
get_ppp_stats(&ppp_cur);
*op = ppp_cur.p.ppp_opackets;
*ip = ppp_cur.p.ppp_ipackets;
*is = ppp_cur.p.ppp_ibytes;
*os = ppp_cur.p.ppp_obytes;
return 0;
}
/*******************************************************************************\
|* stillonline *|
\*******************************************************************************/
int stillonline(char *ifs) {
FILE *fp;
int i;
i = 0;
fp = fopen("/proc/net/route", "r");
if (fp) {
char temp[128];
while (fgets(temp, 128, fp)) {
if (strstr(temp, ifs)) {
i = 1; /* Line is alive */
}
}
fclose(fp);
}
return i;
}
/*******************************************************************************\
|* DrawTime *|
\*******************************************************************************/
void DrawTime(int i, int j) {
int k = 1000;
copyXPMArea(TIMER_SZE_X*((i / k)%10)+1, TIMER_SRC_Y, 5, 7, 6+6*0, TIMER_DES_Y);
k = k /10;
copyXPMArea(TIMER_SZE_X*((i / k)%10)+1, TIMER_SRC_Y, 5, 7, 6+6*1, TIMER_DES_Y);
k = k /10;
if (j)
copyXPMArea(62, TIMER_SRC_Y, 1, 7, 6+6*2+1, TIMER_DES_Y);
else
copyXPMArea(63, TIMER_SRC_Y, 1, 7, 6+6*2+1, TIMER_DES_Y);
2014-09-14 17:57:14 +00:00
copyXPMArea(TIMER_SZE_X*((i / k)%10)+1, TIMER_SRC_Y, 5, 7, 6+6*2 + 4, TIMER_DES_Y);
k = k /10;
copyXPMArea(TIMER_SZE_X*((i / k)%10)+1, TIMER_SRC_Y, 5, 7, 6+6*3 + 4, TIMER_DES_Y);
}
/*******************************************************************************\
|* DrawStats *|
\*******************************************************************************/
void DrawStats(int *his, int num, int size, int x_left, int y_bottom) {
int pixels_per_byte;
int j,k;
int *p;
pixels_per_byte = 1*size;
p = his;
for (j=0; j<num; j++) {
if (p[0] + p[1] > pixels_per_byte)
pixels_per_byte = p[0] + p[1];
p += 2;
}
pixels_per_byte /= size;
p = his;
for (k=0; k<num; k++) {
for (j=0; j<size; j++) {
2014-09-14 17:57:14 +00:00
if (j < p[0] / pixels_per_byte)
copyXPMArea(57+2, 85, 1, 1, k+x_left, y_bottom-j);
else if (j < (p[0] + p[1]) / pixels_per_byte)
copyXPMArea(57+1, 85, 1, 1, k+x_left, y_bottom-j);
else
copyXPMArea(57+0, 85, 1, 1, k+x_left, y_bottom-j);
}
p += 2;
}
}
/*******************************************************************************\
|* DrawSpeedInd *|
\*******************************************************************************/
void PrintLittle(int i, int *k) {
switch (i) {
case -2:
*k -= 5;
/* Print the "k" letter */
copyXPMArea(11*5-5, 86, 4, 9, *k, 48);
break;
case -1:
*k -= 5;
copyXPMArea(13*5-5, 86, 4, 9, *k, 48);
break;
case 0:
*k -= 5;
copyXPMArea(45, 86, 5, 9, *k, 48);
break;
default:
*k -= 5;
copyXPMArea(i*5-5, 86, 5, 9, *k, 48);
break;
}
}
void DrawSpeedInd(char *speed_action) {
int k;
FILE *fp;
fp = popen(speed_action, "r");
2014-09-14 17:57:14 +00:00
if (fp) {
char *p;
char temp[128];
int i, linespeed;
linespeed = 0;
while (fgets(temp, 128, fp))
;
pclose(fp);
if ((p=strstr(temp, "CONNECT"))) {
linespeed = atoi(p + 8);
}
k = 30;
i = (linespeed % 1000) / 100;
linespeed /= 1000;
PrintLittle(i, &k);
k -= 5;
copyXPMArea(50, 86, 5, 9, k, 48);
2014-09-14 17:57:14 +00:00
do {
PrintLittle(linespeed % 10, &k);
linespeed /= 10;
} while (linespeed);
}
}
/*******************************************************************************\
|* DrawLoadInd *|
\*******************************************************************************/
void DrawLoadInd(int speed) {
int i, k;
k = 30;
for (i=0; i<5; i++) PrintLittle(-1, &k);
k = 30;
/* If speed is greater than 99999, display it in K */
if (speed > 99999 )
{
speed /= 1024 ;
PrintLittle(-2, &k) ;
}
do {
PrintLittle(speed % 10, &k);
speed /= 10;
} while (speed);
}
/*******************************************************************************\
|* usage *|
\*******************************************************************************/
void usage(void) {
fprintf(stderr, "\nwmppp - programming: tijno, design & ideas: warp\n\n");
fprintf(stderr, "usage:\n");
fprintf(stderr, "-display <display name>\n");
fprintf(stderr, "-geometry +XPOS+YPOS initial window position\n");
fprintf(stderr, "-h this help screen\n");
fprintf(stderr, "-i <device> (ppp0, ppp1, etc) EXPERIMENTAL! Please send bugreports!\n");
fprintf(stderr, "-t set the on-line timer to MM:SS instead of HH:MM\n");
fprintf(stderr, "-u <update rate> (1..10), default 5 seconds\n");
fprintf(stderr, "-v print the version number\n");
fprintf(stderr, "\n");
}
/*******************************************************************************\
|* printversion *|
\*******************************************************************************/
void printversion(void) {
fprintf(stderr, "%s\n", WMPPP_VERSION);
}
/*******************************************************************************\
|* get_ppp_stats *|
\*******************************************************************************/
void get_ppp_stats(struct ppp_stats *cur) {
struct ifpppstatsreq req;
memset(&req, 0, sizeof(req));
req.stats_ptr = (caddr_t) &req.stats;
strcpy(req.ifr__name, active_interface);
2014-09-14 17:57:14 +00:00
if (ioctl(ppp_h, SIOCGPPPSTATS, &req) >= 0)
*cur = req.stats;
}
#define LED_ON_X (50)
#define LED_ON_Y (80)
#define LED_OFF_Y (75)
#define LED_OFF_X (50)
#define LED_ERR_X (56)
#define LED_ERR_Y (75)
#define LED_WTE_X (56)
#define LED_WTE_Y (80)
#define LED_SZE_X (4)
#define LED_SZE_Y (4)
#define LED_PWR_X (53)
#define LED_PWR_Y (7)
#define LED_SND_X (47)
#define LED_SND_Y (7)
#define LED_RCV_X (41)
#define LED_RCV_Y (7)
#define LED_SW_X (38)
#define LED_SW_Y (14)
/*******************************************************************************\
|* SetOnLED *|
\*******************************************************************************/
void SetOnLED(int led) {
switch (led) {
case LED_PPP_POWER:
copyXPMArea(LED_ON_X, LED_ON_Y, LED_SZE_X, LED_SZE_Y, LED_PWR_X, LED_PWR_Y);
break;
case LED_PPP_RX:
copyXPMArea(LED_ON_X, LED_ON_Y, LED_SZE_X, LED_SZE_Y, LED_RCV_X, LED_RCV_Y);
break;
case LED_PPP_TX:
copyXPMArea(LED_ON_X, LED_ON_Y, LED_SZE_X, LED_SZE_Y, LED_SND_X, LED_SND_Y);
break;
}
}
/*******************************************************************************\
|* SetOffLED *|
\*******************************************************************************/
void SetOffLED(int led) {
switch (led) {
case LED_PPP_POWER:
copyXPMArea(LED_OFF_X, LED_OFF_Y, LED_SZE_X, LED_SZE_Y, LED_PWR_X, LED_PWR_Y);
break;
case LED_PPP_RX:
copyXPMArea(LED_OFF_X, LED_OFF_Y, LED_SZE_X, LED_SZE_Y, LED_RCV_X, LED_RCV_Y);
break;
case LED_PPP_TX:
copyXPMArea(LED_OFF_X, LED_OFF_Y, LED_SZE_X, LED_SZE_Y, LED_SND_X, LED_SND_Y);
break;
}
}
/*******************************************************************************\
|* SetErrLED *|
\*******************************************************************************/
void SetErrLED(int led) {
switch (led) {
case LED_PPP_POWER:
copyXPMArea(LED_ERR_X, LED_ERR_Y, LED_SZE_X, LED_SZE_Y, LED_PWR_X, LED_PWR_Y);
break;
}
}
/*******************************************************************************\
|* SetWaitLED *|
\*******************************************************************************/
void SetWaitLED(int led) {
switch (led) {
case LED_PPP_POWER:
copyXPMArea(LED_WTE_X, LED_WTE_Y, LED_SZE_X, LED_SZE_Y, LED_PWR_X, LED_PWR_Y);
break;
}
}
/*******************************************************************************\
|* ButtonUp *|
\*******************************************************************************/
void ButtonUp(int button) {
switch (button) {
case BUT_V :
copyXPMArea(24, 74, 12, 11, 35, 48);
break;
case BUT_X :
copyXPMArea(36, 74, 12, 11, 47, 48);
break;
}
}
/*******************************************************************************\
|* ButtonDown *|
\*******************************************************************************/
void ButtonDown(int button) {
switch (button) {
case BUT_V :
copyXPMArea(0, 74, 12, 11, 35, 48);
break;
case BUT_X :
copyXPMArea(12, 74, 12, 11, 47, 48);
break;
}
}