From b603570f4a929feaf713ecc3bd03b8bab4e6cec8 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Rodolfo=20Garc=C3=ADa=20Pe=C3=B1as=20=28kix=29?= Date: Fri, 16 Dec 2011 10:59:10 +0100 Subject: [PATCH] wmmon: Official release of wmmon 1.0b2 --- wmmon/BUGS | 22 ++ wmmon/CHANGES | 19 ++ wmmon/COPYING | 339 ++++++++++++++++++++ wmmon/HINTS | 54 ++++ wmmon/INSTALL | 16 + wmmon/README | 77 +++++ wmmon/TODO | 18 ++ wmmon/wmgeneral/list.c | 169 ++++++++++ wmmon/wmgeneral/list.h | 59 ++++ wmmon/wmgeneral/misc.c | 164 ++++++++++ wmmon/wmgeneral/misc.h | 9 + wmmon/wmgeneral/wmgeneral.c | 366 +++++++++++++++++++++ wmmon/wmgeneral/wmgeneral.h | 50 +++ wmmon/wmmon/Makefile | 19 ++ wmmon/wmmon/wmmon-mask.xbm | 72 +++++ wmmon/wmmon/wmmon-master.xpm | 164 ++++++++++ wmmon/wmmon/wmmon.c | 739 +++++++++++++++++++++++++++++++++++++++++++ 17 files changed, 2356 insertions(+) create mode 100644 wmmon/BUGS create mode 100644 wmmon/CHANGES create mode 100644 wmmon/COPYING create mode 100644 wmmon/HINTS create mode 100644 wmmon/INSTALL create mode 100644 wmmon/README create mode 100644 wmmon/TODO create mode 100644 wmmon/wmgeneral/list.c create mode 100644 wmmon/wmgeneral/list.h create mode 100644 wmmon/wmgeneral/misc.c create mode 100644 wmmon/wmgeneral/misc.h create mode 100644 wmmon/wmgeneral/wmgeneral.c create mode 100644 wmmon/wmgeneral/wmgeneral.h create mode 100755 wmmon/wmmon/Makefile create mode 100644 wmmon/wmmon/wmmon-mask.xbm create mode 100644 wmmon/wmmon/wmmon-master.xpm create mode 100644 wmmon/wmmon/wmmon.c diff --git a/wmmon/BUGS b/wmmon/BUGS new file mode 100644 index 0000000..9df5079 --- /dev/null +++ b/wmmon/BUGS @@ -0,0 +1,22 @@ +Known 'features and easter eggs' in WMMon, +(or in non M$ talk, BUGS). + +WMMon 1.0b2 +-------------------------------------------------------------- + + * CPU usage is now normal again, except SysInfo mode, + SysInfo mode consumes about 1.6% CPU still :( ; + * On some systems the MEM and SWP gfx are 'eaten'; + * On some systems the MEM & SWP gauge seems dead, hopefully + this is solved now, but we'll notice if this is not so ;) + * GUI also cycles mode when clicking in the loadgraph area, + should only happen when mode gadget is clicked; + + +WMMon 1.0b1 +-------------------------------------------------------------- + + * CPU usage is still too high (yes, i'm a whiner > warp); + * GUI jumps back to the default CPU display if monitoring + Disk I/O and/or System Info when you stop/restart X; + * No real bugs in WMMon so far, mostly unfinished business ;) diff --git a/wmmon/CHANGES b/wmmon/CHANGES new file mode 100644 index 0000000..a776dae --- /dev/null +++ b/wmmon/CHANGES @@ -0,0 +1,19 @@ +WMMon changes. + +Version Description +-------------------------------------------------------------- +1.0b2 - Released 980520 + - Vastly reduced CPU usage in CPU & IO mode, + MEM/SWAP/UPTIME (i.e. SysInfo) only updated + when visible now and now uses global file + descriptors to reduce filesystem overhead, + based on diff by Dave Harden (dharden@wisewire.com); + - Fixed memory overflow bug; + - Memory gauge now displays real used mem, buffered + & cached mem are no longer being displayed; + - Added -i & -s parameters to select startupmode, based + on diff by Brendan Knox (knoxy@origob.demon.co.uk); + + +1.0b1 - Released 980513 + - First initial stable public BETA release. diff --git a/wmmon/COPYING b/wmmon/COPYING new file mode 100644 index 0000000..a43ea21 --- /dev/null +++ b/wmmon/COPYING @@ -0,0 +1,339 @@ + 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. diff --git a/wmmon/HINTS b/wmmon/HINTS new file mode 100644 index 0000000..cbf50e4 --- /dev/null +++ b/wmmon/HINTS @@ -0,0 +1,54 @@ +Hints for WMMon + +Generic +-------------------------------------------------------------- +WMMon supports 5 commandline options: + + -h (help); + -v (prints); + -d (display); + -i (startup in DiskI/O mode); + -s (startup in SysInfo mode); + +WMMon can lauch 3 user definable commands for left, middle and +right mouse button clicks, which you can define in ~/.wmmonrc, + +left: mycommand-1 & +middle: mycommand-2 & +right: mycommand-3 & + +If wmmon detects a ~/.wmmonrc file, it will launch your defined +command(s) when you click in the average load display area. + +WMMon can cycle in realtime between CPU, Disk I/O and the +SysInfo displays by simply left clicking on the upperleft +gadget (which displays CPU info by default). + +Be sure to drag WMMon on it's outer edges, WMMon is a bit picky +due to the large gfx pixmap it keeps ;-) + + +WindowMaker +-------------------------------------------------------------- +WindowMaker users simply drag and drop the WMMon dock.app on +the WindowMaker Dock (preferred) or on the Fiend and select +'autolaunch' from the rightmouse button popupmenu. + + +Afterstep +-------------------------------------------------------------- +Afterstep users put the following in their .steprc +"Wharf wmmon - MaxSwallow "wmmon" wmmon &". + +Note: AfterStep's Wharf has a problem with pixmaps that are +larger than 60x60 pixels. Please tell the AfterStep authors +to fix this, this is not our fault, but a Wharf problem! + + +Other WindowManagers +-------------------------------------------------------------- +For other windowmanagers, WMMon runs nicely as a 64x64 shaped +icon on your desktop. + + + diff --git a/wmmon/INSTALL b/wmmon/INSTALL new file mode 100644 index 0000000..7defae3 --- /dev/null +++ b/wmmon/INSTALL @@ -0,0 +1,16 @@ +Installation instructions for WMMon. + +Requirements +-------------------------------------------------------------- +Nothing particular :) + + +Installation +-------------------------------------------------------------- +1) % tar -zxvf wmmon-1.0b.tar.gz +2) % cd wmmon.app/wmmon +3) % make +4) copy 'wmmon' somewhere in your $PATH like /usr/local/bin; +5) % wmmon & (or wmmon -h for help) + +Be sure to read the HINTS and TODO files too! diff --git a/wmmon/README b/wmmon/README new file mode 100644 index 0000000..ba5cc9e --- /dev/null +++ b/wmmon/README @@ -0,0 +1,77 @@ +WMMon-1.0b2 - Public BETA release +-------------------------------------------------------------- +Authors...: Martijn Pieterse (pieterse@xs4all.nl) + Antoine Nulle (warp@xs4all.nl) + +Note......: WMMon 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 WMMon support website address: + + http://windowmaker.mezaway.org + +Credits...: Bobby Mezaway (bobby@mezaway.org) for generously + hosting our website! + Dave Harden (dharden@wisewire.com) for the major + speedup diffs! + + +Description +-------------------------------------------------------------- +WMMon monitors the realtime CPU load as well the average +system load and gives you some nice additional features too... + +WMMon currently provides: + + * Realtime CPU 'stress' meter; + * Average systemload, like xload & wmavgload; + * Average systemload graphic is autoscaling; + * Realtime Disk I/O 'stress' meter; + * Average Disk I/O load grapic (autoscaling); + * Realtime total Mem & Swap usage meters; + * System uptime display; + * Realtime cycling through all monitor modes; + * Can lauch 3 user definable commands through ~/.wmmonrc; + * Can be started multiple times; + * Commandline options for help (-h), version (-v), + start mode (-i & -s) and display (-d); + +There are some 'known' unfinished parts, be sure to read the TODO +file, but we decided to release it early because of the high +demand and many requests we got for this one ;) + +WMMon is being developped on DEC Alpha machines running +Linux/RedHat-5.0, but, WMMon has been intensively tested +on x86 and 68K Linux machines too ;-) + +p.s. WMMon is still a Linux ONLY app, sorry about that :( + +Files +-------------------------------------------------------------- +README This file. +INSTALL Installation instructions. +HINTS Hints about what you can do with WMMon. +BUGS Things you don't want to know ;-) +CHANGES Description of changes. +COPYING GNU General Public License Version 2. +TODO Stuff we've planned for future WMMon releases. + + +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 +-------------------------------------------------------------- +WMMon.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. + + diff --git a/wmmon/TODO b/wmmon/TODO new file mode 100644 index 0000000..af01ebb --- /dev/null +++ b/wmmon/TODO @@ -0,0 +1,18 @@ +TODO list for WMMon. +-------------------------------------------------------------- +This is a list of things we've already planned for WMMon-1.0: + + * Commandline? option for LED colors; + * Optional LCD GUI, either compiletime or runtime; + * Lower CPU usage (only in SysInfo mode) CPU and I/O + mode are very low in CPU usage now ;-); + * Multiple CPU support; + * GUI mode for simultanious CPU/IO/MEM&SWAP realtime + loadbars (like Matt suggested ;-) ); + +Your feedback! If you have nice suggestions, ideas, whatever, +that aren't on this list, feel free to mail them to: + + dockapps@windowmaker.mezaway.org + +If you don't let us know... how are we suppose to know? ;-) diff --git a/wmmon/wmgeneral/list.c b/wmmon/wmgeneral/list.c new file mode 100644 index 0000000..f804b2c --- /dev/null +++ b/wmmon/wmgeneral/list.c @@ -0,0 +1,169 @@ +/* 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; + } +} diff --git a/wmmon/wmgeneral/list.h b/wmmon/wmgeneral/list.h new file mode 100644 index 0000000..af0f22c --- /dev/null +++ b/wmmon/wmgeneral/list.h @@ -0,0 +1,59 @@ +/* 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 diff --git a/wmmon/wmgeneral/misc.c b/wmmon/wmgeneral/misc.c new file mode 100644 index 0000000..34281e2 --- /dev/null +++ b/wmmon/wmgeneral/misc.c @@ -0,0 +1,164 @@ +/* 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 */ diff --git a/wmmon/wmgeneral/wmgeneral.c b/wmmon/wmgeneral/wmgeneral.c new file mode 100644 index 0000000..a4f13c1 --- /dev/null +++ b/wmmon/wmgeneral/wmgeneral.c @@ -0,0 +1,366 @@ +/* + 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); + +} diff --git a/wmmon/wmgeneral/wmgeneral.h b/wmmon/wmgeneral/wmgeneral.h new file mode 100644 index 0000000..55b37dd --- /dev/null +++ b/wmmon/wmgeneral/wmgeneral.h @@ -0,0 +1,50 @@ +#ifndef WMGENERAL_H_INCLUDED +#define WMGENERAL_H_INCLUDED + + /***********/ + /* Defines */ +/***********/ + +#define MAX_MOUSE_REGION (8) + + /************/ + /* Typedefs */ +/************/ + +typedef struct _rckeys rckeys; + +struct _rckeys { + const char *label; + char **var; +}; + +typedef struct { + Pixmap pixmap; + Pixmap mask; + XpmAttributes attributes; +} XpmIcon; + + /*******************/ + /* Global variable */ +/*******************/ + +Display *display; + + /***********************/ + /* Function Prototypes */ +/***********************/ + +void AddMouseRegion(int index, int left, int top, int right, int bottom); +int CheckMouseRegion(int x, int y); + +void openXwindow(int argc, char *argv[], char **, char *, int, int); +void RedrawWindow(void); +void RedrawWindowXY(int x, int y); + +void copyXPMArea(int, int, int, int, int, int); +void copyXBMArea(int, int, int, int, int, int); +void setMaskXY(int, int); + +void parse_rcfile(const char *, rckeys *); + +#endif diff --git a/wmmon/wmmon/Makefile b/wmmon/wmmon/Makefile new file mode 100755 index 0000000..a0793dd --- /dev/null +++ b/wmmon/wmmon/Makefile @@ -0,0 +1,19 @@ +LIBDIR = -L/usr/X11R6/lib +LIBS = -lXpm -lXext -lX11 +OBJS = wmmon.o \ + ../wmgeneral/wmgeneral.o \ + ../wmgeneral/misc.o \ + ../wmgeneral/list.o + + +.c.o: + cc -c -O2 -Wall $< -o $*.o + +wmmon: $(OBJS) + cc -o wmmon $^ $(LIBDIR) $(LIBS) + +clean:: + for i in $(OBJS) ; do \ + rm $$i;\ + done + rm wmmon diff --git a/wmmon/wmmon/wmmon-mask.xbm b/wmmon/wmmon/wmmon-mask.xbm new file mode 100644 index 0000000..3289657 --- /dev/null +++ b/wmmon/wmmon/wmmon-mask.xbm @@ -0,0 +1,72 @@ +#define wmmon_mask_width 128 +#define wmmon_mask_height 64 +static char wmmon_mask_bits[] = { + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, + + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; diff --git a/wmmon/wmmon/wmmon-master.xpm b/wmmon/wmmon/wmmon-master.xpm new file mode 100644 index 0000000..7e492c9 --- /dev/null +++ b/wmmon/wmmon/wmmon-master.xpm @@ -0,0 +1,164 @@ +/* XPM */ +static char * wmmon_master_xpm[] = { +"128 120 41 1", +" c #00000000FFFF", +". c #000000000000", +"X c #208120812081", +"o c #C71BC71BC71B", +"O c #28A23CF30000", +"+ c #28A238E30000", +"@ c #30C238E30000", +"# c #30C234D30000", +"$ c #38E330C20000", +"% c #41032CB20000", +"& c #492428A20000", +"* c #514424920000", +"= c #596520810000", +"- c #59651C710000", +"; c #61851C710000", +": c #618518610000", +"> c #2081B2CAAEBA", +", c #000049244103", +"< c #104079E779E7", +"1 c #18618A288617", +"2 c #2081D34C0000", +"3 c #30C2CB2B0000", +"4 c #38E3BEFB0000", +"5 c #4103B6DA0000", +"6 c #4924AAAA0000", +"7 c #5965A2890000", +"8 c #618596580000", +"9 c #69A68E380000", +"0 c #71C682070000", +"q c #861779E70000", +"w c #8E386DB60000", +"e c #965865950000", +"r c #9E7959650000", +"t c #AEBA51440000", +"y c #B6DA45140000", +"u c #BEFB3CF30000", +"i c #C71B30C20000", +"p c #10407DF779E7", +"a c #00007DF771C6", +"s c #2081B6DAAEBA", +"d c #71C6E38D71C6", +" ", +" ", +" ", +" ", +" ...................... ................................ ...................... ................................ ", +" .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o .X>,,,>X<>>>,,,>XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o .X>>X>>X>XXX,X>>X>>XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o .X>X>X>X>XXX,X>X>X>XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o .X<,,,>>XX<,,,XXX>X>XXX,X>XXX>XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o .X>XXX>X>XXX,X>XXX>XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o .X<,,,>>>>>>XXX,X>XXX>X>XXX>XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X>XXX,X>XXX>X>XXX>XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X<>>>>>X>X>X>X>XXX,XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXX>X>>X>>X>XXX,XXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X<>>>,,,>X<,,,XXXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXo .OOOO++@##$$$$%%%&&&&****=--;;:o ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo oooooooooooooooooooooo oooooooooooooooooooooooooooooooo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ........................................................ ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XX,,,XXX,,,XXX,,,XXX,,,XXXXXXXX>XXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXX,X,XXX,X,XXX,X,XXX,XXXXXXX>XXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXX,X,XXX,X,XXX,X,XXX,XXXX>>>>X>>>>XX>XXX>XX>>>XXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XX,,,XXX,,,XXX,,,XXX,,,XXXX>XXX>XXXXX>X>XXX>X>XXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXX,X,XXX,X,XXX,X,XXX,XXX>XXX>X>>>>>XX>>>>X>>>>>XXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXX,X,XXX,X,XXX,X,XXX,XXX>XXX>X>XXX>XXXXX>XXXXX>XXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XX,,,XXX,,,XXX,,,XXX,,,XXXXX>>>>X>>>>>X>>>>XXX>>>>X>XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX>XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XX,,,,XXX,,,,XXXXXXXX,,,,XXX,,,,XXXXXXXX,,,,XXX,,,,XXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXXX,X,XXXX,XX1>XX,XXXX,X,XXXX,XX1>XX,XXXX,X,XXXX,XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXXX,X,XXXX,XX<>XX,XXXX,X,XXXX,XX<>XX,XXXX,X,XXXX,XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXXX,X,XXXX,XXXXXX,XXXX,X,XXXX,XXXXXX,XXXX,X,XXXX,XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XX,,,,XXX,,,,XXXXXXXX,,,,XXX,,,,XXXXXXXX,,,,XXX,,,,XXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXXX,X,XXXX,XXXXXX,XXXX,X,XXXX,XXXXXX,XXXX,X,XXXX,XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXXX,X,XXXX,XX1>XX,XXXX,X,XXXX,XX1>XX,XXXX,X,XXXX,XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .X,XXXX,X,XXXX,XX<>XX,XXXX,X,XXXX,XX<>XX,XXXX,X,XXXX,XXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XX,,,,XXX,,,,XXXXXXXX,,,,XXX,,,,XXXXXXXX,,,,XXX,,,,XXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo .XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXo ", +" oooooooooooooooooooooooooooooooooooooooooooooooooooooooo oooooooooooooooooooooooooooooooooooooooooooooooooooooooo ", +" ", +" ", +" ", +" ", +"................................................................ ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio XX>>>XXX,,,1X1>>>1X1>>>1X>,,,>X1>>>1X1>>>1X1>>>1X1>>>1X1>>>1X ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio X>XXX>X,XXX>X,XXX>X,XXX>X>XXX>X>XXX,X>XXX,X,XXX>X>XXX>X>XXX>X ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio X>XXX>X,XXX>X,XXX>X,XXX>X>XXX>X>XXX,X>XXX,X,XXX>X>XXX>X>XXX>X ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio X1,,,1XX,,,1X1>>>1XX>>>1X1>>>1X>>>>1X1>>>1XX,,,1X1>>>1Xp>>>1X ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio X>XXX>X,XXX>X>XXX,X,XXX>X,XXX>X,XXX>X>XXX>X,XXX>X>XXX>X,XXX>X ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio X>XXX>X,XXX>X>XXX,X,XXX>X,XXX>X,XXX>X>XXX>X,XXX>X>XXX>X,XXX>X ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio XX>>>XXX,,,>X1>>>1X1>>>1XX,,,1X1>>>1X1>>>1XX,,,>X1>>>1X1>>>1X ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX ", +".OOOO++@##$$$$%%%&&&&****=--;;:o.2233445667788990qqwweerrtyyuuio ", +"oooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo ", +" ", +"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX ", +"XasssaXasssaXa,,,aXXX,,,aXXXXXXasssaXX XX>>>>XXX,,,,pXp>>>>1Xp>>>>pXp,,,,pXp>>>>pXp>>>>1Xp>>>>pXp>>>>1Xp>>>>1XXXXXX ", +"XsXXX,XsXXXsXsXXXsXX,XXXsXXXXsXsXXXsXX X>XXXX>X,XXXX>X,XXXX>X,XXXX>X>XXXX>X>XXXX,X>XXXX,X,XXXX>X>XXXX>X>XXXX>XX1>XX ", +"XsXXX,XsXXXsXsXXXsXX,XXXsXXXXsXsXXXsXX X>XXXX>X,XXXX>X,XXXX>X,XXXX>X>XXXX>X>XXXX,X>XXXX,X,XXXX>X>XXXX>X>XXXX>XXp>XX ", +"Xa,,,XXasssaXa,,,aXXX,,,aXXXsXXa,,,aXX X>XXXX>X,XXXX>X,XXXX>X,XXXX>X>XXXX>X>XXXX,X>XXXX,X,XXXX>X>XXXX>X>XXXX>XXXXXX ", +"XsXXX,XsXXX,XsXXXsXX,XXXsXXXsXXsXXXsXX Xp,,,,pXX,,,,pXp>>>>pXp>>>>pXp>>>>pXp>>>>pXp>>>>pXX,,,,pXp>>>>pXp>>>>pXXXXXX ", +"XsXXX,XsXXX,XsXXXsXX,XXXsXXsXXXsXXXsXX X>XXXX>X,XXXX>X>XXXX,X,XXXX>X,XXXX>X,XXXX>X>XXXX>X,XXXX>X>XXXX>X,XXXX>XXXXXX ", +"XasssaXa,,,XXasssaXXX,,,aXXaXXXasssaXX X>XXXX>X,XXXX>X>XXXX,X,XXXX>X,XXXX>X,XXXX>X>XXXX>X,XXXX>X>XXXX>X,XXXX>XX1>XX ", +"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX X>XXXX>X,XXXX>X>XXXX,X,XXXX>X,XXXX>X,XXXX>X>XXXX>X,XXXX>X>XXXX>X,XXXX>XXp>XX ", +"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XX>>>>XXX,,,,pXp>>>>pXp>>>>pXX,,,,pXp>>>>pXp>>>>pXX,,,,pXp>>>>pXp>>>>pXXXXXX ", +" XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX ", +" a ", +" s ", +" X ", +" d ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" "}; diff --git a/wmmon/wmmon/wmmon.c b/wmmon/wmmon/wmmon.c new file mode 100644 index 0000000..20fdabe --- /dev/null +++ b/wmmon/wmmon/wmmon.c @@ -0,0 +1,739 @@ +/* + Code based on wmppp/wmifs + + [Orig WMPPP comments] + + This code was mainly put together by looking at the + following programs: + + asclock + A neat piece of equip, used to display the date + and time on the screen. + Comes with every AfterStep installation. + + Source used: + How do I create a not so solid window? + How do I open a window? + How do I use pixmaps? + + ------------------------------------------------------------ + + Authors: Martijn Pieterse (pieterse@xs4all.nl) + Antoine Nulle (warp@xs4all.nl) + + This program is distributed under the GPL license. + (as were asclock and pppstats) + + ---- + Changes: + ---- + + 18/05/1998 (Antoine Nulle, warp@xs4all.nl) + * MEM/SWAP/UPTIME only updated when visible + * Using global file descriptors to reduce file + system overhead, both updates are based on a diff + supplied by Dave Harden (dharden@wisewire.com) + 15/05/1998 (Antoine Nulle, warp@xs4all.nl) + * Fixed memory overflow in the MEM gaugebar + * MEM gauge displays now real used mem + (buffered + cached mem removed) + 14/05/1998 (Antoine Nulle, warp@xs4all.nl) + * Added -i & -s kludge for selecting startupmode, + tijno, don't hate me for this :) + 12/05/1998 (Antoine Nulle, warp@xs4all.nl) + * Finetuned master-xpm, tijno don't worry, no + reprogramming needed this time ;-) + 07/05/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Added disk i/o + 03/05/1998 (Antoine Nulle, warp@xs4all.nl) + * Added new master-xpm which contains the gfx + for the upcoming SysInfo part :P + 02/05/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Removed a lot of code, that was put in wmgeneral + 23/04/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Added zombie destroying code (aka wait :) ) + 18/04/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Added CPU-on-screen. + * Added -display command line + 15/04/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Fixed a bug in the stats routine + (Top 3 bright pixels were not shown when 100% loaded) + * Changed xpm to a no-title one. + This included the reprogramming of all positions. + warpstah, i hate you! ;) + 05/04/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * First Working Version +*/ + +#include +#include +#include +#include +#include +#include + +#include +#include +#include + +#include +#include +#include + +#include "../wmgeneral/wmgeneral.h" +#include "../wmgeneral/misc.h" + +#include "wmmon-master.xpm" +#include "wmmon-mask.xbm" + + /***********/ + /* Defines */ +/***********/ + +#define LEFT_ACTION (NULL) +#define RIGHT_ACTION (NULL) +#define MIDDLE_ACTION (NULL) + +#define WMMON_VERSION "1.0.b2" + + /********************/ + /* Global Variables */ +/********************/ + +char *ProgName; +int stat_current = 0; /* now global */ +FILE *fp_meminfo; +FILE *fp_stat; +FILE *fp_loadavg; + +/* functions */ +void usage(void); +void printversion(void); +void DrawStats(int *, int, int, int, int); +void DrawStats_io(int *, int, int, int, int); + +void wmmon_routine(int, char **); + +void main(int argc, char *argv[]) { + + int i; + + + /* Parse Command Line */ + + ProgName = argv[0]; + if (strlen(ProgName) >= 5) + ProgName += (strlen(ProgName) - 5); + + for (i=1; i 32) j = 32; + copyXPMArea(32, 64, j, 12, 28, 4); + } else { + /* Nu zal ie wel 3 zijn. */ + + copyXPMArea(0, 64, 32, 12, 28+64, 4); + copyXPMArea(0, 64, 32, 12, 28+64, 18); + + j = stat_device[2].rt_idle; + if (j != 0) { + j = (stat_device[2].rt_stat * 100) / j; + } + j = j * 0.32; + if (j > 32) j = 32; + copyXPMArea(32, 64, j, 12, 28+64, 4); + /*--------------------- ------------------*/ + j = stat_device[3].rt_idle; + if (j != 0) { + j = (stat_device[3].rt_stat * 100) / j; + } + j = j * 0.32; + if (j > 32) j = 32; + copyXPMArea(32, 64, j, 12, 28+64, 18); + + /*----------- online tijd neerzetten! ----------*/ + + cnt_time = time(0) - ref_time + online_time; + + /* cnt_time = uptime in seconden */ + /* + secs = 108,47 + mins = 89,47 + uren = 70,47 + digits = 40,78, 6breed, 9hoog + */ + i = cnt_time % 60; + cnt_time /= 60; + copyXPMArea(40 + (i % 10)*7, 78, 6, 9, 115, 47); + copyXPMArea(40 + (i / 10)*7, 78, 6, 9, 108, 47); + + i = cnt_time % 60; + cnt_time /= 60; + copyXPMArea(40 + (i % 10)*7, 78, 6, 9, 96, 47); + copyXPMArea(40 + (i / 10)*7, 78, 6, 9, 89, 47); + + i = cnt_time % 24; + cnt_time /= 24; + copyXPMArea(40 + (i % 10)*7, 78, 6, 9, 77, 47); + copyXPMArea(40 + (i / 10)*7, 78, 6, 9, 70, 47); + + /* De rest is dagen! 5x7*/ + + i = cnt_time; + copyXPMArea(66 + (i % 10)*6, 66, 5, 7, 88, 35); + i /= 10; + copyXPMArea(66 + (i % 10)*6, 66, 5, 7, 82, 35); + i /= 10; + copyXPMArea(66 + (i % 10)*6, 66, 5, 7, 76, 35); + i /= 10; + copyXPMArea(66 + (i % 10)*6, 66, 5, 7, 70, 35); + } + + if (curtime >= nexttime) { + nexttime+=10; + + for (i=0; i= 0) { + switch (but_stat) { + case 0: + switch (Event.xbutton.button) { + case 1: + if (left_action) + execCommand(left_action); + break; + case 2: + if (middle_action) + execCommand(middle_action); + break; + case 3: + if (right_action) + execCommand(right_action); + break; + } + case 1: + stat_current++; + printf("current stat is :%d\n", stat_current); + if (stat_current == stat_online) + stat_current = 0; + + DrawActive(stat_device[stat_current].name); + if (stat_current == 0) DrawStats(stat_device[stat_current].his, 54, 40, 5, 58); + if (stat_current == 1) { + DrawStats_io(stat_device[stat_current].his, 54, 40, 5, 58); + } + if (stat_current == 2) { + xpm_X = 64; + setMaskXY(-64, 0); + } else { + xpm_X = 0; + setMaskXY(0, 0); + } + RedrawWindowXY(xpm_X, xpm_Y); + break; + } + } + break; + } + } + + usleep(250000L); + } +} + +void update_stat_cpu(stat_dev *st) { + + long k, istat, idle; + + get_statistics(st->name, &k, &istat, &idle); + + st->rt_idle = idle - st->idlelast; + st->idlelast = idle; + + st->rt_stat = istat - st->statlast; + st->statlast = istat; + + st->his[54] += k; + st->hisaddcnt += 1; +} + +void update_stat_io(stat_dev *st) { + + long j, k, istat, idle; + static long maxdiskio = 0; + + get_statistics(st->name, &k, &istat, &idle); + + st->rt_idle = idle - st->idlelast; + st->idlelast = idle; + + st->rt_stat = istat - st->statlast; + st->statlast = istat; + + j = st->rt_stat; + if (maxdiskio < j) { + maxdiskio = j; + } + st->rt_idle = maxdiskio - j; + + st->his[54] += st->rt_stat; + st->hisaddcnt += 1; +} + +void update_stat_mem(stat_dev *st, stat_dev *st2) { + + char temp[128]; + unsigned long free, shared, buffers, cached; + + freopen("/proc/meminfo", "r", fp_meminfo); + while (fgets(temp, 128, fp_meminfo)) { + if (strstr(temp, "Mem:")) { + sscanf(temp, "Mem: %ld %ld %ld %ld %ld %ld", + &st->rt_idle, &st->rt_stat, + &free, &shared, &buffers, &cached); + st->rt_idle >>= 10; + st->rt_stat -= buffers+cached; + st->rt_stat >>= 10; +// break; + } + if (strstr(temp, "Swap:")) { + sscanf(temp, "Swap: %ld %ld", &st2->rt_idle, &st2->rt_stat); + st2->rt_idle >>= 10; + st2->rt_stat >>= 10; + break; + } + } +} + +void update_stat_swp(stat_dev *st) { + + char temp[128]; + + fseek(fp_meminfo, 0, SEEK_SET); + while (fgets(temp, 128, fp_meminfo)) { + if (strstr(temp, "Swap:")) { + sscanf(temp, "Swap: %ld %ld", &st->rt_idle, &st->rt_stat); + st->rt_idle >>= 10; + st->rt_stat >>= 10; + break; + } + } + +} + +/*******************************************************************************\ +|* get_statistics *| +\*******************************************************************************/ + +void get_statistics(char *devname, long *is, long *ds, long *idle) { + + int i; + char temp[128]; + char *p; + char *tokens = " \t\n"; + float f; + long maxdiskio=0; + + *is = 0; + *ds = 0; + *idle = 0; + + if (!strncmp(devname, "cpu", 3)) { + fseek(fp_stat, 0, SEEK_SET); + while (fgets(temp, 128, fp_stat)) { + if (strstr(temp, "cpu")) { + p = strtok(temp, tokens); + /* 1..3, 4 == idle, we don't want idle! */ + for (i=0; i<3; i++) { + p = strtok(NULL, tokens); + *ds += atol(p); + } + p = strtok(NULL, tokens); + *idle = atol(p); + } + } + fp_loadavg = freopen("/proc/loadavg", "r", fp_loadavg); + fscanf(fp_loadavg, "%f", &f); + *is = (long) (100 * f); + } + + if (!strncmp(devname, "i/o", 3)) { + + fseek(fp_stat, 0, SEEK_SET); + while (fgets(temp, 128, fp_stat)) { + if (strstr(temp, "disk_rio") || strstr(temp, "disk_wio")) { + p = strtok(temp, tokens); + /* 1..4 */ + for (i=0; i<4; i++) { + p = strtok(NULL, tokens); + *ds += atol(p); + } + } + } + if (*ds > maxdiskio) maxdiskio = *ds; + } +} + +/*******************************************************************************\ +|* checksysdevs *| +\*******************************************************************************/ + +int checksysdevs(void) { + + strcpy(stat_device[0].name, "cpu0"); + strcpy(stat_device[1].name, "i/o"); + strcpy(stat_device[2].name, "sys"); + + return 3; +} + + +/*******************************************************************************\ +|* void DrawActive(char *) *| +\*******************************************************************************/ + +void DrawActive(char *name) { + + /* Alles op X,77 + CPU: 0 + I/O: 21 + + 20 Breed, 10 hoog + Destinatie: 5,5 + */ + + if (name[0] == 'c') { + copyXPMArea(0, 77, 19, 10, 5, 5); + } else if (name[0] == 'i') { + copyXPMArea(19, 77, 19, 10, 5, 5); + } + +} + +/*******************************************************************************\ +|* DrawStats *| +\*******************************************************************************/ + +void DrawStats(int *his, int num, int size, int x_left, int y_bottom) { + + int pixels_per_byte; + int j,k; + int *p; + int d; + + pixels_per_byte = 100; + p = his; + for (j=0; j pixels_per_byte) + pixels_per_byte += 100; + p += 1; + } + + p = his; + + for (k=0; k 0; j-=100) { + for (k=0; k global_io_scale) global_io_scale = p[j]; + } + + pixels_per_byte = 1.0 * global_io_scale / size; + if (pixels_per_byte == 0) pixels_per_byte = 1; + + for (k=0; k\n"); + fprintf(stderr, "\t-h\tthis screen\n"); + fprintf(stderr, "\t-v\tprint the version number\n"); + fprintf(stderr, "\t-i\tstartup in DiskIO mode\n"); + fprintf(stderr, "\t-s\tstartup in SysInfo mode\n"); + fprintf(stderr, "\n"); +} + +/*******************************************************************************\ +|* printversion *| +\*******************************************************************************/ + +void printversion(void) { + + if (!strcmp(ProgName, "wmmon")) { + fprintf(stderr, "%s\n", WMMON_VERSION); + } +} -- 2.11.4.GIT