wmnd_0.1.0/0040755000175000001440000000000007175176121011410 5ustar reeduserswmnd_0.1.0/WMiFS/0040755000175000001440000000000007146456765012352 5ustar reeduserswmnd_0.1.0/WMiFS/BUGS0100644000175000001440000000515207146456765013035 0ustar reedusersKnown 'features and easter eggs' in WMiFS, (or in non M$ talk, BUGS). WMiFS-1.3b ------------------------------------------------------------- * First initial BETA release, WMiFS is now a separate package, due to the mayor rewrite, there probably will be some ;-) WMPPP/WMiFS 1.2p1 -------------------------------------------------------------- * WMPPP: The -t parameter dumps core on some systems, we're looking into this. * WMPPP: SEGV when running it as user (reported once) we can't reproduce it here, but we're looking into this. * WMPPP: "ifdown:" gets executed when pressing V button, (reported once), we also can't reproduce this one, but we're looking into this. * WMPPP: ppp0 is still hardcoded (sigh), will be fixed. * WMiFS: SEGV with the dummy interface, we're looking into this (needs to be ignored like lo). * WMiFS: Manages to get X CPU usage way to high on some systems somehow (reported myself) :) * Special thanks to Marcelo for providing some real usefull patches for WMPPP, they will be in the next update for sure! WMPPP/WMiFS 1.2 -------------------------------------------------------------- * The pixmap 'shift' in AfterStep's Wharf seems not to be our fault, but a bug in Wharf! Please notify the authors of AfterStep about this if you like to see this fixed, Wharf can't handle pixmaps that are larger than 60x60 pixels very well :( * Most code is yet again quite rewritten, but we think all previous annoyances are gone now ;-) Note: The configuration GUI is no longer supported, everything is done with user definable .rc files now, so we've scrapped it from the BUG list WMPPP/WMiFS 1.1 -------------------------------------------------------------- * most of the below bugs are dealth with and/or made obsolete with 1.1. * None 'known' bugs for 1.1 so far ;-) WMPPP 1.0 -------------------------------------------------------------- * wmppp-start has to be in /etc/ppp * wmppp-stop has to be in /etc/ppp * only ppp0 will be read * the leds won't be reliable with more than 1 ppp connection * there is an iconwin, and win variable. I have no clue why only win shouldn't be enough. Will check it out later. * The afterstep wharf seems to shift the pixmap a bit. Don't know how and why. It works perfectly with WindowManager :) * the configuration GUI doesn't return configured values from /etc/ppp/options yet, when you start the configuration GUI it presents the default parameters. wmnd_0.1.0/WMiFS/CHANGES0100644000175000001440000001065007146456765013344 0ustar reedusersVersion Description -------------------------------------------------------------- 1.3b * Released 980513 * Splitted up WMPPP and WMiFS into separate programs. * WMiFS now uses our 'newstyle' shared dockapps code, it's quite rewritten again. * WMiFS now reads /proc/dev/net instead of /proc/net/route. * Changed the RC file parsing and handling again. * Now ignores DUMMY interface too :) * Fixed the 'Zombie' bug :) * Better 'execvp' code :) * Vastly reduced X CPU usage :) 1.2p1 * Released 980502 * Updated the docs, sorry, we forgot to update some of them, due to some last minute changes in the code the docs where incorrect on some parts (systemrc). * Updated the Makefile because the systemrc files went to the wrong location (due to above changes). * Updated the WMPPP rc files, again, due to some last minute changes in the code, WMPPP's rc files where no longer working properly. 1.2 * Released 980429 * Completely revamped the WMPPP & WMiFS GUI :) * Added 'forceleft, forcemiddle and forceright' options in WMiFS for 'real' multiuser systems, when 'force*' is detected in /etc/wmifsrc the user settings in ~/.wmifsrc are overridden (usefull for sites where users may not fiddle with pppd's options :) * WMPPP: Ditto, added 'force' facility here too * WMPPP: now correctly redisplays time when killed and restarted * WMPPP: timer now starts to run when the actual connection is made * WMPPP: added BAUD CONNECT value display * WMPPP: added 'getmodemspeed', a SUID proggie to read the CONNECT value from /var/log/messages * WMPPP: dropped the config GUI and added an .wmppprc file instead > motivation to do so: this way, WMPPP is much more platform and distribution independant :) * WMPPP: enhanced the status LED, yellow means dialing, green means online, red means error * WMPPP: added -display commandline option * WMPPP: added -t commandline option, default the timer will display HH:MM, -t will display MM:SS and switch to HH:MM after 60 minutes * WMiFS: added support for all interfaces in /proc/net/, now all interfaces are supported :) * WMiFS: added -display commandline option * WMiFS: added -w commandline option, this will draw the graph in our new 'waveform' look :) * WMiFS: fixed the coredump problems that occured on some systems with or without .wmifsrc file typo's, errors, etc. in the .wmifsrc file are now also being ignored/rejected, the worst thing that can happen now is that the scripts do not execute (i.e. luser error) ;-) * WMiFS: when monitoring a ppp interface, bytes are used to draw the graph, otherwise packets * WMiFS: made the RX/TX/Status LED box identical to the one in WMPPP, the right LED is the status LED, green means interface is working, red means error (interface down, NIC broken, etc.) 1.1 - Released 980407 - Added WMiFS, the no button more stats version - All ppp/eth load graphs are now autoscaling - Autosensing of all active ppp/eth interfaces - 99 hours --> 00 hours is now okay - Now detects already running WMPPP(s) - WMIFS has 'mousebutton' script launch support - Now reads pppsocket instead of /proc/dev/net - WMIFS reads ~/.wmifsrc (optional) 1.0 - Released 980315 - Total rewrite of WMPPP-1.0pre2 - WMPPP dock.app again redesigned improved timer display readability Some code cleanups 1.0pre7 - Not released, developers release Started writing documentation Enhanced Makefile Bugfixes 1.0pre6 - Not released, developers release Redesigned WMPPP's dock.app GUI Added failsave Yes/No disconnect requester Some code cleaning Configuration GUI is ready 1.0pre5 - Not released, developers release Bugfixes Enhanced configuration GUI 1.0pre4 - Not released, developers release Bugfixes Enhanced configuration GUI 1.0pre3 - Not released, developers release - WMPPP dialup frontend is now a dock.app with online timer. 1.0pre2 - Released 980115 First initial public release Bugfixes and some cosmetic stuff 0.5b - Not released, developers release Bugfixes and cosmetic changes 0.3b - Not released, developers release First working WMPPP version wmnd_0.1.0/WMiFS/README0100644000175000001440000000473707146456765013242 0ustar reedusersWMiFS-1.3b - The public BETA release -------------------------------------------------------------- Authors...: Martijn Pieterse (pieterse@xs4all.nl) Antoine Nulle (warp@xs4all.nl) Note......: WMiFS has it's own mailbox, as our pop3 accounts are already way too crowded :) Please mail bugreports, comments, suggestions, requests and flames to: dockapps@windowmaker.mezaway.org The official WMiFS support website address: http://windowmaker.mezaway.org Credits...: Bobby Mezaway (bobby@mezaway.org) for generously hosting our website! Description -------------------------------------------------------------- WMiFS is a complete network monitoring dock.app, it's mainly designed for usage in WindowMaker's dock and gives you some nice & nifty features like: * Autosensing of *ALL* active network interfaces; * Integrated autoscaling (per interface) transfer statistics, tested upto 100Mbit; * Displays a 'normal' xload style graph or our new 'waveform' like load graph; * Realtime cycling through active interfaces by simply clicking on the eth0/ppp0 (interface) gadget; * Integrated RX/TX interface activity LEDs; * Integrated interface status LED; * Commandline options to force monitoring a particular interface, even 'lo' is supported (-h for help); * User-definable scripts for left/middle/right mouse buttons which are read from ~/.wmifsrc (optional); * Fixed rc file option, usefull for sites where users are not allowed to mess with pppd; WMiFS is developped on DEC Alpha machines running RedHat-5.0/Linux, but, WMiFS has also been intensively tested on x86 and 68K RedHat/ Linux machines ;-) Files -------------------------------------------------------------- README This file. INSTALL Installation instructions. HINTS Hints about what you can do with WMiFS. BUGS Things you don't want to know ;-) CHANGES Description of changes. TODO Things we've already planned for WMiFS. COPYING GNU General Public License Version 2. Bugs -------------------------------------------------------------- If you discover any bugs in this software, please send a bugreport to dockapps@windowmaker.mezaway.org and describe the problem as detailed as you can. Copyright -------------------------------------------------------------- WMiFS.app is copyright (c) 1997, 1998 by Martijn Pieterse and Antoine Nulle and licensed through the GNU General Public License. Read the COPYING file for the complete GNU license. wmnd_0.1.0/BUGS0100644000175000001440000000012007171015202012045 0ustar reedusersPlease read bug reports at web page http://www.wingeer.org/wmnd/bugreport.shtml wmnd_0.1.0/COPYING0100644000175000001440000004307607146456765012467 0ustar reedusers GNU GENERAL PUBLIC LICENSE Version 2, June 1991 Copyright (C) 1989, 1991 Free Software Foundation, Inc. 675 Mass Ave, Cambridge, MA 02139, USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. Preamble The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change free software--to make sure the software is free for all its users. This General Public License applies to most of the Free Software Foundation's software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is covered by the GNU Library General Public License instead.) You can apply it to your programs, too. When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things. To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it. For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights. We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the software. Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors' reputations. Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone's free use or not licensed at all. The precise terms and conditions for copying, distribution and modification follow. GNU GENERAL PUBLIC LICENSE TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION 0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you". Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does. 1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program. You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. 2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions: a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change. b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this License. c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not required to print an announcement.) These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it. Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program. In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License. 3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you also do one of the following: a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b above.) The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable. If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code. 4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. 5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Program or works based on it. 6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License. 7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Program. If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances. It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice. This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License. 8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License. 9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation. 10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally. NO WARRANTY 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. END OF TERMS AND CONDITIONS Appendix: How to Apply These Terms to Your New Programs If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms. To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. Copyright (C) 19yy This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Also add information on how to contact you by electronic and paper mail. If the program is interactive, make it output a short notice like this when it starts in an interactive mode: Gnomovision version 69, Copyright (C) 19yy name of author Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details. The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, the commands you use may be called something other than `show w' and `show c'; they could even be mouse-clicks or menu items--whatever suits your program. You should also get your employer (if you work as a programmer) or your school, if any, to sign a "copyright disclaimer" for the program, if necessary. Here is a sample; alter the names: Yoyodyne, Inc., hereby disclaims all copyright interest in the program `Gnomovision' (which makes passes at compilers) written by James Hacker. , 1 April 1989 Ty Coon, President of Vice This General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Library General Public License instead of this License. wmnd_0.1.0/CHANGELOGS0100644000175000001440000000623707171005306012742 0ustar reedusers Changes in WMND ------------------------------------------------------------------------------ 0.1.0 Changed time gap method from time() to signal driven. This change resolves the race problem when the system wakes up from hibernation mode. The values of max-meter and rate-meter are defaultly scaled by base 10 floating point division. K=1000 (10e3), M=10000000 (10e6), G=1000000000 (10e9). Using the option -b scales bitwise instead. K=1024 (2^10), M=1048576 (2^20), G=1073741824 (2^30). There is no floating point in binary mode. Displayed device name defaults to short format. Right click on the device name to toggle between full name and short name. For example, tunl1 is normally shortened to tun1, but in full name mode, tunl1 is displayed. Added a new graph display mode that is similar to wmnet, right click on the main display area to switch modes. Now there are two modes for max-meter. Default shows the maximum value from screen graphed. The second mode shows the maximum value from historical record since wmnd is started. Left click on max-meter to switch modes, right click on max-meter to toggle the display of the max-meter. Fixed the overflow bug when reading a statistics value from /proc/net/dev that's larger than INT_MAX by replacing a long integer with an unsigned long integer. 0.0.4 One more bug has been fixed. Replace line 1200 in wmnd.c while (!stat_devices[j].name[0] && j < MAX_STAT_DEVICES) { with while (j < MAX_STAT_DEVICES && !stat_devices[j].name[0]) { This bug allowed stat_devices[j] to be checked even if j is out of the range of stat_devices[], and causes a segmentation fault on some system. Thanks to Ben (rain@insane.loonybin.net) 0.0.3b The size of the device name buffer from WMiFS is 4. In other words, if there are more than 4 network devices on system, wmnd will crash. I do not know what the reasonable number is. Just change 4 to 32 if you need more. Theoretically, it will support up to 32 devices. Thanks to Paul (paul@luon.net) 0.0.3 Bug fix Changed the size of reading buffer to 256 bytes. The original size is 128 bytes, and will cause segmentation fault when the line from /proc/net/dev or /proc/net/route is longer than 128 bytes. Thanks to John Bafford (dshadow@zort.net) 0.0.2 Bug fix Corrected the AddMouseRegion for mouse-triggered user script. Thanks to Anstinus (http://www.acm.rpi.edu/~anstinus/) Added codes to skip the statistics reading of invalid device "irda?." The invalid entries in /proc/net/dev look like this: ... irda0: No statistics available. irlan0: 0 0 0 0 ... ... Thanks to Paul (paul@luon.net) 0.0.1 Initially created by Reed Lai (reed@wingeer.org) Created and modified based on WMiFS-1.3b. Displays last send and receive bytes/packets. Displays the maxima for rx and tx in current display history. Default update time gap is 1 sec. Defaults to waveform mode. Runtime switchable to waveform or traditional mode. Runtime switchable to packets or bytes mode. Runtime togglable display of maxima. wmnd_0.1.0/INSTALL0100644000175000001440000000636707171010027012436 0ustar reedusersInstallation instructions for WMND. NOTE! -------------------------------------------------------------- Installing this program requires root privileges, ask your local system/network administrator kindly if she/he wants to install this software for you ;-) You can also install the program in your very own bin directory. You'll have to figure that one out yourself, though, make install won't do it for you. Reccomendations ---------------------------------------------------------- - root access To be able to complete the installation you'll need to make changes in the system's /etc directory, as the installation copies the GLOBAL config file there. Don't worry, nothing will be overwritten ;-) This config file isn't required, but it's nice to have. Installation -------------------------------------------------------------- 1) % tar -zxvf wmnd_0.0.1.tar.gz 2) % cd wmnd 3) % make 4) % su root 5) # make install 6)* # vi ~/.wmndrc and/or /etc/wmndrc set up the paths to your pppd start, stop & restart scripts 7) % wmnd & (or wmnd -h for brief help). 6)* This is optional, WMND also works fine without them, it's entirely up to you ;-) Extra Install Info For Site Administrators! -------------------------------------------------------------- For site administrators who don't want their users messing up pppd's configuration files, WMND now supports an /etc/wmndrc.fixed file. The installation will install the normal user and global wmndrc files in $HOME and /etc, NOT the fixed one! WMND scan for 3 files at startup, in the following order: 1. /etc/wmndrc 2. $HOME/.wmndrc 3. /etc/wmndrc.fixed If no .wmndrc file is found in the users home directory, WMND will use the global one (/etc/wmndrc, if present and valid). When WMND finds a /etc/wmnd.fixed file, all settings that WMND detected in /etc/wmndrc and/or $HOME/.wmndrc will be discarted i.e. OVERRIDDEN! If you want your users to be able to dialout, but you don't want them to mess around, simply move or copy the default /etc/wmndrc to /etc/wmndrc.fixed :) Note: When NO wmndrc files are found at all, WMND will work, but quite obvious, WMND won't launch any scripts. Make sure there are valid and FULL pathnames in the wmndrc file(s) if you want WMND to launch your pppd scripts ;-) Usage ------------------------------------------------------------- WMND support the following commandline options: -h Help screen -b Scale value by bitwise, read the version section 0.1.0 of file CHANGELOGS for detail. -display X server display where wmppp should appear (default = 0:0) -i Interface name, note: 'lo' can ONLY be specified with '-i lo' ;-) (default = default interface as it appears in /proc/net/route) -w Draw the statistics graph in waveform like mode, try it! (default = normal) -v Print wmnd version number General Notes -------------------------------------------------------------- Note 1: If "make install" fails on your system, please edit the Makefile to set the paths according to your setup. "make install" defaults to /usr/local/bin, $HOME & /etc. Note 2: Please DO read the HINTS, this file contains some very usefull tips about WMND. wmnd_0.1.0/TODO0100644000175000001440000000147707172531121012076 0ustar reedusersTODO list for WMND. ------------------------------------------------------------------------ Your feedback! If you have nice suggestions, ideas, whatever, that aren't on this list, feel free to post to Wall or mail them to me :) Reduce dirty and redundant codes, and debug. WMND is a great tool! I like it! But it would be even better if there's the possibility of adding a timer like in wmppp (pretty useful the timer in the countries where the phone costs a lot of $$) Thanks to Pascal Jermini Colors changable for your favor or video enhancement. Thanks to Mark Manning A larger font version? Thanks to Mark Manning Use the libdockapp? Thanks to Paulo E. Abreu TODO are updated at web page http://www.wingeer.org/wmnd/todo.shtml wmnd_0.1.0/man/0040755000175000001440000000000007171217264012163 5ustar reeduserswmnd_0.1.0/man/wmnd.10100644000175000001440000000577007171217066013220 0ustar reedusers.\" Hey, EMACS: -*- nroff -*- .\" .\" This documentation may be distributed under the terms of .\" the GNU General Public Licence version 2. .\" .\" First parameter, NAME, should be all caps .\" Second parameter, SECTION, should be 1-8, maybe w/ subsection .\" other parameters are allowed: see man(7), man(1) .TH WMND 1 "Oct 7, 2000" .\" Please adjust this date whenever revising the manpage. .\" .\" Some roff macros, for reference: .\" .nh disable hyphenation .\" .hy enable hyphenation .\" .ad l left justify .\" .ad b justify to both left and right margins .\" .nf disable filling .\" .fi enable filling .\" .br insert line break .\" .sp insert n+1 empty lines .\" for manpage-specific macros, see man(7) .SH NAME wmnd \- WindowMaker network device monitor .SH SYNOPSIS .BR wmnd " [ " -v " | " -h " | [ " -d .IR display " ] [ " .BI -i " interface " .RB " ] [ " -w " ] [ " -b " ] ]" .SH DESCRIPTION .BR wmnd (1) is a WindowMaker dock application that shows a graph of the network traffic of the past few minutes, current activity and current and overall send and receive rates. Additionally it can launch any program in response to mouse clicks. .PP There are two modes for max-meter (the one on top of the graph). Default shows the maximum value from screen graphed. The second mode shows the maximum value from historical record since wmnd is started. Left click on max-meter to switch modes, right click on max-meter to toggle the hiding of the max-meter. .SH OPTIONS All options (short and long form) start with one dash. .TP .BI "\-i " interface ", \-interface " interface Start showing the status of network interface \fIinterface\fP. You can cycle through all available interfaces at runtime by left clicking the interface name in the upper left corner of the status display. The device name is per default shown in short form, right click on the device name to toggle between full name and short name. \fB-i lo\fP is the only way to get the status of the loopback interface. .TP .B \-w Show graph in traditional mode (default is inverse waveform mode). Right clicks cycle through all available modes. .TP .B \-b, \-binary Scale the values of the maximum and current rate on a base of 1 instead of the default 10. This means that \fB1K\fP equals 1024 in binary mode, but 1000 in decimal mode. .TP .B \-h, \-help Show summary of options. .TP .BI "\-d " display ", \-display " display Show status on X11 display \fIdisplay\fP. .TP .B \-v, \-version Show version of wmnd. .SH FILES Wmnd reads it's configuration in this order, the last read overrides all other: .nf .ta \w'/etc/wmndrc.fixed 'u /etc/wmndrc System defaults. ~/.wmndrc User configuration. /etc/wmndrc.fixed System override. .fi .PP The format of these files is: .nf left: \fI/executed/on/left/click\fP middle: \fI/executed/on/middle/click\fP right: \fI/executed/on/right/click\fP .fi .SH SEE ALSO .BR X (3x), .BR wmaker (1x). .SH AUTHOR This manual page was written by Arthur Korn . wmnd_0.1.0/wmgeneral/0040755000175000001440000000000007175176121013371 5ustar reeduserswmnd_0.1.0/wmgeneral/wmgeneral.c0100644000175000001440000002407107146456765015534 0ustar reedusers/* Best viewed with vim5, using ts=4 wmgeneral was taken from wmppp. It has a lot of routines which most of the wm* programs use. ------------------------------------------------------------ Author: Martijn Pieterse (pieterse@xs4all.nl) --- CHANGES: --- 02/05/1998 (Martijn Pieterse, pieterse@xs4all.nl) * changed the read_rc_file to parse_rcfile, as suggester by Marcelo E. Magallon * debugged the parse_rc file. 30/04/1998 (Martijn Pieterse, pieterse@xs4all.nl) * Ripped similar code from all the wm* programs, and put them in a single file. */ #include #include #include #include #include #include #include #include #include #include "wmgeneral.h" /*****************/ /* X11 Variables */ /*****************/ Window Root; int screen; int x_fd; int d_depth; XSizeHints mysizehints; XWMHints mywmhints; Pixel back_pix, fore_pix; char *Geometry = ""; Window iconwin, win; GC NormalGC; XpmIcon wmgen; Pixmap pixmask; /*****************/ /* Mouse Regions */ /*****************/ typedef struct { int enable; int top; int bottom; int left; int right; } MOUSE_REGION; #define MAX_MOUSE_REGION (8) MOUSE_REGION mouse_region[MAX_MOUSE_REGION]; /***********************/ /* Function Prototypes */ /***********************/ static void GetXPM(XpmIcon *, char **); static Pixel GetColor(char *); void RedrawWindow(void); void AddMouseRegion(int, int, int, int, int); int CheckMouseRegion(int, int); /*******************************************************************************\ |* read_rc_file *| \*******************************************************************************/ void parse_rcfile(const char *filename, rckeys *keys) { char *p; char temp[128]; char *tokens = " :\t\n"; FILE *fp; int i,key; fp = fopen(filename, "r"); if (fp) { while (fgets(temp, 128, fp)) { key = 0; while (key >= 0 && keys[key].label) { if ((p = strstr(temp, keys[key].label))) { p += strlen(keys[key].label); p += strspn(p, tokens); if ((i = strcspn(p, "#\n"))) p[i] = 0; free(*keys[key].var); *keys[key].var = strdup(p); key = -1; } else key++; } } fclose(fp); } } /*******************************************************************************\ |* GetXPM *| \*******************************************************************************/ static void GetXPM(XpmIcon *wmgen, char *pixmap_bytes[]) { XWindowAttributes attributes; int err; /* For the colormap */ XGetWindowAttributes(display, Root, &attributes); wmgen->attributes.valuemask |= (XpmReturnPixels | XpmReturnExtensions); err = XpmCreatePixmapFromData(display, Root, pixmap_bytes, &(wmgen->pixmap), &(wmgen->mask), &(wmgen->attributes)); if (err != XpmSuccess) { fprintf(stderr, "Not enough free colorcells.\n"); exit(1); } } /*******************************************************************************\ |* GetColor *| \*******************************************************************************/ static Pixel GetColor(char *name) { XColor color; XWindowAttributes attributes; XGetWindowAttributes(display, Root, &attributes); color.pixel = 0; if (!XParseColor(display, attributes.colormap, name, &color)) { fprintf(stderr, "wm.app: can't parse %s.\n", name); } else if (!XAllocColor(display, attributes.colormap, &color)) { fprintf(stderr, "wm.app: can't allocate %s.\n", name); } return color.pixel; } /*******************************************************************************\ |* flush_expose *| \*******************************************************************************/ static int flush_expose(Window w) { XEvent dummy; int i=0; while (XCheckTypedWindowEvent(display, w, Expose, &dummy)) i++; return i; } /*******************************************************************************\ |* RedrawWindow *| \*******************************************************************************/ void RedrawWindow(void) { flush_expose(iconwin); XCopyArea(display, wmgen.pixmap, iconwin, NormalGC, 0,0, wmgen.attributes.width, wmgen.attributes.height, 0,0); flush_expose(win); XCopyArea(display, wmgen.pixmap, win, NormalGC, 0,0, wmgen.attributes.width, wmgen.attributes.height, 0,0); } /*******************************************************************************\ |* RedrawWindowXY *| \*******************************************************************************/ void RedrawWindowXY(int x, int y) { flush_expose(iconwin); XCopyArea(display, wmgen.pixmap, iconwin, NormalGC, x,y, wmgen.attributes.width, wmgen.attributes.height, 0,0); flush_expose(win); XCopyArea(display, wmgen.pixmap, win, NormalGC, x,y, wmgen.attributes.width, wmgen.attributes.height, 0,0); } /*******************************************************************************\ |* AddMouseRegion *| \*******************************************************************************/ void AddMouseRegion(int index, int left, int top, int right, int bottom) { if (index < MAX_MOUSE_REGION) { mouse_region[index].enable = 1; mouse_region[index].top = top; mouse_region[index].left = left; mouse_region[index].bottom = bottom; mouse_region[index].right = right; } } /*******************************************************************************\ |* CheckMouseRegion *| \*******************************************************************************/ int CheckMouseRegion(int x, int y) { int i; int found; found = 0; for (i=0; i= mouse_region[i].left && y <= mouse_region[i].bottom && y >= mouse_region[i].top) found = 1; } if (!found) return -1; return (i-1); } /*******************************************************************************\ |* copyXPMArea *| \*******************************************************************************/ void copyXPMArea(int x, int y, int sx, int sy, int dx, int dy) { XCopyArea(display, wmgen.pixmap, wmgen.pixmap, NormalGC, x, y, sx, sy, dx, dy); } /*******************************************************************************\ |* copyXBMArea *| \*******************************************************************************/ void copyXBMArea(int x, int y, int sx, int sy, int dx, int dy) { XCopyArea(display, wmgen.mask, wmgen.pixmap, NormalGC, x, y, sx, sy, dx, dy); } /*******************************************************************************\ |* setMaskXY *| \*******************************************************************************/ void setMaskXY(int x, int y) { XShapeCombineMask(display, win, ShapeBounding, x, y, pixmask, ShapeSet); XShapeCombineMask(display, iconwin, ShapeBounding, x, y, pixmask, ShapeSet); } /*******************************************************************************\ |* openXwindow *| \*******************************************************************************/ void openXwindow(int argc, char *argv[], char *pixmap_bytes[], char *pixmask_bits, int pixmask_width, int pixmask_height) { unsigned int borderwidth = 1; XClassHint classHint; char *display_name = NULL; char *wname = argv[0]; XTextProperty name; XGCValues gcv; unsigned long gcm; int dummy=0; int i; for (i=1; argv[i]; i++) { if (!strcmp(argv[i], "-display")) display_name = argv[i+1]; } if (!(display = XOpenDisplay(display_name))) { fprintf(stderr, "%s: can't open display %s\n", wname, XDisplayName(display_name)); exit(1); } screen = DefaultScreen(display); Root = RootWindow(display, screen); d_depth = DefaultDepth(display, screen); x_fd = XConnectionNumber(display); /* Convert XPM to XImage */ GetXPM(&wmgen, pixmap_bytes); /* Create a window to hold the stuff */ mysizehints.flags = USSize | USPosition; mysizehints.x = 0; mysizehints.y = 0; back_pix = GetColor("white"); fore_pix = GetColor("black"); XWMGeometry(display, screen, Geometry, NULL, borderwidth, &mysizehints, &mysizehints.x, &mysizehints.y,&mysizehints.width,&mysizehints.height, &dummy); mysizehints.width = 64; mysizehints.height = 64; win = XCreateSimpleWindow(display, Root, mysizehints.x, mysizehints.y, mysizehints.width, mysizehints.height, borderwidth, fore_pix, back_pix); iconwin = XCreateSimpleWindow(display, win, mysizehints.x, mysizehints.y, mysizehints.width, mysizehints.height, borderwidth, fore_pix, back_pix); /* Activate hints */ XSetWMNormalHints(display, win, &mysizehints); classHint.res_name = wname; classHint.res_class = wname; XSetClassHint(display, win, &classHint); XSelectInput(display, win, ButtonPressMask | ExposureMask | ButtonReleaseMask | PointerMotionMask | StructureNotifyMask); XSelectInput(display, iconwin, ButtonPressMask | ExposureMask | ButtonReleaseMask | PointerMotionMask | StructureNotifyMask); if (XStringListToTextProperty(&wname, 1, &name) == 0) { fprintf(stderr, "%s: can't allocate window name\n", wname); exit(1); } XSetWMName(display, win, &name); /* Create GC for drawing */ gcm = GCForeground | GCBackground | GCGraphicsExposures; gcv.foreground = fore_pix; gcv.background = back_pix; gcv.graphics_exposures = 0; NormalGC = XCreateGC(display, Root, gcm, &gcv); /* ONLYSHAPE ON */ pixmask = XCreateBitmapFromData(display, win, pixmask_bits, pixmask_width, pixmask_height); XShapeCombineMask(display, win, ShapeBounding, 0, 0, pixmask, ShapeSet); XShapeCombineMask(display, iconwin, ShapeBounding, 0, 0, pixmask, ShapeSet); /* ONLYSHAPE OFF */ mywmhints.initial_state = WithdrawnState; mywmhints.icon_window = iconwin; mywmhints.icon_x = mysizehints.x; mywmhints.icon_y = mysizehints.y; mywmhints.window_group = win; mywmhints.flags = StateHint | IconWindowHint | IconPositionHint | WindowGroupHint; XSetWMHints(display, win, &mywmhints); XSetCommand(display, win, argv, argc); XMapWindow(display, win); } wmnd_0.1.0/wmgeneral/misc.c0100644000175000001440000000703307146456765014505 0ustar reedusers/* dock.c- built-in Dock module for WindowMaker * * WindowMaker window manager * * Copyright (c) 1997 Alfredo K. Kojima * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include "list.h" #include "misc.h" /* *---------------------------------------------------------------------- * parse_command-- * Divides a command line into a argv/argc pair. *---------------------------------------------------------------------- */ #define PRC_ALPHA 0 #define PRC_BLANK 1 #define PRC_ESCAPE 2 #define PRC_DQUOTE 3 #define PRC_EOS 4 #define PRC_SQUOTE 5 typedef struct { short nstate; short output; } DFA; static DFA mtable[9][6] = { {{3,1},{0,0},{4,0},{1,0},{8,0},{6,0}}, {{1,1},{1,1},{2,0},{3,0},{5,0},{1,1}}, {{1,1},{1,1},{1,1},{1,1},{5,0},{1,1}}, {{3,1},{5,0},{4,0},{1,0},{5,0},{6,0}}, {{3,1},{3,1},{3,1},{3,1},{5,0},{3,1}}, {{-1,-1},{0,0},{0,0},{0,0},{0,0},{0,0}}, /* final state */ {{6,1},{6,1},{7,0},{6,1},{5,0},{3,0}}, {{6,1},{6,1},{6,1},{6,1},{5,0},{6,1}}, {{-1,-1},{0,0},{0,0},{0,0},{0,0},{0,0}}, /* final state */ }; char* next_token(char *word, char **next) { char *ptr; char *ret, *t; int state, ctype; t = ret = malloc(strlen(word)+1); ptr = word; state = 0; *t = 0; while (1) { if (*ptr==0) ctype = PRC_EOS; else if (*ptr=='\\') ctype = PRC_ESCAPE; else if (*ptr=='"') ctype = PRC_DQUOTE; else if (*ptr=='\'') ctype = PRC_SQUOTE; else if (*ptr==' ' || *ptr=='\t') ctype = PRC_BLANK; else ctype = PRC_ALPHA; if (mtable[state][ctype].output) { *t = *ptr; t++; *t = 0; } state = mtable[state][ctype].nstate; ptr++; if (mtable[state][0].output<0) { break; } } if (*ret==0) t = NULL; else t = strdup(ret); free(ret); if (ctype==PRC_EOS) *next = NULL; else *next = ptr; return t; } extern void parse_command(char *command, char ***argv, int *argc) { LinkedList *list = NULL; char *token, *line; int count, i; line = command; do { token = next_token(line, &line); if (token) { list = list_cons(token, list); } } while (token!=NULL && line!=NULL); count = list_length(list); *argv = malloc(sizeof(char*)*count); i = count; while (list!=NULL) { (*argv)[--i] = list->head; list_remove_head(&list); } *argc = count; } extern pid_t execCommand(char *command) { pid_t pid; char **argv; int argc; parse_command(command, &argv, &argc); if (argv==NULL) { return 0; } if ((pid=fork())==0) { char **args; int i; args = malloc(sizeof(char*)*(argc+1)); if (!args) exit(10); for (i=0; i extern void parse_command(char *, char ***, int *); extern pid_t execCommand(char *); #endif /* __MISC_H */ wmnd_0.1.0/wmgeneral/list.c0100644000175000001440000000704507146456765014530 0ustar reedusers/* Generic single linked list to keep various information Copyright (C) 1993, 1994 Free Software Foundation, Inc. Author: Kresten Krab Thorup Many modifications by Alfredo K. Kojima This file is part of GNU CC. GNU CC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. GNU CC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GNU CC; see the file COPYING. If not, write to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* As a special exception, if you link this library with files compiled with GCC to produce an executable, this does not cause the resulting executable to be covered by the GNU General Public License. This exception does not however invalidate any other reasons why the executable file might be covered by the GNU General Public License. */ #include "list.h" #ifdef HAVE_SYS_TYPES_H # include #endif #include /* Return a cons cell produced from (head . tail) */ INLINE LinkedList* list_cons(void* head, LinkedList* tail) { LinkedList* cell; cell = (LinkedList*)malloc(sizeof(LinkedList)); cell->head = head; cell->tail = tail; return cell; } /* Return the length of a list, list_length(NULL) returns zero */ INLINE int list_length(LinkedList* list) { int i = 0; while(list) { i += 1; list = list->tail; } return i; } /* Return the Nth element of LIST, where N count from zero. If N larger than the list length, NULL is returned */ INLINE void* list_nth(int index, LinkedList* list) { while(index-- != 0) { if(list->tail) list = list->tail; else return 0; } return list->head; } /* Remove the element at the head by replacing it by its successor */ INLINE void list_remove_head(LinkedList** list) { if (!*list) return; if ((*list)->tail) { LinkedList* tail = (*list)->tail; /* fetch next */ *(*list) = *tail; /* copy next to list head */ free(tail); /* free next */ } else /* only one element in list */ { free(*list); (*list) = 0; } } /* Remove the element with `car' set to ELEMENT */ /* INLINE void list_remove_elem(LinkedList** list, void* elem) { while (*list) { if ((*list)->head == elem) list_remove_head(list); *list = (*list ? (*list)->tail : NULL); } }*/ INLINE LinkedList * list_remove_elem(LinkedList* list, void* elem) { LinkedList *tmp; if (list) { if (list->head == elem) { tmp = list->tail; free(list); return tmp; } list->tail = list_remove_elem(list->tail, elem); return list; } return NULL; } /* Return element that has ELEM as car */ INLINE LinkedList* list_find(LinkedList* list, void* elem) { while(list) { if (list->head == elem) return list; list = list->tail; } return NULL; } /* Free list (backwards recursive) */ INLINE void list_free(LinkedList* list) { if(list) { list_free(list->tail); free(list); } } /* Map FUNCTION over all elements in LIST */ INLINE void list_mapcar(LinkedList* list, void(*function)(void*)) { while(list) { (*function)(list->head); list = list->tail; } } wmnd_0.1.0/wmgeneral/list.h0100644000175000001440000000352407146456765014533 0ustar reedusers/* Generic single linked list to keep various information Copyright (C) 1993, 1994 Free Software Foundation, Inc. Author: Kresten Krab Thorup This file is part of GNU CC. GNU CC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. GNU CC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GNU CC; see the file COPYING. If not, write to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* As a special exception, if you link this library with files compiled with GCC to produce an executable, this does not cause the resulting executable to be covered by the GNU General Public License. This exception does not however invalidate any other reasons why the executable file might be covered by the GNU General Public License. */ #ifndef __LIST_H_ #define __LIST_H_ #if defined(__GNUC__) && !defined(__STRICT_ANSI__) # define INLINE inline #else # define INLINE #endif typedef struct LinkedList { void *head; struct LinkedList *tail; } LinkedList; INLINE LinkedList* list_cons(void* head, LinkedList* tail); INLINE int list_length(LinkedList* list); INLINE void* list_nth(int index, LinkedList* list); INLINE void list_remove_head(LinkedList** list); INLINE LinkedList *list_remove_elem(LinkedList* list, void* elem); INLINE void list_mapcar(LinkedList* list, void(*function)(void*)); INLINE LinkedList*list_find(LinkedList* list, void* elem); INLINE void list_free(LinkedList* list); #endif wmnd_0.1.0/Makefile0100644000175000001440000000051107171020304013025 0ustar reedusersPJ = 'wmnd' VERSION = '0.1.0' # Pre-release level PRE = '' all: cd $(PJ) && $(MAKE) install: cd $(PJ) && $(MAKE) install package: rm -f $(PJ)_*.tar.gz $(MAKE) clean cd .. && tar -cf - $(PJ)_$(VERSION)$(PRE) | gzip -c > $(PJ)_$(VERSION)$(PRE).tar.gz # clean: rm -f *.o *~ *.tmp \#* .\#* cd $(PJ) && $(MAKE) clean wmnd_0.1.0/wmnd/0040755000175000001440000000000007175176121012355 5ustar reeduserswmnd_0.1.0/wmnd/Makefile0100644000175000001440000000075707171501224014013 0ustar reedusersLDFLAGS = -L/usr/X11R6/lib -lXpm -lXext -lX11 CFLAGS ?= -Wall -g OBJS = wmnd.o beat.o\ ../wmgeneral/wmgeneral.o \ ../wmgeneral/misc.o \ ../wmgeneral/list.o dest ?= /usr/local wmnd: $(OBJS) all:: wmnd clean:: rm -f $(OBJS) wmnd *~ \#* .\#* install:: set -e install -d $(dest)/bin $(dest)/share/doc/example $(dest)/man/man1 install -m 755 wmnd $(dest)/bin/ install sample.wmndrc $(dest)/share/doc/example install ../man/wmnd.1 $(dest)/man/man1/ gzip -9 $(dest)/man/man1/wmnd.1 wmnd_0.1.0/wmnd/wmnd-master.xpm0100644000175000001440000004072207147172437015350 0ustar reedusers/* XPM */ static char * wmnd_master_xpm[] = { "160 100 26 1", " c None", ". c #0000FF", "+ c #202020", "@ c #000000", "# c #333133", "$ c #666366", "% c #999599", "& c #22332F", "* c #004941", "= c #283C38", "- c #C7C3C7", "; c #B59900", "> c #D8BB00", ", c #188A86", "' c #20B2AE", ") c #FFDD00", "! c #00FFF2", "~ c #B60418", "{ c #009900", "] c #FF0724", "^ c #00EB00", "/ c #00AD00", "( c #F7F3FF", "_ c #71E371", ": c #1E1E27", "< c #1F1F22", "................................................................+...............................................................................................", "................................................................+...............................................................................................", "..@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@#$..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++%..+...............................................................................................", "..@+&***&+&***&+&***&+&***&++&***&+&***&+=====++++=++++&===&+-..+...............................................................................................", "..@+*+++*+*+++*+*+++*+*+++*++*+++*+*+++*++===++++===+++=+++=+-..+...............................................................................................", "..@+*+++*+*+++*+*+++*+*+++*++*+++*+*+++*++===++++===+++=+++=+-..+...............................................................................................", "..@+&***&+&***&+&***&+&***&++&***&+&***&+++=++++=====++&===&+-..+...............................................................................................", "..@+*+++*+*+++*+*+++*+*+++*++*+++*+*+++*+++++++++++++++=+++=+-..+...............................................................................................", "..@+*+++*+*+++*+*+++*+*+++*++*+++*+*+++*+&=&=&++&=&=&++=+++=+-..+...............................................................................................", "..@+&***&+&***&+&***&+&***&++&***&+&***&+=+=+=++=+=+=++&===&+-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@**********************************************************-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++......................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++;>>>;+,''',+++;+++++,+++;>>>;+,''',+++;+++++,+++;>>>;+,''',+++;+++++,+++......................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++++)+++++!+++++>+++++'+++++)+++++!+++++>+++++'+++;+)+++,+!+++++>+++++'+++......................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++++)+++++!+++++)+++++!++++>)>+++'!'+++>)>+++'!'++;+)+++,+!+++;+)+++,+!+++...........;););.;));.", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++++>+++++'+++++)+++++!+++++>+++++'+++++)+++++!+++++>+++++'+++;+)+++,+!+++...........)+)+).)++).", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++++;+++++,+++;>>>;+,''',+++;+++++,+++;>>>;+,''',+++;+++++,+++;>>>;+,''',+......................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++......................", "..@**********************************************************-..+...............................................................................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..........................;););.;));.", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++&***&+&***&+&***&+&***&++&***&+&***&+=====++++=++++&===&+..........................)+)+).)++).", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++*+++*+*+++*+*+++*+*+++*++*+++*+*+++*++===++++===+++=+++=+.....................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++*+++*+*+++*+*+++*+*+++*++*+++*+*+++*++===++++===+++=+++=+.....................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++&***&+&***&+&***&+&***&++&***&+&***&+++=++++=====++&===&+.....................................", "..@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++*+++*+*+++*+*+++*+*+++*++*+++*+*+++*+++++++++++++++=+++=+.....................................", "..#++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-..++*+++*+*+++*+*+++*+*+++*++*+++*+*+++*+&=&=&++&=&=&++=+++=+.....................................", "..$%----------------------------------------------------------..++&***&+&***&+&***&+&***&++&***&+&***&+=+=+=++=+=+=++&===&+.....................................", "................................................................+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.....................................", "................................................................+...............................................................................................", "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.++~++.++{++.++=++.+]]+..+^^+..+==+../^^^&.~]]]&./^^^/.~]]]~.&===&...............", "++'''+++***,+,''',+,''',+,***,+,''',+,''',+,''',+,''',+,''',+++++++++++++++++++.+~]~+.+{^{+.+&=&+.](]]..^(^^..====..^+++^.]+++].^+++^.]+++].=+++=...............", "+'+++'+*+++'+*+++'+*+++'+'+++'+'+++*+'+++*+*+++'+'+++'+'+++'++++++++++++'++++++.+]]]+.+^^^+.+===+.]]]]..^^^^..====..^+++^.]+++].^+++^.]+++].=+++=...............", "+'+++'+*+++'+*+++'+*+++'+'+++'+'+++*+'+++*+*+++'+'+++'+'+++'+++++++'++++'++++++.~]]]~.{^^^{.&===&.+]]+..+^^+..+==+../^^^=.~]]]=./^^^/.~]]]~.&===&...............", "+,***,++***,+,''',++''',+,''',+,''',+,''',++***,+,''',+,''',++,'+++,+++'+++++++.....................................^+++^.]+++].^+++=.]+++=.=+++=...............", "+'+++'+*+++'+'+++*+*+++'+*+++'+*+++'+'+++'+*+++'+'+++'+*+++'+++++++++++'+++++++.~]]]~.{^^^{.&===&.~]]~../^^/..&==&..^+++^.]+++].^+++=.]+++=.=+++=...............", "+'+++'+*+++'+'+++*+*+++'+*+++'+*+++'+'+++'+*+++'+'+++'+*+++'+++++++'++'++++++++.+]]]+.+^^^+.+===+.]]]]..^^^^..====../^^^&.~]]]&./===+.~===+.&===&...............", "++'''+++***,+,''',+,''',++***,+,''',+,''',++***,+,''',+,''',+++++++,++'++++++++.+~]~+.+{^{+.+&=&+.]]]]..^^^^..====..............................................", "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.++~++.++{++.++=++.~]]~../^^/..&==&..............................................", "................................................................................................................................................................", "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", "+*'''*+,'''+++''',+,'''++,''',+,''',+,''',+,***,++***,++***,+,***,+,***++'***'+,'''++,''',+,''',+,''',+,''',+,''',+,''',+,***,+,***,+,***,+,***,+,***,+,''',++++", "+'+++'+'+++'+'+++*+'+++'+'+++*+'+++*+'+++*+'+++'+*+++'+*+++'+'+++'+'+++*+''+''+'+++'+'+++'+'+++'+'+++'+'+++'+'+++*+*+'+*+'+++'+'+++'+'+++'+'+++'+'+++'+*+++'++++", "+'+++'+'+++'+'+++*+'+++'+'+++*+'+++*+'+++*+'+++'+*+++'+*+++'+'+++'+'+++*+'+'+'+'+++'+'+++'+'+++'+'+++'+'+++'+'+++*+*+'+*+'+++'+'+++'+'+++'++'+'++'+++'+*++'*++++", "+,''',+,'''++,***++,***,+,'''++,'''++,*,',+,''',++***,++***,+,'''++,***++,***,+,***,+,***,+,''',+,'**,+,'''++,''',++*,*++,***,+,***,+,***,+++'+++,''',++*'*+++++", "+'+++'+'+++'+'+++*+'+++'+'+++*+'+++*+'+++'+'+++'+*+++'+*+++'+'+++'+'+++*+'+++'+'+++'+'+++'+'+++*+'+'+'+'+++'+*+++'+*+'+*+'+++'+'+++'+'+'+'++'+'++*+++'+*'++*++++", "+'+++'+'+++'+'+++*+'+++'+'+++*+'+++*+'+++'+'+++'+*+++'+*+++'+'+++'+'+++*+'+++'+'+++'+'+++'+'+++*+'++''+'+++'+*+++'+*+'+*+'+++'+'+++'+''+''+'+++'+*+++'+'+++*++++", "+,***,+,'''+++''',+,'''++,''',+,***++,''',+,***,++***,+,''',+,***,+,''',+,***,+,***,+,''',+,***++,''',+,***,+,''',++*,*++,''''++'''++,***,+,***,+,''',+,''',++++", "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", "................................................................................................................................................................", "+++++++++++++++++++++++++++++++.+!,_*...........................................................................................................................", "+++++++++++++++++++++++++++++++.+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..", "+++++++++++++++++++++++++++++++.++''+++**,+,'',+,'',+,**,+,'',+,'',+,'',+,'',+,'',+++++++++++++++++.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..", "+++++++++++++++++++++++++++++++.+'++'+*++'+*++'+*++'+'++'+'++*+'++*+*++'+'++'+'++'++++++++++'+++,'+.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..", "+++++++++++++++++++++++++++++++.+,**,++**,+,'',++'',+,'',+,'',+,'',++**,+,'',+,'',++,'++'++'++++:<+.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..", "+++++++++++++++++++++++++++++++.+'++'+*++'+'++*+*++'+*++'+*++'+'++'+*++'+'++'+*++'+++++++++'++++,'+.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..", "+++++++++++++++++++++++++++++++.++''+++**,+,'',+,'',++**,+,'',+,'',++**,+,'',+,'',++++++'+'+++!++++.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..", "+++++++++++++++++++++++++++++++.+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++..", "+++++++++++++++++++++++++++++++.................................................................................................................................", "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++.+++++++++++++++++++++++++...", "+*''*+,''+++'',+,''++,'',+,'',+,'',+,**,++**,++**,+,**,+,**++'**'+,''++,'',+,'',+,'',+,'',+,'',+,'',+,**,+,**,+,**,+,**,+,**,+,'',+.+;>>>;+,''',+++;+++++,+++...", "+'++'+'++'+'++*+'++'+'++*+'++*+'++*+'++'+*++'+*++'+'+'++'++*+''''+'++'+'++'+'++'+'++'+'++'+'++*+*+'*+'++'+'++'+'++'+'++'+'++'+*++'+.++>)>+++'!'++++>+++++'+++...", "+,'',+,''++,**++,**,+,''++,''++,*,,+,'',++**,++**,+,'+++,**++,**,+,**,+,**,+,'',+,'*,+,''++,'',++*,++,**,+,**,+,**,++''++,'',++*'++.++;);+++,!,+++;);+++,!,++...", "+'++'+'++'+'++*+'++'+'++*+'++*+'++'+'++'+*++'+*++'+'+'++'++*+'++'+'++'+'++'+'++*+'+''+'++'+*++'+*+'*+'++'+'++'+'++'+'++'+*++'+*'+*+.+++>+++++'++++>)>+++'!'++...", "+,**,+,''+++'',+,''++,'',+,**++,'',+,**,++**,+,'',+,**,+,'',+,**,+,**,+,'',+,**++,'''+,**,+,'',++*,++,'''++''++,**,+,**,+,'',+,'',+.+++;+++++,+++;>>>;+,''',+...", "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++'+++++++++++++++++++++++++++++++++++++++++++++++.+++++++++++++++++++++++++..."}; wmnd_0.1.0/wmnd/wmnd.c0100644000175000001440000012150007171215422013454 0ustar reedusers/************************************************************************ * * wmnd.c * * by Reed Lai * * Coding Tool: EMACS with c-mode-hook and font lock * ************************************************************************/ //#define WMND_DEBUG 4 /* unmark to show debug information */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "../wmgeneral/wmgeneral.h" #include "../wmgeneral/misc.h" #include "wmnd-master.xpm" #include "wmnd-mask.xbm" #include "beat.h" /********************* * Local Definitions * *********************/ #define WMND_VERSION "0.1.0pre3" //#define NET_DEV "/home/reed/pj/wmnd/proc_dev" //#define NET_ROUTE "/home/reed/pj/wmnd/proc_route" //#define NET_DEV "/home/reed/pj/wmnd/dev" //#define NET_ROUTE "/home/reed/pj/wmnd/route" #define NET_DEV "/proc/net/dev" #define NET_ROUTE "/proc/net/route" //#define MIN(a,b) ( (a) < (b) ? (a) : (b) ) //#define MAX(a,b) ( (a) > (b) ? (a) : (b) ) #define ABS(a) ( (a) < 0 ? -(a) : (a) ) #define PROC_NET_DEV_LINE_SIZE 256 #define SCALEMETER_H 6 /* height of scale meter */ #define SCOPE_TY 12 /* default top-Y of scope without scale meter */ #define SCOPE_BY 53 /* default bottom-Y of scope */ #define SCOPE_LX 3 /* default left-X of scope */ #define CHRD_BASE_X 33 /* digit */ #define CHRD_BASE_Y 85 #define CHR_BASE_X 1 #define CHR_BASE_Y 93 #define CHR_W 5 #define CHR_H 7 #define CHR_DOT_X 94 #define CHR_DOT_Y 85 #define CHR_DOT_W 2 #define CHR_DASH_X 84 #define CHR_DASH_Y 85 #define CHR_DASH_W 3 #define CHR_RXP_X_SCR 133 #define CHR_RXP_Y_SCR 93 #define CHR_RXN_X_SCR 139 #define CHR_RXN_Y_SCR 93 #define CHR_RXP_X_HIS 66 #define CHR_RXP_Y_HIS 46 #define CHR_RXN_X_HIS 72 #define CHR_RXN_Y_HIS 46 #define CHR_RXP_X 133 #define CHR_RXP_Y 93 #define CHR_RXN_X 139 #define CHR_RXN_Y 93 #define CHR_RX_W 6 #define CHR_RX_H 7 #define CHR_TXP_X_SCR 145 #define CHR_TXP_Y_SCR 93 #define CHR_TXN_X_SCR 151 #define CHR_TXN_Y_SCR 93 #define CHR_TXP_X_HIS 78 #define CHR_TXP_Y_HIS 46 #define CHR_TXN_X_HIS 84 #define CHR_TXN_Y_HIS 46 #define CHR_TXP_X 145 #define CHR_TXP_Y 93 #define CHR_TXN_X 151 #define CHR_TXN_Y 93 #define CHR_TX_W 6 #define CHR_TX_H 7 #define CHR_EQUAL_X 96 #define CHR_EQUAL_Y 85 #define CHR_EQUAL_W 3 #define CHR1_H 9 #define CHR1_W 6 #define BEAT_RESOLUTION 1000000 /* default beat resolution for 1 second */ #define DEFAULT_TIME_GAP 0 /* default time gap for 1 second */ #define DEFAULT_TIME_SLEEP 50000 /* default loop sleep for 0.05 seconds */ /* Fill in the hardcoded actions */ #define LEFT_ACTION (NULL) #define MIDDLE_ACTION (NULL) #define RIGHT_ACTION (NULL) /* Defines voor alle coordinate */ #define LED_NET_RX (4) #define LED_NET_TX (5) #define LED_NET_POWER (6) /* Misc */ #define SCREEN 0 #define HISTORY 1 /********************** * External Variables * **********************/ extern char **environ; /******************** * Global Variables * ********************/ //char *prog_name; char *active_interface = NULL; int waveform = 2; /* waveform default on wmnt mode */ int max_meter = 1; int max_type = SCREEN; int scale_base = 10; #define PB_MODE_BYTES 0 #define PB_MODE_PACKETS 1 int pb_mode; char *pb_mode_bytes = "bytes"; char *pb_mode_packets = "packets"; char *pb_mode_label; #define MAX_STAT_DEVICES 32 #define HIS_SIZE 58 #define HIS_ITEMS 4 /* input bytes, output bytes, input packets, output packets */ #define NAME_SIZE 16 #define SHORT_NAME_SIZE 4 typedef struct { char name[NAME_SIZE+1]; /* name in full size */ char sname[SHORT_NAME_SIZE+1]; /* name in short format */ unsigned long int his[HIS_SIZE+1][HIS_ITEMS]; unsigned long int ib_stat_last; unsigned long int ob_stat_last; unsigned long int ip_stat_last; unsigned long int op_stat_last; unsigned long int ib_max_his; /* maximum input bytes in history */ unsigned long int ob_max_his; /* maximum output bytes in history */ unsigned long int ip_max_his; /* maximum input packages in history */ unsigned long int op_max_his; /* maximum output packages in history */ } stat_dev; stat_dev stat_devices[MAX_STAT_DEVICES]; char *left_action = NULL; char *right_action = NULL; char *middle_action = NULL; /***************** * PPP variables * *****************/ #define PPP_UNIT 0 #define PPP_STATS_HIS 54 int ppp_h = -1; /*********************** * Function Prototypes * ***********************/ void usage(void); void printversion(void); void draw_stats(stat_dev *, int, int, int, int); void draw_rate(unsigned long int, unsigned long int); void SetOnLED(int); void SetErrLED(int); void SetWaitLED(int); void SetOffLED(int); void ButtonUp(int); void ButtonDown(int); void wmnd_routine(int, char **); void get_ppp_stats(struct ppp_stats *cur); int checknetdevs(void); int get_statistics(char *, unsigned long *, unsigned long *, unsigned long *, unsigned long *); int stillonline(char *); void draw_ifs(char *); /************************************************************************ * main * * main routine ************************************************************************/ int main(int argc, char *argv[]) { int i; #if WMND_DEBUG > 1 fprintf( stderr, "WMND start."); #endif /* WMND_DEBUG */ /********************* * give default mode * *********************/ pb_mode = PB_MODE_BYTES; pb_mode_label = pb_mode_bytes; /********************** * parse command line * **********************/ /* prog_name = argv[0]; if (strlen(prog_name) >= 5) { prog_name += (strlen(prog_name) - 5); } */ for (i=1; i 1 int counter = 0; #endif /* WMND_DEBUG */ /******************** * scope characters * ********************/ scope_by = SCOPE_BY; scope_lx = SCOPE_LX; if (max_meter) { scope_ty = SCOPE_TY + SCALEMETER_H; } else { scope_ty = SCOPE_TY; } scope_h = scope_by - scope_ty - 1; /**************** * clear buffer * ****************/ for (i=0; i 1 fprintf( stderr, "Gather device names..."); #endif /* WMND_DEBUG */ stat_online = checknetdevs(); #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /******************************************** * command line specified network interface * ********************************************/ stat_current = 0; if (active_interface) { for (i=0; i 1 fprintf( stderr, "Read rc files..."); #endif /* WMND_DEBUG */ strcpy(temp, "/etc/wmndrc"); parse_rcfile(temp, wmnd_keys); p = getenv("HOME"); strcpy(temp, p); strcat(temp, "/.wmndrc"); parse_rcfile(temp, wmnd_keys); strcpy(temp, "/etc/wmndrc.fixed"); parse_rcfile(temp, wmnd_keys); #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /*************** * open window * ***************/ #if WMND_DEBUG > 1 fprintf( stderr, "Open window... "); #endif /* WMND_DEBUG */ openXwindow(argc, argv, wmnd_master_xpm, wmnd_mask_bits, wmnd_mask_width, wmnd_mask_height); #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /*********************** * engage mouse button * ***********************/ #if WMND_DEBUG > 1 fprintf( stderr, "Engage mouse buttons..."); #endif /* WMND_DEBUG */ AddMouseRegion( 0, 3, 3, 27, 11 ); /* device */ AddMouseRegion( 1, 54, 3, 60, 11 ); /* up/down packet/byte mode */ AddMouseRegion( 2, 3, 22, 60, 52 ); /* main display area */ AddMouseRegion( 3, 3, 13, 60, 21 ); /* scale meter */ AddMouseRegion( 4, 3, 53, 60, 60 ); /* user script */ #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /**************** * rocking time * ****************/ beat_init(BEAT_RESOLUTION); for (i=0; i 1 fprintf( stderr, "Loop..."); #endif /* WMND_DEBUG */ while (1) { #if WMND_DEBUG > 1 fprintf( stderr, " %d", counter++ ); #endif /* WMND_DEBUG */ //curtime = time(0); waitpid(0, NULL, WNOHANG); for (i=0; i DEFAULT_TIME_GAP) { beat_roger(0); for (i=0; i= 0) { switch (but_stat) { case 0: /* device name area */ switch (Event.xbutton.button) { case 1: /* left click, change device */ /* re-read the table */ strcpy(temp, stat_devices[stat_current].name); stat_online = checknetdevs(); stat_current = 0; for (i=0; i= '0' && name[strlen(name)-1] <= '9') { copyXPMArea(61, 64, 4, 9, k, AIFS_y); k+=4; } */ c = toupper(name[i]); if (c >= 'A' && c <= 'Z') { c -= 'A'; copyXPMArea(c * 6, 74, 6, 9, k, AIFS_y); k += 6; } else { c -= '0'; copyXPMArea(c * 6, 64, 6, 9, k, AIFS_y); k += 6 ; } } } /******************************************************************* * scale *******************************************************************/ void scale( char *rx_buf, char *tx_buf, unsigned long int rx, unsigned long int tx ) { float f; char rx_sign, tx_sign; char scale; char *r, *t; int i; /****************** * who's the boss * ******************/ if (rx > tx) { rx_sign = '+'; tx_sign = '-'; } else if (rx < tx) { rx_sign = '-'; tx_sign = '+'; } else { rx_sign = '-'; tx_sign = '-'; } /****************** * make rx string * ******************/ if (scale_base == 10) { f = (float)rx; if (f > 999999999) { /* scale in giga */ f /= 1000000000; scale = 'G'; } else if (f > 999999) { /* scale in mega */ f /= 1000000; scale = 'M'; } else if (f > 999) { /* scale in kilo */ f /= 1000; scale = 'K'; } else { scale = ' '; } sprintf( rx_buf, "%c%f", rx_sign, f ); /* to string */ } else { if (rx > 1073741823) { /* scale in giga */ rx = rx >> 30; scale = 'G'; } else if (rx > 1048575) { /* scale in mega */ rx = rx >> 20; scale = 'M'; } else if (rx > 1023) { /* scale in kilo */ rx = rx >> 10; scale = 'K'; } else { scale = ' '; } sprintf(rx_buf, "%c%lu", rx_sign, rx); /* to string */ } r = rx_buf; r++; for (i = 3; i > 0 && *r != '\0'; i--) { if (*r == '+' || *r == '-' || *r == '.') { ++i; } ++r; } *r++ = scale; *r = '\0'; /****************** * make tx string * ******************/ if (scale_base == 10) { f = (float)tx; if (f > 999999999) { /* scale in giga */ f /= 1000000000; scale = 'G'; } else if (f > 999999) { /* scale in mega */ f /= 1000000; scale = 'M'; } else if (f > 999) { /* scale in kilo */ f /= 1000; scale = 'K'; } else { scale = ' '; } sprintf( tx_buf, "%c%f", tx_sign, f ); /* to string */ } else { if (tx > 1073741823) { /* scale in giga */ tx = tx >> 30; scale = 'G'; } else if (tx > 1048575) { /* scale in mega */ tx = tx >> 20; scale = 'M'; } else if (tx > 1023) { /* scale in kilo */ tx = tx >> 10; scale = 'K'; } else { scale = ' '; } sprintf(tx_buf, "%c%lu", tx_sign, tx); /* to string */ } t = tx_buf; t++; for (i = 3; i > 0 && *t != '\0'; i--) { if (*t == '+' || *t == '-' || *t == '.') { ++i; } ++t; } *t++ = scale; *t = '\0'; return; } /******************************************************************* * draw_rate *******************************************************************/ void draw_rate(unsigned long int rx, unsigned long int tx) { #define RATE_BG_X 100 #define RATE_BG_Y 85 #define RATE_BG_W 58 #define RATE_BG_H 7 #define RATE_X 3 #define RATE_Y 54 char rx_buf[16]; char tx_buf[16]; char *r, *t; unsigned int sx, sy, dx, dy, w, h; unsigned int draw; scale(rx_buf, tx_buf, rx, tx); /****************** * clear rate bar * ******************/ copyXPMArea(RATE_BG_X, RATE_BG_Y, RATE_BG_W, RATE_BG_H, RATE_X, RATE_Y); /*********** * show rx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = RATE_X; dy = RATE_Y; h = CHR_H; draw = 0; for (r = rx_buf; *r != '\0'; r++) { if (*r >= '0' && *r <= '9') { w = CHR_W; sx = CHRD_BASE_X + (w * (*r - '0')); sy = CHRD_BASE_Y; draw = 1; } else if (*r == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*r >= 'A' && * r <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*r - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*r == '+') { w = CHR_RX_W; sx = CHR_RXP_X; sy = CHR_RXP_Y; draw = 1; } else if (*r == '-') { w = CHR_RX_W; sx = CHR_RXN_X; sy = CHR_RXN_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } /*********** * show tx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = RATE_X + (RATE_BG_W / 2); dy = RATE_Y; h = CHR_H; draw = 0; for (t = tx_buf; *t != '\0'; t++) { if (*t >= '0' && *t <= '9') { w = CHR_W; sx = CHRD_BASE_X + w * (*t - '0'); sy = CHRD_BASE_Y; draw = 1; } else if (*t == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*t >= 'A' && * t <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*t - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*t == '+') { w = CHR_TX_W; sx = CHR_TXP_X; sy = CHR_TXP_Y; draw = 1; } else if (*t == '-') { w = CHR_TX_W; sx = CHR_TXN_X; sy = CHR_TXN_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } } /******************************************************************* * draw_max *******************************************************************/ void draw_max( int type, unsigned int rx, unsigned int tx ) { #define SCALE_BG_X RATE_BG_X #define SCALE_BG_Y RATE_BG_Y #define SCALE_BG_W RATE_BG_W #define SCALE_BG_H RATE_BG_H #define SCALE_X 3 #define SCALE_Y 11 char rx_buf[16]; char tx_buf[16]; char *r, *t; unsigned int sx, sy, dx, dy, w, h; unsigned int draw; unsigned int chr_rxp_x, chr_rxp_y; unsigned int chr_rxn_x, chr_rxn_y; unsigned int chr_txp_x, chr_txp_y; unsigned int chr_txn_x, chr_txn_y; scale(rx_buf, tx_buf, rx, tx); /******** * type * ********/ switch (max_type) { case SCREEN: chr_rxp_x = CHR_RXP_X_SCR; chr_rxp_y = CHR_RXP_Y_SCR; chr_rxn_x = CHR_RXN_X_SCR; chr_rxn_y = CHR_RXN_Y_SCR; chr_txp_x = CHR_TXP_X_SCR; chr_txp_y = CHR_TXP_Y_SCR; chr_txn_x = CHR_TXN_X_SCR; chr_txn_y = CHR_TXN_Y_SCR; break; case HISTORY: chr_rxp_x = CHR_RXP_X_HIS; chr_rxp_y = CHR_RXP_Y_HIS; chr_rxn_x = CHR_RXN_X_HIS; chr_rxn_y = CHR_RXN_Y_HIS; chr_txp_x = CHR_TXP_X_HIS; chr_txp_y = CHR_TXP_Y_HIS; chr_txn_x = CHR_TXN_X_HIS; chr_txn_y = CHR_TXN_Y_HIS; break; } /****************** * clear rate bar * ******************/ copyXPMArea( SCALE_BG_X, SCALE_BG_Y, SCALE_BG_W, SCALE_BG_H, SCALE_X, SCALE_Y ); /*********** * show rx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = SCALE_X; dy = SCALE_Y; h = CHR_H; draw = 0; for (r = rx_buf; *r != '\0'; r++) { if (*r >= '0' && *r <= '9') { w = CHR_W; sx = CHRD_BASE_X + (w * (*r - '0')); sy = CHRD_BASE_Y; draw = 1; } else if (*r == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*r >= 'A' && * r <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*r - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*r == '+') { w = CHR_RX_W; sx = chr_rxp_x; sy = chr_rxp_y; draw = 1; } else if (*r == '-') { w = CHR_RX_W; sx = chr_rxn_x; sy = chr_rxn_y; draw = 1; } else if (*r == '=') { w = CHR_EQUAL_W; sx = CHR_EQUAL_X; sy = CHR_EQUAL_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } /*********** * show tx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = SCALE_X + (RATE_BG_W / 2); dy = SCALE_Y; h = CHR_H; draw = 0; for (t = tx_buf; *t != '\0'; t++) { if (*t >= '0' && *t <= '9') { w = CHR_W; sx = CHRD_BASE_X + w * (*t - '0'); sy = CHRD_BASE_Y; draw = 1; } else if (*t == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*t >= 'A' && * t <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*t - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*t == '+') { w = CHR_TX_W; sx = chr_txp_x; sy = chr_txp_y; draw = 1; } else if (*t == '-') { w = CHR_TX_W; sx = chr_txn_x; sy = chr_txn_y; draw = 1; } else if (*t == '=') { w = CHR_EQUAL_W; sx = CHR_EQUAL_X; sy = CHR_EQUAL_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } } /******************************************************************* * get_statistics *******************************************************************/ int get_statistics(char *devname, unsigned long *ip, unsigned long *op, unsigned long *is, unsigned long *os) { FILE *fp; char temp[PROC_NET_DEV_LINE_SIZE]; char *p; char *tokens = " |:\n"; unsigned long int input_b, output_b; /* bytes */ unsigned long int input_p, output_p; /* packets */ int i; int found; struct ppp_stats ppp_cur, ppp_old; static int ppp_opened = 0; #if WMND_DEBUG > 2 fprintf( stderr, " get_statistics() %s", devname); #endif /* WMND_DEBUG */ if (!strncmp(devname, "ppp", 3)) { #if WMND_DEBUG > 1 fprintf(stderr, " PPP"); #endif /* WMND_DEBUG */ if (!ppp_opened) { /* Open the ppp device. */ memset(&ppp_cur, 0, sizeof(ppp_cur)); if ((ppp_h = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { return -1; } get_ppp_stats(&ppp_cur); ppp_old = ppp_cur; 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; #if WMND_DEBUG > 2 fprintf(stderr, " ip:%lu op:%lu ib:%lu ob:%lu", *ip, *op, *is, *os); #endif /* WMND_DEBUG */ return 0; } /************************************** * Read statistics from /proc/net/dev * **************************************/ #if WMND_DEBUG > 1 fprintf(stderr, " DEV"); #endif /* WMND_DEBUG */ fp = fopen(NET_DEV, "r"); fgets(temp, PROC_NET_DEV_LINE_SIZE, fp); fgets(temp, PROC_NET_DEV_LINE_SIZE, fp); i = 0; input_b = -1; output_b = -1; input_p = -1; output_p = -1; found = -1; p = strtok(temp, tokens); do { if (!(strcmp(p, "bytes"))) { /* remember position of bytes */ if (input_b == -1) input_b = i; else output_b = i; } else if (!(strcmp(p, "packets"))) { /* remember position of packets */ if (input_p == -1) input_p = i; else output_p = i; } i++; p = strtok(NULL, tokens); } while (input_b == -1 || output_b == -1 || input_p == -1 || output_p == -1); while (fgets(temp, PROC_NET_DEV_LINE_SIZE, fp)) { if (strstr(temp, devname)) { found = 0; p = strtok(temp, tokens); i = 0; do { if (i == input_b) { /* read incoming bytes */ *is = strtoul(p, (char **)NULL, 0); input_b = -1; } else if (i == output_b) { /* read outgoing bytes */ *os = strtoul(p, (char **)NULL, 0); output_b = -1; } else if (i == input_p) { /* read incoming packets */ *ip = strtoul(p, (char **)NULL, 0); input_p = -1; } else if (i == output_p) { /* read outgoing packets */ *op = strtoul(p, (char **)NULL, 0); output_p = -1; } i++; p = strtok(NULL, tokens); } while (input_b != -1 || output_b != -1 || input_p != -1 || output_p != -1); #if WMND_DEBUG > 2 fprintf(stderr, " ip:%lu op:%lu ib:%lu ob:%lu", *ip, *op, *is, *os); #endif /* WMND_DEBUG */ } } fclose(fp); return found; } /************************************************************************ * stillonline ************************************************************************/ int stillonline(char *ifs) { FILE *fp; char temp[PROC_NET_DEV_LINE_SIZE]; int i; i = 0; fp = fopen(NET_ROUTE, "r"); if (fp) { while (fgets(temp, PROC_NET_DEV_LINE_SIZE, fp)) { if (strstr(temp, ifs)) { i = 1; /* Line is alive */ } } fclose(fp); } return i; } /************************************************************************ * checknetdevs ************************************************************************/ int checknetdevs(void) { FILE *fd; char temp[PROC_NET_DEV_LINE_SIZE]; char *p; int i=0,j; int k; int devsfound=0; char *tokens = " :\t\n"; char foundbuffer[MAX_STAT_DEVICES][8]; int name_size; #if WMND_DEBUG > 2 fprintf( stderr, " checknetdevs()"); #endif /* WMND_DEBUG */ for (i=0; i 2 fprintf( stderr, " %s", p ); #endif /* WMND_DEBUG */ } } fclose(fd); } /* Nu foundbuffer naar stat_devices[].name kopieeren */ for (i=0; i SHORT_NAME_SIZE) { stat_devices[i].sname[SHORT_NAME_SIZE-1] = foundbuffer[j][name_size-1]; } for (k=0; k < (HIS_SIZE-6); k++) { stat_devices[i].his[k][0] = 0; stat_devices[i].his[k][1] = 0; stat_devices[i].his[k][2] = 0; stat_devices[i].his[k][3] = 0; } i++; } } return devsfound; } /******************************************************************* * draw_stats *******************************************************************/ void draw_stats(stat_dev *st, int num, int size, int x_scope_left, int y_scope_bottom) { #define PIX_TX_x 33 /* pixel for TX */ #define PIX_TX_y 84 #define PIX_RX_x 34 /* pixel for RX */ #define PIX_RX_y 84 #define PIX_NA_x 32 /* pixel for N.A. */ #define PIX_NA_y 84 #define PIX_TB_x 35 /* pixel for time base line */ #define PIX_TB_y 84 #define PIX_SF_x 36 /* pixel for scope frame */ #define PIX_SF_y 84 int bpp; /* bytes per pixel */ int j,k; unsigned long int *p; int p0,p1,p2,p3; int in, out; int x_left, y_bottom; unsigned long int rx_max, tx_max, rx_max_his, tx_max_his; unsigned long int max; x_left = x_scope_left; y_bottom = y_scope_bottom - 1; if (pb_mode == PB_MODE_BYTES) { /* bytes mode */ in = 0; out = 1; rx_max_his = st->ib_max_his; tx_max_his = st->ob_max_his; } else { /* packets mode */ in = 2; out = 3; rx_max_his = st->ip_max_his; tx_max_his = st->op_max_his; } /* ***************************************** * get the maximum value in screen history * *******************************************/ bpp = 1; rx_max = tx_max = 0; p = &st->his[0][0]; for (j=0; j size) { bpp = max / size; if ((max % size) > 0) { ++bpp; } } /***************************** * draw the last rx/tx bytes * *****************************/ p -= HIS_ITEMS; draw_rate( p[in], p[out] ); /* Draw the last rate */ /*********** * draw_max * ***********/ switch (max_type) { case SCREEN: draw_max(SCREEN, rx_max, tx_max); break; case HISTORY: draw_max(HISTORY, rx_max_his, tx_max_his); break; } /************** * graph work * **************/ p = &st->his[0][0]; switch (waveform) { case 0: /* traditional mode */ for (k=0; k\n" ); fprintf( stderr, " -h this help screen\n" ); fprintf( stderr, " -i default (as it appears in /proc/net/route)\n" ); fprintf( stderr, " -v print the version number\n" ); fprintf( stderr, " -w traditional mode (default is waveform mode)\n" ); fprintf( stderr, "\n" ); } /******************************************************************* * printversion *******************************************************************/ void printversion(void) { fprintf(stderr, "%s\n", WMND_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; sprintf(req.ifr__name, "ppp%d", PPP_UNIT); if (ioctl(ppp_h, SIOCGPPPSTATS, &req) < 0) { fprintf(stderr, "heyho!\n"); } *cur = req.stats; } /************* * Power LED * *************/ #define LED_ON_PW_X_B 116 /* bytes mode */ #define LED_ON_PW_Y_B 64 #define LED_ERR_PW_X_B 122 #define LED_ERR_PW_Y_B 64 #define LED_ON_PW_X_P 128 /* packets mode */ #define LED_ON_PW_Y_P 64 #define LED_ERR_PW_X_P 134 #define LED_ERR_PW_Y_P 64 #define LED_OFF_PW_X 140 #define LED_OFF_PW_Y 64 #define LED_PW_W 5 #define LED_PW_H 7 #define LED_PW_X 55 #define LED_PW_Y 4 /*************** * Receive LED * ***************/ #define LED_ON_RX_X 86 #define LED_ON_RX_Y 69 #define LED_OFF_RX_X 92 #define LED_OFF_RX_Y 69 #define LED_ERR_RX_X 80 #define LED_ERR_RX_Y 69 #define LED_RX_W 5 #define LED_RX_H 4 #define LED_RX_X 41 #define LED_RX_Y 4 /************ * Send LED * ************/ #define LED_ON_TX_X 86 #define LED_ON_TX_Y 64 #define LED_OFF_TX_X 92 #define LED_OFF_TX_Y 64 #define LED_ERR_TX_X 80 #define LED_ERR_TX_Y 64 #define LED_TX_W 5 #define LED_TX_H 4 #define LED_TX_X 48 #define LED_TX_Y 4 /******************************************************************** * SetOnLED ********************************************************************/ void SetOnLED( int led ) { switch (led) { case LED_NET_RX: copyXPMArea( LED_ON_RX_X, LED_ON_RX_Y, LED_RX_W, LED_RX_H, LED_RX_X, LED_RX_Y ); break; case LED_NET_TX: copyXPMArea( LED_ON_TX_X, LED_ON_TX_Y, LED_TX_W, LED_TX_H, LED_TX_X, LED_TX_Y ); break; case LED_NET_POWER: if (pb_mode == PB_MODE_BYTES) { copyXPMArea( LED_ON_PW_X_B, LED_ON_PW_Y_B, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } else { copyXPMArea( LED_ON_PW_X_P, LED_ON_PW_Y_P, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } break; } } /******************************************************************** * SetOffLED ********************************************************************/ void SetOffLED( int led ) { switch (led) { case LED_NET_RX: copyXPMArea( LED_OFF_RX_X, LED_OFF_RX_Y, LED_RX_W, LED_RX_H, LED_RX_X, LED_RX_Y ); break; case LED_NET_TX: copyXPMArea( LED_OFF_TX_X, LED_OFF_TX_Y, LED_TX_W, LED_TX_H, LED_TX_X, LED_TX_Y ); break; case LED_NET_POWER: copyXPMArea( LED_OFF_PW_X, LED_OFF_PW_Y, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); break; } } /******************************************************************** * SetErrLED ********************************************************************/ void SetErrLED( int led ) { switch (led) { case LED_NET_POWER: if (pb_mode == PB_MODE_BYTES) { copyXPMArea( LED_ERR_PW_X_B, LED_ERR_PW_Y_B, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } else { copyXPMArea( LED_ERR_PW_X_P, LED_ERR_PW_Y_P, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } break; } } wmnd_0.1.0/wmnd/wmnd-mask.xbm0100644000175000001440000000623607146456765015004 0ustar reedusers#define wmnd_mask_width 64 #define wmnd_mask_height 64 static char wmnd_mask_bits[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x3f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; wmnd_0.1.0/wmnd/wmnd-mask.xpm0100644000175000001440000001063307146456765015016 0ustar reedusers/* XPM */ #define wmnd_mask_width 64 #define wmnd_mask_height 64 static char * wmnd_mask_xpm[] = { "64 64 3 1", " c None", ". c #000000", "+ c #FFFFFF", "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++............................................................++", "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; wmnd_0.1.0/wmnd/sample.wmndrc0100644000175000001440000000020507146456765015061 0ustar reedusersleft: /foo/bar/your-wmnd-start-script-here middle: /foo/bar/your-wmnd-stop-script-here right: /foo/bar/your-wmnd-restart-script-here wmnd_0.1.0/wmnd/beat.c0100644000175000001440000000562007147161601013430 0ustar reedusers/********************************************************************** **********************************************************************/ /********************************************************************** * * beat.c * * v 0.0.1 2000.05.03 by Reed Lai * * time beats * * History: * * v 0.0.1 2000.05.03 by Reed Lai * replace alarm() with setitimer(), beat resolution up to 1 microsecond * * v 0.0.0 2000.04.28 by Reed Lai * create, use alarm() and SIGALRM, 1 second time beat resolution * **********************************************************************/ #define BEAT_DEBUG /* unmark to show beat debug message */ #include "beat.h" struct itimerval itv, oitv; unsigned int beat; unsigned int beat2; /********************************************************************** * beat_next * * set the next time beat * * Arguments: * t time in microseconds **********************************************************************/ int beat_next( unsigned long long int t ) { itv.it_value.tv_sec = t / 1000000; itv.it_value.tv_usec = t % 1000000; itv.it_interval.tv_sec = itv.it_value.tv_sec; itv.it_interval.tv_usec = itv.it_value.tv_usec; return( setitimer( ITIMER_REAL, &itv, 0 ) ); } /********************************************************************** * beat_close * * restore original itimerval **********************************************************************/ void beat_close() { setitimer( ITIMER_REAL, &oitv, &itv ); } /********************************************************************** * beat_roger **********************************************************************/ void beat_roger(int which) { switch (which) { case 0: beat = 0; break; case 1: beat2 = 0; break; } } /********************************************************************** * beat_handler * * routine to handle time beat **********************************************************************/ void beat_handler(int sig) { ++beat; ++beat2; } /********************************************************************** * beat_init * * routine to handle time beat * * Arguments: * usecs time in microseconds **********************************************************************/ int beat_init( unsigned long long int usecs ) { static struct sigaction act; /****************** * clear old beat * ******************/ itv.it_interval.tv_sec = 0; itv.it_interval.tv_usec = 0; itv.it_value.tv_sec = 0; itv.it_value.tv_usec = 0; setitimer( ITIMER_REAL, &itv, &oitv ); beat = 0; //usleep( 1000000 ); /************************ * set action for alarm * ************************/ act.sa_handler = beat_handler; sigemptyset( &act.sa_mask ); sigaddset( &act.sa_mask, SIGALRM ); sigaction( SIGALRM, &act, NULL ); /**************** * rocking roll * ****************/ return( beat_next( usecs ) ); } wmnd_0.1.0/wmnd/beat.h0100644000175000001440000000172507147162102013434 0ustar reedusers/********************************************************************** **********************************************************************/ /********************************************************************** * * beat.h * * v 0.0.0 2000.04.28 by Reed Lai * * header of beat.c * * History: * * v 0.0.0 2000.04.28 by Reed Lai * create, yeh * **********************************************************************/ #ifndef BEAT_H #define BEAT_H #include #include #include //#include //enum { // BEAT, /* signal for time beat */ // LAST_SIGNAL //}; //extern guint time_signals[LAST_SIGNAL]; /* signal array for time beat */ extern struct itimerval itv, oitv; extern unsigned int beat; extern unsigned int beat2; int beat_next( unsigned long long int ); void beat_roger( int ); void beat_handler( int ); int beat_init( unsigned long long int ); void beat_close(); #endif /* BEAT_H */ wmnd_0.1.0/wmnd/wmnd.c.org0100644000175000001440000011617107155073734014264 0ustar reedusers/************************************************************************ * * wmnd.c * * by Reed Lai * * Coding Tool: EMACS with c-mode-hook and font lock * ************************************************************************/ //#define WMND_DEBUG 4 /* unmark to show debug information */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "../wmgeneral/wmgeneral.h" #include "../wmgeneral/misc.h" #include "wmnd-master.xpm" #include "wmnd-mask.xbm" #include "beat.h" /********************* * Local Definitions * *********************/ #define WMND_VERSION "0.1.0" //#define NET_DEV "/home/reed/pj/wmnd/proc_dev" //#define NET_ROUTE "/home/reed/pj/wmnd/proc_route" //#define NET_DEV "/home/reed/pj/wmnd/dev" //#define NET_ROUTE "/home/reed/pj/wmnd/route" #define NET_DEV "/proc/net/dev" #define NET_ROUTE "/proc/net/route" //#define MIN(a,b) ( (a) < (b) ? (a) : (b) ) //#define MAX(a,b) ( (a) > (b) ? (a) : (b) ) #define ABS(a) ( (a) < 0 ? -(a) : (a) ) #define PROC_NET_DEV_LINE_SIZE 256 #define SCALEMETER_H 6 /* height of scale meter */ #define SCOPE_TY 12 /* default top-Y of scope without scale meter */ #define SCOPE_BY 53 /* default bottom-Y of scope */ #define SCOPE_LX 3 /* default left-X of scope */ #define CHRD_BASE_X 33 /* digit */ #define CHRD_BASE_Y 85 #define CHR_BASE_X 1 #define CHR_BASE_Y 93 #define CHR_W 5 #define CHR_H 7 #define CHR_DOT_X 94 #define CHR_DOT_Y 85 #define CHR_DOT_W 2 #define CHR_DASH_X 84 #define CHR_DASH_Y 85 #define CHR_DASH_W 3 #define CHR_RXP_X 133 #define CHR_RXP_Y 93 #define CHR_RXN_X 139 #define CHR_RXN_Y 93 #define CHR_RX_W 6 #define CHR_RX_H 7 #define CHR_TXP_X 145 #define CHR_TXP_Y 93 #define CHR_TXN_X 151 #define CHR_TXN_Y 93 #define CHR_TX_W 6 #define CHR_TX_H 7 #define CHR_EQUAL_X 96 #define CHR_EQUAL_Y 85 #define CHR_EQUAL_W 3 #define CHR1_H 9 #define CHR1_W 6 #define BEAT_RESOLUTION 1000000 /* default beat resolution for 1 second */ #define DEFAULT_TIME_GAP 0 /* default time gap for 1 second */ #define DEFAULT_TIME_SLEEP 50000 /* default loop sleep for 0.05 seconds */ /* Fill in the hardcoded actions */ #define LEFT_ACTION (NULL) #define MIDDLE_ACTION (NULL) #define RIGHT_ACTION (NULL) /* Defines voor alle coordinate */ #define LED_NET_RX (4) #define LED_NET_TX (5) #define LED_NET_POWER (6) /* Misc */ #define SCREEN 0 #define HISTORY 1 /********************** * External Variables * **********************/ extern char **environ; /******************** * Global Variables * ********************/ char *ProgName; char *active_interface = NULL; int TimerDivisor=60; int WaveForm=1; int ScaleMeter=1; #define PB_MODE_BYTES 0 #define PB_MODE_PACKETS 1 int pb_mode; char *pb_mode_bytes = "bytes"; char *pb_mode_packets = "packets"; char *pb_mode_label; #define MAX_STAT_DEVICES 32 #define HIS_SIZE 58 #define HIS_ITEMS 4 /* input bytes, output bytes, input packets, output packets */ #define NAME_SIZE 16 #define SHORT_NAME_SIZE 4 typedef struct { char name[NAME_SIZE+1]; /* name in full size */ char sname[SHORT_NAME_SIZE+1]; /* name in short format */ unsigned long int his[HIS_SIZE+1][HIS_ITEMS]; unsigned long int ib_stat_last; unsigned long int ob_stat_last; unsigned long int ip_stat_last; unsigned long int op_stat_last; unsigned long int ib_max_his; /* maximum input bytes in history */ unsigned long int ob_max_his; /* maximum output bytes in history */ unsigned long int ip_max_his; /* maximum input packages in history */ unsigned long int op_max_his; /* maximum output packages in history */ } stat_dev; stat_dev stat_devices[MAX_STAT_DEVICES]; char *left_action = NULL; char *right_action = NULL; char *middle_action = NULL; /***************** * PPP variables * *****************/ #define PPP_UNIT 0 #define PPP_STATS_HIS 54 int ppp_h = -1; /*********************** * Function Prototypes * ***********************/ void usage(void); void printversion(void); void DrawTime(int, int); void DrawStats(unsigned long int *, int, int, int, int); void DrawRate(unsigned long int, unsigned long int); void SetOnLED(int); void SetErrLED(int); void SetWaitLED(int); void SetOffLED(int); void ButtonUp(int); void ButtonDown(int); void wmnd_routine(int, char **); void get_ppp_stats(struct ppp_stats *cur); int checknetdevs(void); int get_statistics(char *, unsigned long *, unsigned long *, unsigned long *, unsigned long *); int stillonline(char *); void DrawActiveIFS(char *); /************************************************************************ * main * * main routine ************************************************************************/ int main(int argc, char *argv[]) { int i; #if WMND_DEBUG > 1 fprintf( stderr, "WMND start."); #endif /* WMND_DEBUG */ /********************* * give default mode * *********************/ pb_mode = PB_MODE_BYTES; pb_mode_label = pb_mode_bytes; /********************** * parse command line * **********************/ ProgName = argv[0]; if (strlen(ProgName) >= 5) { ProgName += (strlen(ProgName) - 5); } for (i=1; i 1 int counter = 0; #endif /* WMND_DEBUG */ /******************** * scope characters * ********************/ scope_by = SCOPE_BY; scope_lx = SCOPE_LX; if (ScaleMeter) { scope_ty = SCOPE_TY + SCALEMETER_H; } else { scope_ty = SCOPE_TY; } scope_h = scope_by - scope_ty - 1; /**************** * clear buffer * ****************/ for (i=0; i 1 fprintf( stderr, "Gather device names..."); #endif /* WMND_DEBUG */ stat_online = checknetdevs(); #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /******************************************** * command line specified network interface * ********************************************/ stat_current = 0; if (active_interface) { for (i=0; i 1 fprintf( stderr, "Read rc files..."); #endif /* WMND_DEBUG */ strcpy(temp, "/etc/wmndrc"); parse_rcfile(temp, wmnd_keys); p = getenv("HOME"); strcpy(temp, p); strcat(temp, "/.wmndrc"); parse_rcfile(temp, wmnd_keys); strcpy(temp, "/etc/wmndrc.fixed"); parse_rcfile(temp, wmnd_keys); #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /*************** * open window * ***************/ #if WMND_DEBUG > 1 fprintf( stderr, "Open window... "); #endif /* WMND_DEBUG */ openXwindow(argc, argv, wmnd_master_xpm, wmnd_mask_bits, wmnd_mask_width, wmnd_mask_height); #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /*********************** * engage mouse button * ***********************/ #if WMND_DEBUG > 1 fprintf( stderr, "Engage mouse buttons..."); #endif /* WMND_DEBUG */ AddMouseRegion( 0, 3, 3, 27, 11 ); /* device */ AddMouseRegion( 1, 54, 3, 60, 11 ); /* up/down packet/byte mode */ AddMouseRegion( 2, 3, 22, 60, 52 ); /* main display area */ AddMouseRegion( 3, 3, 13, 60, 21 ); /* scale meter */ AddMouseRegion( 4, 3, 53, 60, 60 ); /* user script */ #if WMND_DEBUG > 1 fprintf( stderr, " done.\n"); #endif /* WMND_DEBUG */ /**************** * rocking time * ****************/ beat_init(BEAT_RESOLUTION); for (i=0; i 1 fprintf( stderr, "Loop..."); #endif /* WMND_DEBUG */ while (1) { #if WMND_DEBUG > 1 fprintf( stderr, " %d", counter++ ); #endif /* WMND_DEBUG */ //curtime = time(0); waitpid(0, NULL, WNOHANG); for (i=0; i DEFAULT_TIME_GAP) { beat_roger(0); for (i=0; i= 0) { switch (but_stat) { case 0: /* device name area */ switch (Event.xbutton.button) { case 1: /* left click, change device */ /* re-read the table */ strcpy(temp, stat_devices[stat_current].name); stat_online = checknetdevs(); stat_current = 0; for (i=0; i= '0' && name[strlen(name)-1] <= '9') { copyXPMArea(61, 64, 4, 9, k, AIFS_y); k+=4; } */ c = toupper(name[i]); if (c >= 'A' && c <= 'Z') { c -= 'A'; copyXPMArea(c * 6, 74, 6, 9, k, AIFS_y); k += 6; } else { c -= '0'; copyXPMArea(c * 6, 64, 6, 9, k, AIFS_y); k += 6 ; } } } /******************************************************************* * DrawRate *******************************************************************/ void DrawRate( unsigned long int rx, unsigned long int tx ) { #define RATE_BG_X 100 #define RATE_BG_Y 85 #define RATE_BG_W 58 #define RATE_BG_H 7 #define RATE_X 3 #define RATE_Y 54 float f; char rx_buf[16]; char rx_scale = ' '; char rx_sign; char tx_buf[16]; char tx_scale = ' '; char tx_sign; char *r, *t; unsigned int sx, sy, dx, dy, w, h; unsigned int i, draw; /******************* * who is the boss * *******************/ if (rx > tx) { rx_sign = '+'; tx_sign = '-'; } else if (rx < tx) { rx_sign = '-'; tx_sign = '+'; } else { rx_sign = '-'; tx_sign = '-'; } /****************** * make rx string * ******************/ f = (float)rx; if (f > 999999999) { /* scale in giga */ f /= 1000000000; rx_scale = 'G'; } else if (f > 999999) { /* scale in mega */ f /= 1000000; rx_scale = 'M'; } else if (f > 999) { /* scale in kilo */ f /= 1000; rx_scale = 'K'; } sprintf( rx_buf, "%c%f", rx_sign, f ); /* to string */ r = rx_buf; r++; for (i = 3; i > 0 && *r != '\0'; i--) { if (*r == '+' || *r == '-' || *r == '.') { ++i; } ++r; } *r++ = rx_scale; *r = '\0'; /****************** * make tx string * ******************/ f = (float)tx; if (f > 999999999) { /* scale in giga */ f /= 1000000000; tx_scale = 'G'; } else if (f > 999999) { /* scale in mega */ f /= 1000000; tx_scale = 'M'; } else if (f > 999) { /* scale in kilo */ f /= 1000; tx_scale = 'K'; } sprintf( tx_buf, "%c%f", tx_sign, f ); /* to string */ t = tx_buf; t++; for (i = 3; i > 0 && *t != '\0'; i--) { if (*t == '+' || *t == '-' || *t == '.') { ++i; } ++t; } *t++ = tx_scale; *t = '\0'; /****************** * clear rate bar * ******************/ copyXPMArea( RATE_BG_X, RATE_BG_Y, RATE_BG_W, RATE_BG_H, RATE_X, RATE_Y ); /*********** * show rx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = RATE_X; dy = RATE_Y; h = CHR_H; draw = 0; for (r = rx_buf; *r != '\0'; r++) { if (*r >= '0' && *r <= '9') { w = CHR_W; sx = CHRD_BASE_X + (w * (*r - '0')); sy = CHRD_BASE_Y; draw = 1; } else if (*r == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*r >= 'A' && * r <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*r - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*r == '+') { w = CHR_RX_W; sx = CHR_RXP_X; sy = CHR_RXP_Y; draw = 1; } else if (*r == '-') { w = CHR_RX_W; sx = CHR_RXN_X; sy = CHR_RXN_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } /*********** * show tx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = RATE_X + (RATE_BG_W / 2); dy = RATE_Y; h = CHR_H; draw = 0; for (t = tx_buf; *t != '\0'; t++) { if (*t >= '0' && *t <= '9') { w = CHR_W; sx = CHRD_BASE_X + w * (*t - '0'); sy = CHRD_BASE_Y; draw = 1; } else if (*t == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*t >= 'A' && * t <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*t - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*t == '+') { w = CHR_TX_W; sx = CHR_TXP_X; sy = CHR_TXP_Y; draw = 1; } else if (*t == '-') { w = CHR_TX_W; sx = CHR_TXN_X; sy = CHR_TXN_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } } /******************************************************************* * DrawMax *******************************************************************/ void DrawMax( int type, unsigned int rx, unsigned int tx ) { #define SCALE_BG_X RATE_BG_X #define SCALE_BG_Y RATE_BG_Y #define SCALE_BG_W RATE_BG_W #define SCALE_BG_H RATE_BG_H #define SCALE_X 3 #define SCALE_Y 11 float f; char rx_buf[16]; char rx_scale = ' '; char rx_sign; char tx_buf[16]; char tx_scale = ' '; char tx_sign; char *r, *t; unsigned int sx, sy, dx, dy, w, h; unsigned int i, draw; /******** * sign * ********/ if (rx > tx) { rx_sign = '+'; tx_sign = '-'; } else if (rx < tx) { rx_sign = '-'; tx_sign = '+'; } else { rx_sign = '-'; tx_sign = '-'; } /****************** * make rx string * ******************/ f = (float)rx; if (f > 999999999) { /* scale in giga */ f /= 1000000000; rx_scale = 'G'; } else if (f > 999999) { /* scale in mega */ f /= 1000000; rx_scale = 'M'; } else if (f > 999) { /* scale in kilo */ f /= 1000; rx_scale = 'K'; } sprintf( rx_buf, "%c%f", rx_sign, f ); /* to string */ r = rx_buf; r++; for (i = 3; i > 0 && *r != '\0'; i--) { if (*r == '+' || *r == '-' || *r == '.') { ++i; } ++r; } *r++ = rx_scale; *r = '\0'; /****************** * make tx string * ******************/ f = (float)tx; if (f > 999999999) { /* scale in giga */ f /= 1000000000; tx_scale = 'G'; } else if (f > 999999) { /* scale in mega */ f /= 1000000; tx_scale = 'M'; } else if (f > 999) { /* scale in kilo */ f /= 1000; tx_scale = 'K'; } sprintf( tx_buf, "%c%f", tx_sign, f ); /* to string */ t = tx_buf; t++; for (i = 3; i > 0 && *t != '\0'; i--) { if (*t == '+' || *t == '-' || *t == '.') { ++i; } ++t; } *t++ = tx_scale; *t = '\0'; /****************** * clear rate bar * ******************/ copyXPMArea( SCALE_BG_X, SCALE_BG_Y, SCALE_BG_W, SCALE_BG_H, SCALE_X, SCALE_Y ); /*********** * show rx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = SCALE_X; dy = SCALE_Y; h = CHR_H; draw = 0; for (r = rx_buf; *r != '\0'; r++) { if (*r >= '0' && *r <= '9') { w = CHR_W; sx = CHRD_BASE_X + (w * (*r - '0')); sy = CHRD_BASE_Y; draw = 1; } else if (*r == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*r >= 'A' && * r <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*r - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*r == '+') { w = CHR_RX_W; sx = CHR_RXP_X; sy = CHR_RXP_Y; draw = 1; } else if (*r == '-') { w = CHR_RX_W; sx = CHR_RXN_X; sy = CHR_RXN_Y; draw = 1; } else if (*r == '=') { w = CHR_EQUAL_W; sx = CHR_EQUAL_X; sy = CHR_EQUAL_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } /*********** * show tx * ***********/ w = CHR_DASH_W; sx = CHR_DASH_X; sy = CHR_DASH_Y; dx = SCALE_X + (RATE_BG_W / 2); dy = SCALE_Y; h = CHR_H; draw = 0; for (t = tx_buf; *t != '\0'; t++) { if (*t >= '0' && *t <= '9') { w = CHR_W; sx = CHRD_BASE_X + w * (*t - '0'); sy = CHRD_BASE_Y; draw = 1; } else if (*t == '.') { w = CHR_DOT_W; sx = CHR_DOT_X; sy = CHR_DOT_Y; draw = 1; } else if (*t >= 'A' && * t <= 'Z') { w = CHR_W; sx = CHR_BASE_X + (w * (*t - 'A')); sy = CHR_BASE_Y; draw = 1; } else if (*t == '+') { w = CHR_TX_W; sx = CHR_TXP_X; sy = CHR_TXP_Y; draw = 1; } else if (*t == '-') { w = CHR_TX_W; sx = CHR_TXN_X; sy = CHR_TXN_Y; draw = 1; } else if (*t == '=') { w = CHR_EQUAL_W; sx = CHR_EQUAL_X; sy = CHR_EQUAL_Y; draw = 1; } if (draw) { copyXPMArea( sx, sy, w, h, dx, dy ); draw = 0; } dx += w; } } /******************************************************************* * get_statistics *******************************************************************/ int get_statistics(char *devname, unsigned long *ip, unsigned long *op, unsigned long *is, unsigned long *os) { FILE *fp; char temp[PROC_NET_DEV_LINE_SIZE]; char *p; char *tokens = " |:\n"; unsigned long int input_b, output_b; /* bytes */ unsigned long int input_p, output_p; /* packets */ int i; int found; struct ppp_stats ppp_cur, ppp_old; static int ppp_opened = 0; #if WMND_DEBUG > 2 fprintf( stderr, " get_statistics() %s", devname); #endif /* WMND_DEBUG */ if (!strncmp(devname, "ppp", 3)) { #if WMND_DEBUG > 1 fprintf(stderr, " PPP"); #endif /* WMND_DEBUG */ if (!ppp_opened) { /* Open the ppp device. */ memset(&ppp_cur, 0, sizeof(ppp_cur)); if ((ppp_h = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { return -1; } get_ppp_stats(&ppp_cur); ppp_old = ppp_cur; 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; #if WMND_DEBUG > 2 fprintf(stderr, " ip:%lu op:%lu ib:%lu ob:%lu", *ip, *op, *is, *os); #endif /* WMND_DEBUG */ return 0; } /************************************** * Read statistics from /proc/net/dev * **************************************/ #if WMND_DEBUG > 1 fprintf(stderr, " DEV"); #endif /* WMND_DEBUG */ fp = fopen(NET_DEV, "r"); fgets(temp, PROC_NET_DEV_LINE_SIZE, fp); fgets(temp, PROC_NET_DEV_LINE_SIZE, fp); i = 0; input_b = -1; output_b = -1; input_p = -1; output_p = -1; found = -1; p = strtok(temp, tokens); do { if (!(strcmp(p, "bytes"))) { /* remember position of bytes */ if (input_b == -1) input_b = i; else output_b = i; } else if (!(strcmp(p, "packets"))) { /* remember position of packets */ if (input_p == -1) input_p = i; else output_p = i; } i++; p = strtok(NULL, tokens); } while (input_b == -1 || output_b == -1 || input_p == -1 || output_p == -1); while (fgets(temp, PROC_NET_DEV_LINE_SIZE, fp)) { if (strstr(temp, devname)) { found = 0; p = strtok(temp, tokens); i = 0; do { if (i == input_b) { /* read incoming bytes */ *is = strtoul(p, (char **)NULL, 0); input_b = -1; } else if (i == output_b) { /* read outgoing bytes */ *os = strtoul(p, (char **)NULL, 0); output_b = -1; } else if (i == input_p) { /* read incoming packets */ *ip = strtoul(p, (char **)NULL, 0); input_p = -1; } else if (i == output_p) { /* read outgoing packets */ *op = strtoul(p, (char **)NULL, 0); output_p = -1; } i++; p = strtok(NULL, tokens); } while (input_b != -1 || output_b != -1 || input_p != -1 || output_p != -1); #if WMND_DEBUG > 2 fprintf(stderr, " ip:%lu op:%lu ib:%lu ob:%lu", *ip, *op, *is, *os); #endif /* WMND_DEBUG */ } } fclose(fp); return found; } /************************************************************************ * stillonline ************************************************************************/ int stillonline(char *ifs) { FILE *fp; char temp[PROC_NET_DEV_LINE_SIZE]; int i; i = 0; fp = fopen(NET_ROUTE, "r"); if (fp) { while (fgets(temp, PROC_NET_DEV_LINE_SIZE, fp)) { if (strstr(temp, ifs)) { i = 1; /* Line is alive */ } } fclose(fp); } return i; } /************************************************************************ * checknetdevs ************************************************************************/ int checknetdevs(void) { FILE *fd; char temp[PROC_NET_DEV_LINE_SIZE]; char *p; int i=0,j; int k; int devsfound=0; char *tokens = " :\t\n"; char foundbuffer[MAX_STAT_DEVICES][8]; int name_size; #if WMND_DEBUG > 2 fprintf( stderr, " checknetdevs()"); #endif /* WMND_DEBUG */ for (i=0; i 2 fprintf( stderr, " %s", p ); #endif /* WMND_DEBUG */ } } fclose(fd); } /* Nu foundbuffer naar stat_devices[].name kopieeren */ for (i=0; i SHORT_NAME_SIZE) { stat_devices[i].sname[SHORT_NAME_SIZE-1] = foundbuffer[j][name_size-1]; } for (k=0; k < (HIS_SIZE-6); k++) { stat_devices[i].his[k][0] = 0; stat_devices[i].his[k][1] = 0; stat_devices[i].his[k][2] = 0; stat_devices[i].his[k][3] = 0; } i++; } } return devsfound; } /******************************************************************* * DrawStats *******************************************************************/ void DrawStats(unsigned long int *his, int num, int size, int x_scope_left, int y_scope_bottom) { #define PIX_TX_x 33 /* pixel for TX */ #define PIX_TX_y 84 #define PIX_RX_x 34 /* pixel for RX */ #define PIX_RX_y 84 #define PIX_NA_x 32 /* pixel for N.A. */ #define PIX_NA_y 84 #define PIX_TB_x 35 /* pixel for time base line */ #define PIX_TB_y 84 #define PIX_SF_x 36 /* pixel for scope frame */ #define PIX_SF_y 84 int bpp; /* bytes per pixel */ int j,k; unsigned long int *p; int p0,p1,p2,p3; int in, out; int x_left, y_bottom; unsigned long int rx_max, tx_max; unsigned long int max; x_left = x_scope_left; y_bottom = y_scope_bottom - 1; if (pb_mode == PB_MODE_BYTES) { /* bytes mode */ in = 0; out = 1; } else { /* packets mode */ in = 2; out = 3; } /* ***************************************** * get the maximum value in screen history * *******************************************/ bpp = 1; rx_max = tx_max = 0; p = his; for (j=0; j size) { bpp = max / size; if ((max % size) > 0) { ++bpp; } } /***************************** * draw the last rx/tx bytes * *****************************/ p -= HIS_ITEMS; DrawRate( p[in], p[out] ); /* Draw the last rate */ /*********** * DrawMax * ***********/ switch (max_type) { case SCREEN: DrawMax(SCREEN, rx_max, tx_max); break; case HISTORY: DrawMax(); break; } /************** * graph work * **************/ p = his; switch (WaveForm) { case 0: /* traditional mode */ for (k=0; k\n" ); fprintf( stderr, " -h this help screen\n" ); fprintf( stderr, " -i default (as it appears in /proc/net/route)\n" ); fprintf( stderr, " -v print the version number\n" ); fprintf( stderr, " -w traditional mode (default is waveform mode)\n" ); fprintf( stderr, "\n" ); } /******************************************************************* * printversion *******************************************************************/ void printversion(void) { fprintf(stderr, "%s\n", WMND_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; sprintf(req.ifr__name, "ppp%d", PPP_UNIT); if (ioctl(ppp_h, SIOCGPPPSTATS, &req) < 0) { fprintf(stderr, "heyho!\n"); } *cur = req.stats; } /************* * Power LED * *************/ #define LED_ON_PW_X_B 116 /* bytes mode */ #define LED_ON_PW_Y_B 64 #define LED_ERR_PW_X_B 122 #define LED_ERR_PW_Y_B 64 #define LED_ON_PW_X_P 128 /* packets mode */ #define LED_ON_PW_Y_P 64 #define LED_ERR_PW_X_P 134 #define LED_ERR_PW_Y_P 64 #define LED_OFF_PW_X 140 #define LED_OFF_PW_Y 64 #define LED_PW_W 5 #define LED_PW_H 7 #define LED_PW_X 55 #define LED_PW_Y 4 /*************** * Receive LED * ***************/ #define LED_ON_RX_X 86 #define LED_ON_RX_Y 69 #define LED_OFF_RX_X 92 #define LED_OFF_RX_Y 69 #define LED_ERR_RX_X 80 #define LED_ERR_RX_Y 69 #define LED_RX_W 5 #define LED_RX_H 4 #define LED_RX_X 41 #define LED_RX_Y 4 /************ * Send LED * ************/ #define LED_ON_TX_X 86 #define LED_ON_TX_Y 64 #define LED_OFF_TX_X 92 #define LED_OFF_TX_Y 64 #define LED_ERR_TX_X 80 #define LED_ERR_TX_Y 64 #define LED_TX_W 5 #define LED_TX_H 4 #define LED_TX_X 48 #define LED_TX_Y 4 /******************************************************************** * SetOnLED ********************************************************************/ void SetOnLED( int led ) { switch (led) { case LED_NET_RX: copyXPMArea( LED_ON_RX_X, LED_ON_RX_Y, LED_RX_W, LED_RX_H, LED_RX_X, LED_RX_Y ); break; case LED_NET_TX: copyXPMArea( LED_ON_TX_X, LED_ON_TX_Y, LED_TX_W, LED_TX_H, LED_TX_X, LED_TX_Y ); break; case LED_NET_POWER: if (pb_mode == PB_MODE_BYTES) { copyXPMArea( LED_ON_PW_X_B, LED_ON_PW_Y_B, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } else { copyXPMArea( LED_ON_PW_X_P, LED_ON_PW_Y_P, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } break; } } /******************************************************************** * SetOffLED ********************************************************************/ void SetOffLED( int led ) { switch (led) { case LED_NET_RX: copyXPMArea( LED_OFF_RX_X, LED_OFF_RX_Y, LED_RX_W, LED_RX_H, LED_RX_X, LED_RX_Y ); break; case LED_NET_TX: copyXPMArea( LED_OFF_TX_X, LED_OFF_TX_Y, LED_TX_W, LED_TX_H, LED_TX_X, LED_TX_Y ); break; case LED_NET_POWER: copyXPMArea( LED_OFF_PW_X, LED_OFF_PW_Y, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); break; } } /******************************************************************** * SetErrLED ********************************************************************/ void SetErrLED( int led ) { switch (led) { case LED_NET_POWER: if (pb_mode == PB_MODE_BYTES) { copyXPMArea( LED_ERR_PW_X_B, LED_ERR_PW_Y_B, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } else { copyXPMArea( LED_ERR_PW_X_P, LED_ERR_PW_Y_P, LED_PW_W, LED_PW_H, LED_PW_X, LED_PW_Y ); } break; } } wmnd_0.1.0/README0100644000175000001440000000230407171014620012253 0ustar reedusersWMND -------------------------------------------------------------- Web site: http://www.wingeer.org/wmnd/ Author: Reed Lai http://www.wingeer.org/bv4qo/ Description -------------------------------------------------------------- WMND (WindowMaker Network Devices) is a network monitoring dock app improved and based on WMiFS 1.3b. You can find the features of WMiFS 1.3b from documents in directory WMiFS. Files -------------------------------------------------------------- README This file. INSTALL Installation instructions. HINTS Hints about what you can do with WMND. BUGS Things you don't want to know ;-) CHANGELOGS Description of changes. TODO Things we've already planned for WMND. COPYING GNU General Public License Version 2. Bugs -------------------------------------------------------------- If you discover any bugs in this software, please post it to http://www.wingeer.org/wmnd/wall/ Please describe the problems in as much detail as you can. Copyright -------------------------------------------------------------- WMND is copyright (c) 2000 by Reed Lai and licensed under the GNU General Public License. Read the COPYING file for the complete GNU license. wmnd_0.1.0/HINTS0100644000175000001440000000675707171007405012226 0ustar reedusersHints for WMND Generic -------------------------------------------------------------- WMND supports commandline options, 'wmnd -h' prints help about them. WMND has a special -i option, this way you can force WMND to monitor a particular interface like: wmnd -i eth0 & wmnd -i ppp0 & wmnd -i lo & Without the -i option (wmnd &) WMND automagicly grabs the default interface and will display the name and statistics of that interface. You can cycle in realtime through all available active interfaces by simply clicking with the left mousebutton on the interface name gadget in the upperleft corner of WMND... Note: The 'lo' interface is an exception, 'lo' ONLY works when invoked from the commandline (wmnd -i lo), lo was mainly built in for testing purposes ;-) WindowMaker -------------------------------------------------------------- WindowMaker users simply drag and drop the WMND dock.app on the WindowMaker Dock (preferred) or on the Fiend, and then press the rightmouse button on the outer edges of WMND and then enable 'Autolaunch' from the Dock popup menu. Afterstep -------------------------------------------------------------- Afterstep users put the following in their .steprc "Wharf wmnd - MaxSwallow "wmnd" wmnd -i eth0 -w &". Note: the small pixmap placement bug is in Wharf, please notify the AfterStep developers if you want to see this fixed! Other WindowManagers -------------------------------------------------------------- For other windowmanagers, WMND runs nicely as 64x64 pixel shaped icon on your desktop. p.s. FVWM can swallow it too, so we've heard ;-) Dragging WMND -------------------------------------------------------------- Be sure to drag WMND on it's outer edges, it's a bit picky due to the large gfx pixmap it keeps ;-). You can also use a mouse+keyboard shortcut in your window manager to drag it around. Setting up the WMND RC file -------------------------------------------------------------- WMND can (optionally) launch your scripts with a simple mouse click on the rate-meter of interface statistics display. You may define your settings in ~/.wmndrc like: left: /home/foobar/MyPPP-connect-script middle: /home/foobar/MyPPP-disconnect-script right: /home/foobar/MyPPP-reconnect-script Note: If you run a site where users may not fiddle with the PPP scripts, read INSTALL > Info For Site Admins! Obviously the PPP script needs to be runnable by the user running wmnd. Creating PPP dialup scripts -------------------------------------------------------------- Because a very good PPP HowTo already exists, it's quite pointless for us to explain to you how you should and can make them. Read the PPP HowTo, and you'll see that it's very easy to create your own PPP scripts. Permissions to allow non-root WMPPP connections -------------------------------------------------------------- WMND will connect just fine when run as root, but if you want to run WMND as a non-root user, there are a few files and programs to make permissions changes to. WMND needs access to the device file your modem is on, so if you use COM1, then the modem device file you use is /dev/cua0. Change the permissions so that it is world read/writable: chmod 666 /dev/cua0 The pppd daemon also makes calls to the kernel which require root permissions. The pppd daemon must be owned by root, and then have it's set-user-id bit turned on. This way, the pppd daemon will always run as SUID root. Change the owner and SUID bit like: chown root.root pppd chmod +s pppd wmnd_0.1.0/CREDIT0100644000175000001440000000057007171501540012275 0ustar reedusers Arthur Korn Wmnd man page author. Makefile maintenance. Debian package maintenance: http://www.korn.ch/arthur/wmnd-deb/ Michael Leuchtenburg http://otter.yi.org/ Web site adminstration: http://www.wingeer.org/wmnd/ English refinement of articles Reed Lai http://www.wingeer.org/bv4qo/ program.