wmspaceweather: Add version 1.04 to repository.
From ftp://ftp.uk.freebsd.org/pub/OpenBSD/distfiles/wmSpaceWeather-1.04.tar.gz
This commit is contained in:
parent
62dc94e5c9
commit
7335ef2927
1
wmspaceweather/BUGS
Normal file
1
wmspaceweather/BUGS
Normal file
|
@ -0,0 +1 @@
|
|||
Please send bug reports to mghenderson@lanl.gov
|
18
wmspaceweather/CHANGES
Normal file
18
wmspaceweather/CHANGES
Normal file
|
@ -0,0 +1,18 @@
|
|||
wmSpaceWeather changes.
|
||||
|
||||
Version Description
|
||||
-------------------------------------------------------------------------
|
||||
1.04 - released Feb 18, 1999
|
||||
Added double click capability. Double clicking on mouse button 1 sends
|
||||
URL (defined via ne command line option -url) to netscape.
|
||||
|
||||
1.03 - released Feb 11, 1999
|
||||
Changed display a bit. When no data is
|
||||
available, it now shows nothing (before it would
|
||||
show false junk...). Modified Perl Script GetKp.
|
||||
|
||||
|
||||
1.02 - released Feb 8, 1999
|
||||
bug fixes...
|
||||
|
||||
1.0b - released Dec 19, 1998
|
339
wmspaceweather/COPYING
Normal file
339
wmspaceweather/COPYING
Normal file
|
@ -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.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) 19yy <name of author>
|
||||
|
||||
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.
|
||||
|
||||
<signature of Ty Coon>, 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.
|
36
wmspaceweather/HINTS
Normal file
36
wmspaceweather/HINTS
Normal file
|
@ -0,0 +1,36 @@
|
|||
Hints for wmSpaceWeather
|
||||
|
||||
Generic.
|
||||
--------
|
||||
wmSpaceWeather version: 1.0b
|
||||
|
||||
usage: wmSpaceWeather [-h] [-display <display>]
|
||||
|
||||
-d <display> Use alternate display.
|
||||
-h Display help screen.
|
||||
|
||||
|
||||
|
||||
WindowMaker.
|
||||
------------
|
||||
In WindowMaker simply drag and drop the wmSpaceWeather App on
|
||||
the WindowMaker Dock or Clip.
|
||||
|
||||
|
||||
Afterstep.
|
||||
---------
|
||||
Afterstep users put the following in their .steprc
|
||||
"Wharf wmSpaceWeather - MaxSwallow "wmSpaceWeather" wmSpaceWeather &".
|
||||
|
||||
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 window managers.
|
||||
----------------------
|
||||
wmSpaceWeather shows as a 64x64 shaped icon on your desktop under other
|
||||
window managers.
|
||||
|
||||
|
||||
|
22
wmspaceweather/INSTALL
Normal file
22
wmspaceweather/INSTALL
Normal file
|
@ -0,0 +1,22 @@
|
|||
Installation instructions for wmSpaceWeather.
|
||||
|
||||
Requirements
|
||||
--------------------------------------------------------------
|
||||
wmSpaceWeather requires the Xpm library (which should be available on
|
||||
most machines with XFree86 installed).
|
||||
|
||||
Installation
|
||||
--------------------------------------------------------------
|
||||
1) gunzip wmSpaceWeather-1.0.tar.gz
|
||||
1) tar -xvf wmSpaceWeather-1.0.tar
|
||||
2) cd wmSpaceWeather-1.0/wmSpaceWeather/
|
||||
3) make
|
||||
4) make install (must be root)
|
||||
5) wmSpaceWeather & (or 'wmSpaceWeather -h' for help, or 'man wmSpaceWeather' for the man page)
|
||||
6) You need to set the location of perl correctly in GetKp if your perl
|
||||
is located in a place other than /usr/bin/
|
||||
|
||||
|
||||
|
||||
|
||||
|
30
wmspaceweather/README
Normal file
30
wmspaceweather/README
Normal file
|
@ -0,0 +1,30 @@
|
|||
wmSpaceWeather-1.0b release
|
||||
----------------------
|
||||
Author....: Michael G. Henderson <mghenderson@lanl.gov>
|
||||
|
||||
|
||||
Description
|
||||
-----------
|
||||
wmSpaceWeather is a space weather monitor
|
||||
|
||||
|
||||
Files
|
||||
-----
|
||||
README This file.
|
||||
INSTALL Installation instructions.
|
||||
HINTS Hints about what you can do with wmSpaceWeather.
|
||||
BUGS Bug reports
|
||||
CHANGES Change history.
|
||||
COPYING GNU General Public License Version 2.
|
||||
|
||||
|
||||
Bugs
|
||||
-----
|
||||
Send bug reports to mghenderson@lanl.gov
|
||||
|
||||
|
||||
Copyright
|
||||
----------
|
||||
wmSpaceWeather is copyright (c) 1998 by Michael G. Henderson and
|
||||
licensed through the GNU General Public License. Read the
|
||||
COPYING file for the complete GNU license.
|
212
wmspaceweather/wmSpaceWeather/GetKp
Executable file
212
wmspaceweather/wmSpaceWeather/GetKp
Executable file
|
@ -0,0 +1,212 @@
|
|||
#!/usr/bin/perl
|
||||
|
||||
#
|
||||
# A really crappy code to grab last 8 Kp values....
|
||||
#
|
||||
|
||||
|
||||
require "ctime.pl";
|
||||
|
||||
|
||||
($Year, $Month, $Day) = &year_month_day();
|
||||
|
||||
if (-e "/tmp/DGD.txt"){
|
||||
unlink("/tmp/DGD.txt");
|
||||
}
|
||||
|
||||
if (-e "/tmp/curind.txt"){
|
||||
unlink("/tmp/curind.txt");
|
||||
}
|
||||
|
||||
|
||||
$grabcmd = "cd /tmp; wget --passive-ftp --tries 2 -q ftp://www.sec.noaa.gov/pub/indices/DGD.txt";
|
||||
system "$grabcmd";
|
||||
|
||||
|
||||
#
|
||||
# ensure that there are at least 8 values available...
|
||||
#
|
||||
%Kp = ();
|
||||
$Kp{190001011} = 999;
|
||||
$Kp{190001012} = 999;
|
||||
$Kp{190001013} = 999;
|
||||
$Kp{190001014} = 999;
|
||||
$Kp{190001015} = 999;
|
||||
$Kp{190001016} = 999;
|
||||
$Kp{190001017} = 999;
|
||||
$Kp{190001018} = 999;
|
||||
|
||||
|
||||
open(TmpFile, "/tmp/DGD.txt");
|
||||
while (<TmpFile>){
|
||||
chop;
|
||||
if ($_ =~ /^\d{4} \d{2} \d{2}\s*\d*/ ){
|
||||
|
||||
$Date = $_;
|
||||
|
||||
s/^(\d{4}) (\d{2}) (\d{2}).*\s{2,}(.*)/\4/;
|
||||
s/([ -]{0,1}\d{1,2})([ -]{0,1}\d{1,2})([ -]{0,1}\d{1,2})([ -]{0,1}\d{1,2})([ -]{0,1}\d{1,2})([ -]{0,1}\d{1,2})([ -]{0,1}\d{1,2})([ -]{0,1}\d{1,2})/\1 \2 \3 \4 \5 \6 \7 \8/;
|
||||
|
||||
$Date =~ s/^(\d{4}) (\d{2}) (\d{2}).*\s{2,}(.*)/\1\2\3/;
|
||||
($a, $b, $c, $d, $e, $f, $g, $h) = split(/\s{1,}/, $_);
|
||||
|
||||
$TimeTag = $Date*10 + 1; $Kp{$TimeTag} = $a;
|
||||
$TimeTag = $Date*10 + 2; $Kp{$TimeTag} = $b;
|
||||
$TimeTag = $Date*10 + 3; $Kp{$TimeTag} = $c;
|
||||
$TimeTag = $Date*10 + 4; $Kp{$TimeTag} = $d;
|
||||
$TimeTag = $Date*10 + 5; $Kp{$TimeTag} = $e;
|
||||
$TimeTag = $Date*10 + 6; $Kp{$TimeTag} = $f;
|
||||
$TimeTag = $Date*10 + 7; $Kp{$TimeTag} = $g;
|
||||
$TimeTag = $Date*10 + 8; $Kp{$TimeTag} = $h;
|
||||
|
||||
}
|
||||
}
|
||||
close(TmpFile);
|
||||
|
||||
|
||||
|
||||
#
|
||||
# Add in very latest stuff
|
||||
#
|
||||
$grabcmd = "cd /tmp; wget --passive-ftp --tries 2 -q ftp://www.sec.noaa.gov/pub/latest/curind.txt";
|
||||
system "$grabcmd";
|
||||
%lmonstr = ( "Jan", 1, "Feb", 2, "Mar", 3, "Apr", 4, "May", 5, "Jun", 6, "Jul", 7, "Aug", 8, "Sep", 9, "Oct", 10, "Nov", 11, "Dec", 12);
|
||||
|
||||
@lval = ($lyear, $lmonstr{$lmon}, $ldom);
|
||||
open(TmpFile, "/tmp/curind.txt");
|
||||
while (<TmpFile>){
|
||||
chop;
|
||||
if ($_ =~ /^:Geomagnetic_Values: (\d{4}) (.*) (\d{1,2})/){
|
||||
$y = $_;
|
||||
$ms = $_;
|
||||
$d = $_;
|
||||
|
||||
$y =~ s/^:Geomagnetic_Values: (\d{4}) (.*) (\d{1,2})/\1/;
|
||||
$ms =~ s/^:Geomagnetic_Values: (\d{4}) (.*) (\d{1,2})/\2/;
|
||||
$d =~ s/^:Geomagnetic_Values: (\d{4}) (.*) (\d{1,2})/\3/;
|
||||
$tDate = $y*10000 + $lmonstr{$ms}*100 + $d;
|
||||
}
|
||||
if ($_ =~ /.*\d/) {
|
||||
$Line = $_;
|
||||
}
|
||||
|
||||
if ($_ =~ /^\s{1,}[0-9e\.\+\-]{2,}\s{1,}[0-9e\.\+\-]{2,}\s{1,}[0-9e\.\+\-]{2,}\s{1,}[0-9e\.\+\-]{2,}\s{1,}[0-9e\.\+\-]{2,}\s{1,}[BCMX]{1,}[0-9\.]{1,}\s{1,}[0-9-]{1,}/){
|
||||
|
||||
$FluxLine = $_;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
$Line =~ s/.*\s{3,}(.*)/\1/;
|
||||
($a, $b, $c, $d, $e, $f, $g, $h) = split(/\s{1,}/, $Line);
|
||||
if ($tDate > 0) {
|
||||
$TimeTag = $tDate*10 + 1; $Kp{$TimeTag} = $a;
|
||||
$TimeTag = $tDate*10 + 2; $Kp{$TimeTag} = $b;
|
||||
$TimeTag = $tDate*10 + 3; $Kp{$TimeTag} = $c;
|
||||
$TimeTag = $tDate*10 + 4; $Kp{$TimeTag} = $d;
|
||||
$TimeTag = $tDate*10 + 5; $Kp{$TimeTag} = $e;
|
||||
$TimeTag = $tDate*10 + 6; $Kp{$TimeTag} = $f;
|
||||
$TimeTag = $tDate*10 + 7; $Kp{$TimeTag} = $g;
|
||||
$TimeTag = $tDate*10 + 8; $Kp{$TimeTag} = $h;
|
||||
} else {
|
||||
$Kp{190001011} = 999;
|
||||
$Kp{190001012} = 999;
|
||||
$Kp{190001013} = 999;
|
||||
$Kp{190001014} = 999;
|
||||
$Kp{190001015} = 999;
|
||||
$Kp{190001016} = 999;
|
||||
$Kp{190001017} = 999;
|
||||
$Kp{190001018} = 999;
|
||||
}
|
||||
|
||||
|
||||
|
||||
$n = 0;
|
||||
%Result = ();
|
||||
foreach $key (reverse sort keys %Kp ) {
|
||||
if (($Kp{$key} >= 0)&&($n < 8)){
|
||||
$Result{$key} = $Kp{$key};
|
||||
++$n;
|
||||
}
|
||||
}
|
||||
|
||||
open(TmpFile, ">/tmp/LatestKp.txt");
|
||||
foreach $key (sort keys %Result ) {
|
||||
if ($Result{$key} > 10) { $Result{$key} = -1; }
|
||||
printf TmpFile "$key $Result{$key}\n";
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
$FluxLine =~ s/^\s*//;
|
||||
if ($FluxLine =~ /\d/){
|
||||
($E1, $E2, $P1, $P2, $P3, $Xray, $junk) = split(/\s{1,}/, $FluxLine);
|
||||
|
||||
} else {
|
||||
$E1 = -999;
|
||||
$E2 = -999;
|
||||
$P1 = -999;
|
||||
$P2 = -999;
|
||||
$P3 = -999;
|
||||
$Xray = "Z0.0";
|
||||
}
|
||||
|
||||
|
||||
printf TmpFile "$E1\n";
|
||||
printf TmpFile "$E2\n";
|
||||
printf TmpFile "$P1\n";
|
||||
printf TmpFile "$P2\n";
|
||||
printf TmpFile "$P3\n";
|
||||
printf TmpFile "$Xray\n";
|
||||
close(TmpFile);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#
|
||||
# sort(List);
|
||||
#
|
||||
# $Gif = "$List[$#List]";
|
||||
# $Latest = "http://swdcdb.kugi.kyoto-u.ac.jp/dstdir/dst1/q/$Gif";
|
||||
#
|
||||
#
|
||||
# $grabcmd = "/u/mgh/wwwgrab/wwwgrab $Latest /n/tmp/polar/$Gif";
|
||||
# system "$grabcmd";
|
||||
#
|
||||
#
|
||||
# system "convert -crop 0x0 /n/tmp/polar/${Gif} /n/tmp/polar/Dst.rle";
|
||||
# system "fant -s .5 .5 -o /n/tmp/polar/Dst2.rle /n/tmp/polar/Dst.rle";
|
||||
# system "convert -frame 4x4 -gamma 3 -crop 0x0 -colors 256 /n/tmp/polar/Dst2.rle /n/leadbelly/belly3/PolarNRT/CEPPAD/IPS/LatestDst.gif";
|
||||
#
|
||||
#
|
||||
#
|
||||
#
|
||||
#
|
||||
# open(TmpFile, ">/n/leadbelly/belly3/PolarNRT/CEPPAD/IPS/LatestDst.txt");
|
||||
# printf TmpFile "${Gif}\n";
|
||||
# close(TmpFile);
|
||||
#
|
||||
# system "touch /n/leadbelly/belly3/PolarNRT/CEPPAD/IPS/LatestDst.txt";
|
||||
|
||||
|
||||
sub year_month_day{
|
||||
|
||||
local($ldate_string, $ldow, $lmon, $ldom, $ltim, $lyear, %lmonstr, $tzone, @lval);
|
||||
|
||||
$ldate_string = &ctime(time);
|
||||
($ldow, $lmon, $ldom, $ltim, $lyear) = split(" ", $ldate_string);
|
||||
|
||||
%lmonstr = ( "Jan", 1, "Feb", 2, "Mar", 3, "Apr", 4, "May", 5, "Jun", 6, "Jul", 7, "Aug", 8, "Sep", 9, "Oct", 10, "Nov", 11, "Dec", 12);
|
||||
|
||||
@lval = ($lyear, $lmonstr{$lmon}, $ldom);
|
||||
|
||||
}
|
||||
|
34
wmspaceweather/wmSpaceWeather/Makefile
Normal file
34
wmspaceweather/wmSpaceWeather/Makefile
Normal file
|
@ -0,0 +1,34 @@
|
|||
CC = gcc
|
||||
CFLAGS = -O2 -Wall
|
||||
INCDIR = -I/usr/X11R6/include/X11
|
||||
DESTDIR= /usr/X11R6
|
||||
LIBDIR = -L/usr/X11R6/lib
|
||||
# for linux
|
||||
LIBS = -lXpm -lX11 -lXext
|
||||
# for Solaris
|
||||
# LIBS = -lXpm -lX11 -lXext -lsocket
|
||||
OBJS = wmSpaceWeather.o \
|
||||
../wmgeneral/wmgeneral.o
|
||||
|
||||
|
||||
.c.o:
|
||||
$(CC) $(COPTS) -D$(shell echo `uname -s`) -c $< -o $*.o $(INCDIR)
|
||||
|
||||
|
||||
all: wmSpaceWeather.o wmSpaceWeather
|
||||
|
||||
wmSpaceWeather.o: wmSpaceWeather_master.xpm wmSpaceWeather_mask.xbm
|
||||
wmSpaceWeather: $(OBJS)
|
||||
$(CC) $(COPTS) $(SYSTEM) -o wmSpaceWeather $^ $(INCDIR) $(LIBDIR) $(LIBS)
|
||||
|
||||
clean:
|
||||
for i in $(OBJS) ; do \
|
||||
rm -f $$i; \
|
||||
done
|
||||
rm -f wmSpaceWeather
|
||||
|
||||
install:: wmSpaceWeather
|
||||
install -s -m 0755 wmSpaceWeather $(DESTDIR)/bin
|
||||
install -m 0755 GetKp $(DESTDIR)/bin
|
||||
install -m 0644 wmSpaceWeather.1 $(DESTDIR)/man/man1
|
||||
|
BIN
wmspaceweather/wmSpaceWeather/wmSpaceWeather
Executable file
BIN
wmspaceweather/wmSpaceWeather/wmSpaceWeather
Executable file
Binary file not shown.
30
wmspaceweather/wmSpaceWeather/wmSpaceWeather.1
Normal file
30
wmspaceweather/wmSpaceWeather/wmSpaceWeather.1
Normal file
|
@ -0,0 +1,30 @@
|
|||
.TH WMSPACEWEATHER 1.1 "19 December 1998"
|
||||
.SH NAME
|
||||
WMSPACEWEATHER \- Dockable Space Weather Monitor
|
||||
.SH SYNOPSIS
|
||||
.B wmSpaceWeather
|
||||
[-h] [-display <Display>]
|
||||
.SH DESCRIPTION
|
||||
.PP
|
||||
wmSpaceWeather is a space weather monitor. The monitor shows: 2 relativistic electron
|
||||
and 3 relativistic proton flux levels at geosyncronous orbit (currently from the NOAA
|
||||
GOES spacecraft), current Solar Flare X-ray flux, and the last 8 3-hour Kp index values.
|
||||
.PP
|
||||
Large fluxes of relativistic (aka `Killer') electrons can cause harmful `deep-dielectric'
|
||||
charging/discharging events inside satellites. High proton fluxes (`Solar Energetic Proton' or
|
||||
SEP events) can cause single event upsets in satellite electronics. The Kp index is a measure
|
||||
of how disturbed the Earth's magnetic field has been over a 3-hour interval. Kp can range from
|
||||
0-9, where 0 is quiet and 9 is very disturbed. The Kp values shown are the 8 previous values
|
||||
(i.e. the last 24 hours). If the display is up-to-date, the LED next to the Kp
|
||||
bars will flash blue. If the display is not up-to-date, the LED will flash orange.
|
||||
.SH OPTIONS
|
||||
.TP
|
||||
.B \-h
|
||||
Display list of command-line options.
|
||||
.TP
|
||||
.B \-display [display]
|
||||
Use an alternate X Display.
|
||||
.SH BUGS
|
||||
Let me know if/when you find any.
|
||||
.SH AUTHOR
|
||||
Michael G. Henderson <mghenderson@lanl.gov>
|
680
wmspaceweather/wmSpaceWeather/wmSpaceWeather.c
Normal file
680
wmspaceweather/wmSpaceWeather/wmSpaceWeather.c
Normal file
|
@ -0,0 +1,680 @@
|
|||
/*
|
||||
*
|
||||
* wmSpaceWeather-1.04 (C) 1998 Mike Henderson (mghenderson@lanl.gov)
|
||||
*
|
||||
* - Its a Space Weather Monitor
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
* 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, 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 (see the file COPYING); if not, write to the
|
||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
* Boston, MA 02111-1307, USA
|
||||
*
|
||||
* ToDo:
|
||||
*
|
||||
* - The whole NOAA space weather www site is pretty screwed up! I currently have
|
||||
* to grab data from 2 separate files to get all that I need. But it seems that
|
||||
* sometimes one of the files shows less than it should. This seems to be related to
|
||||
* the way they update the 2 separate files... I will have to find some way of
|
||||
* making that more robust.
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
* Changes:
|
||||
*
|
||||
* Version 1.04 - released Feb 18, 1999
|
||||
* Added double click capability. Double clicking on mouse button 1 sends
|
||||
* URL (defined via ne command line option -url) to netscape.
|
||||
*
|
||||
* Version 1.03 - released Feb 11, 1999
|
||||
* Changed display a bit. When no data is
|
||||
* available, it now shows nothing (before it would
|
||||
* show false junk...). Modified Perl Script GetKp.
|
||||
*
|
||||
*
|
||||
* Version 1.02 - released Feb 8, 1999
|
||||
* bug fixes...
|
||||
*
|
||||
* Version 1.0b - released Dec 19, 1998
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Includes
|
||||
*/
|
||||
#include <stdio.h>
|
||||
#include <unistd.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <time.h>
|
||||
#include <X11/X.h>
|
||||
#include <X11/xpm.h>
|
||||
#include "../wmgeneral/wmgeneral.h"
|
||||
#include "wmSpaceWeather_master.xpm"
|
||||
#include "wmSpaceWeather_mask.xbm"
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Delay between refreshes (in microseconds)
|
||||
*/
|
||||
#define DELAY 10000L
|
||||
#define WMSPACEWEATHER_VERSION "1.04"
|
||||
|
||||
int GotFirstClick1, GotDoubleClick1;
|
||||
int GotFirstClick2, GotDoubleClick2;
|
||||
int GotFirstClick3, GotDoubleClick3;
|
||||
int DblClkDelay;
|
||||
char URL[1024];
|
||||
int ForceUpdate2;
|
||||
|
||||
|
||||
void ParseCMDLine(int argc, char *argv[]);
|
||||
void pressEvent(XButtonEvent *xev);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* main
|
||||
*/
|
||||
int main(int argc, char *argv[]) {
|
||||
|
||||
|
||||
struct tm *Time;
|
||||
XEvent event;
|
||||
int i, n, s, k, m, dt1, dt2;
|
||||
int Year, Month, Day, DayOfMonth, OldDayOfMonth;
|
||||
int Hours, Mins, Secs, OldSecs, xoff, D[10], xsize;
|
||||
long CurrentLocalTime;
|
||||
int height, UpToDate, LEDOn;
|
||||
double UT, TU, TU2, TU3, T0, gmst, hour24();
|
||||
|
||||
|
||||
double jd(), CurrentJD, LatestAvailJD, tim, DeltaT;
|
||||
long int TimeTag[8];
|
||||
int Kp[8] = { -1, -1, -1, -1, -1, -1, -1, -1 };
|
||||
double E1, E2, P1, P2, P3;
|
||||
char Xray[10], digit[2];
|
||||
FILE *fp;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Parse any command line arguments.
|
||||
*/
|
||||
ParseCMDLine(argc, argv);
|
||||
|
||||
|
||||
|
||||
openXwindow(argc, argv, wmSpaceWeather_master, wmSpaceWeather_mask_bits, wmSpaceWeather_mask_width, wmSpaceWeather_mask_height);
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Loop until we die
|
||||
*/
|
||||
n = 32000;
|
||||
s = 32000;
|
||||
m = 32000;
|
||||
dt1 = 32000;
|
||||
dt2 = 32000;
|
||||
LEDOn = 0;
|
||||
DblClkDelay = 32000;
|
||||
ForceUpdate2 = 1;
|
||||
while(1) {
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Keep track of # of seconds
|
||||
*/
|
||||
if (m > 100){
|
||||
|
||||
m = 0;
|
||||
++dt1;
|
||||
++dt2;
|
||||
|
||||
} else {
|
||||
|
||||
/*
|
||||
* Increment counter
|
||||
*/
|
||||
++m;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Double Click Delays
|
||||
* Keep track of click events. If Delay too long, set GotFirstClick's to False.
|
||||
*/
|
||||
if (DblClkDelay > 15) {
|
||||
|
||||
DblClkDelay = 0;
|
||||
GotFirstClick1 = 0; GotDoubleClick1 = 0;
|
||||
GotFirstClick2 = 0; GotDoubleClick2 = 0;
|
||||
GotFirstClick3 = 0; GotDoubleClick3 = 0;
|
||||
|
||||
} else {
|
||||
|
||||
++DblClkDelay;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Process any pending X events.
|
||||
*/
|
||||
while(XPending(display)){
|
||||
XNextEvent(display, &event);
|
||||
switch(event.type){
|
||||
case Expose:
|
||||
RedrawWindow();
|
||||
break;
|
||||
case ButtonPress:
|
||||
pressEvent(&event.xbutton);
|
||||
break;
|
||||
case ButtonRelease:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Redraw
|
||||
*/
|
||||
RedrawWindow();
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Check the Kp file every (approx.) 2 seconds.
|
||||
* Can significantly reduce this frequency later. But its
|
||||
* easier to debug this way...
|
||||
* Do this before trying to download again! The file may be there and it
|
||||
* may be Up-To-Date!
|
||||
*/
|
||||
if (dt2 > 2){
|
||||
|
||||
dt2 = 0;
|
||||
|
||||
/*
|
||||
* Compute Current Julian Date
|
||||
*/
|
||||
CurrentLocalTime = time(CurrentTime);
|
||||
Time = gmtime(&CurrentLocalTime);
|
||||
Year = Time->tm_year+1900;
|
||||
Month = Time->tm_mon+1;
|
||||
Day = Time->tm_mday;
|
||||
Hours = Time->tm_hour;
|
||||
Mins = Time->tm_min;
|
||||
Secs = Time->tm_sec;
|
||||
UT = (double)Hours + (double)Mins/60.0 + (double)Secs/3600.0;
|
||||
CurrentJD = jd(Year, Month, Day, UT);
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Read in Kp values
|
||||
*/
|
||||
if ((fp = fopen("/tmp/LatestKp.txt", "r")) != NULL){
|
||||
|
||||
for (i=0; i<8; ++i){
|
||||
fscanf(fp, "%ld %d", &TimeTag[i], &Kp[i]);
|
||||
if (Kp[i] < 0) TimeTag[i] = 190001011;
|
||||
}
|
||||
fscanf(fp, "%lf", &P1);
|
||||
fscanf(fp, "%lf", &P2);
|
||||
fscanf(fp, "%lf", &P3);
|
||||
fscanf(fp, "%lf", &E1);
|
||||
fscanf(fp, "%lf", &E2);
|
||||
fscanf(fp, "%10s", Xray);
|
||||
fclose(fp);
|
||||
|
||||
} else {
|
||||
|
||||
for (i=0; i<8; ++i) {
|
||||
Kp[i] = -1;
|
||||
TimeTag[i] = 190001011;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Compute Julian Date for latest available Kp
|
||||
*/
|
||||
tim = TimeTag[7];
|
||||
Year = tim/100000;
|
||||
tim -= Year*100000;
|
||||
Month = tim/1000;
|
||||
tim -= Month*1000;
|
||||
Day = tim/10;
|
||||
tim -= Day*10;
|
||||
UT = tim*3.0;
|
||||
LatestAvailJD = jd(Year, Month, Day, UT);
|
||||
|
||||
DeltaT = (CurrentJD - LatestAvailJD)*24.0;
|
||||
UpToDate = (DeltaT <= 3.0) ? 1 : 0;
|
||||
|
||||
if (!UpToDate){
|
||||
|
||||
/*
|
||||
* shift data back
|
||||
*/
|
||||
k = (int)(DeltaT/3.0);
|
||||
|
||||
if ((k>=0)&&(k<=7)){
|
||||
for (i=0; i<8-k; ++i) Kp[i] = Kp[i+k];
|
||||
for (i=8-k; i<8; ++i) Kp[i] = -1;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Update Kp Bars etc...
|
||||
*/
|
||||
if (n > 200){
|
||||
|
||||
n = 0;
|
||||
|
||||
copyXPMArea(5, 67, 47, 20, 5, 39);
|
||||
|
||||
for (i=0; i<8; ++i){
|
||||
if ((Kp[i] >= 0)&&(Kp[i] <= 9)){
|
||||
height = 2*Kp[i] + 1;
|
||||
copyXPMArea(53, 86-height+1, 5, height, 5+5*i+i, 58-height+1);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Update Xray display...
|
||||
*/
|
||||
if (Xray[0] != 'Z'){
|
||||
switch(Xray[0]){
|
||||
case 'B':
|
||||
copyXPMArea(66, 17, 5, 7, 37, 25);
|
||||
break;
|
||||
case 'C':
|
||||
copyXPMArea(72, 17, 5, 7, 37, 25);
|
||||
break;
|
||||
case 'M':
|
||||
copyXPMArea(78, 17, 5, 7, 37, 25);
|
||||
break;
|
||||
case 'X':
|
||||
copyXPMArea(84, 17, 5, 7, 37, 25);
|
||||
break;
|
||||
}
|
||||
digit[0] = Xray[1]; digit[1] = '\0';
|
||||
copyXPMArea(atoi(digit)*6+66, 25, 5, 7, 43, 25);
|
||||
copyXPMArea(127, 30, 3, 3, 49, 30);
|
||||
digit[0] = Xray[3]; digit[1] = '\0';
|
||||
copyXPMArea(atoi(digit)*6+66, 25, 5, 7, 53, 25);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Update E1 LED...
|
||||
*/
|
||||
if ((E1 > 0)&&(E1 < 1e6))
|
||||
copyXPMArea(66, 12, 4, 4, 25, 7);
|
||||
else if ((E1 >= 1e6)&&(E1 < 1e7))
|
||||
copyXPMArea(66, 7, 4, 4, 25, 7);
|
||||
else if (E1 > 1e7)
|
||||
copyXPMArea(66, 2, 4, 4, 25, 7);
|
||||
|
||||
|
||||
/*
|
||||
* Update E2 LED...
|
||||
*/
|
||||
if ((E2 > 0)&&(E2 < 1e3))
|
||||
copyXPMArea(66, 12, 4, 4, 31, 7);
|
||||
else if ((E2 >= 1e3)&&(E2 < 1e4))
|
||||
copyXPMArea(66, 7, 4, 4, 31, 7);
|
||||
else if (E2 > 1e4)
|
||||
copyXPMArea(66, 2, 4, 4, 31, 7);
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Update P1 LED...
|
||||
*/
|
||||
if ((P1 > 0)&&(P1 < 1e2))
|
||||
copyXPMArea(66, 12, 4, 4, 22, 16);
|
||||
else if ((P1 >= 1e2)&&(P1 < 1e3))
|
||||
copyXPMArea(66, 7, 4, 4, 22, 16);
|
||||
else if (P1 > 1e3)
|
||||
copyXPMArea(66, 2, 4, 4, 22, 16);
|
||||
|
||||
|
||||
/*
|
||||
* Update P2 LED...
|
||||
*/
|
||||
if ((P2 > 0)&&(P2 < 0.5e0))
|
||||
copyXPMArea(66, 12, 4, 4, 28, 16);
|
||||
else if ((P2 >= 0.5e0)&&(P2 < 0.5e1))
|
||||
copyXPMArea(66, 7, 4, 4, 28, 16);
|
||||
else if (P2 > 0.5e1)
|
||||
copyXPMArea(66, 2, 4, 4, 28, 16);
|
||||
|
||||
|
||||
/*
|
||||
* Update P3 LED...
|
||||
*/
|
||||
if ((P3 > 0)&&(P3 < 0.3e0))
|
||||
copyXPMArea(66, 12, 4, 4, 34, 16);
|
||||
else if ((P3 >= 0.3e0)&&(P3 < 0.3e1))
|
||||
copyXPMArea(66, 7, 4, 4, 34, 16);
|
||||
else if (P3 > 0.3e1)
|
||||
copyXPMArea(66, 2, 4, 4, 34, 16);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
} else {
|
||||
|
||||
/*
|
||||
* Increment counter
|
||||
*/
|
||||
++n;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Update the blinking LED which indicates whether or not the
|
||||
* display is up-to-date
|
||||
*/
|
||||
if (s > 20){
|
||||
|
||||
s = 0;
|
||||
|
||||
if (LEDOn){
|
||||
|
||||
if (UpToDate)
|
||||
copyXPMArea(65, 82, 4, 4, 54, 53);
|
||||
else
|
||||
copyXPMArea(65, 76, 4, 4, 54, 53);
|
||||
|
||||
LEDOn = 0;
|
||||
|
||||
} else {
|
||||
|
||||
if (UpToDate)
|
||||
copyXPMArea(60, 82, 4, 4, 54, 53);
|
||||
else
|
||||
copyXPMArea(60, 76, 4, 4, 54, 53);
|
||||
|
||||
LEDOn = 1;
|
||||
|
||||
}
|
||||
} else {
|
||||
|
||||
/*
|
||||
* Increment counter
|
||||
*/
|
||||
++s;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Check every 5 min if the values are not up to date...
|
||||
*/
|
||||
if (((!UpToDate)&&(dt1 > 300))||ForceUpdate2){
|
||||
|
||||
dt1 = 0;
|
||||
|
||||
/*
|
||||
* Execute Perl script to grab the Latest Kp values
|
||||
*/
|
||||
system("GetKp &");
|
||||
|
||||
ForceUpdate2 = 0;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Wait for next update
|
||||
*/
|
||||
usleep(DELAY);
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* ParseCMDLine()
|
||||
*/
|
||||
void ParseCMDLine(int argc, char *argv[]) {
|
||||
|
||||
int i;
|
||||
|
||||
for (i = 1; i < argc; i++) {
|
||||
|
||||
if (!strcmp(argv[i], "-display")){
|
||||
|
||||
++i;
|
||||
|
||||
} else if ((!strcmp(argv[i], "-url"))||(!strcmp(argv[i], "-u"))){
|
||||
|
||||
strcpy(URL, argv[++i]);
|
||||
|
||||
} else {
|
||||
|
||||
printf("\nwmSpaceWeather version: %s\n", WMSPACEWEATHER_VERSION);
|
||||
printf("\nusage: wmSpaceWeather [-h] [-url <www URL>]\n\n");
|
||||
printf("\t-url <URL>\tURL to send to Netscape with Button1 double click.\n\n");
|
||||
printf("\t-h\t\tDisplay help screen.\n\n");
|
||||
exit(1);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Compute the Julian Day number for the given date.
|
||||
* Julian Date is the number of days since noon of Jan 1 4713 B.C.
|
||||
*/
|
||||
double jd(ny, nm, nd, UT)
|
||||
int ny, nm, nd;
|
||||
double UT;
|
||||
{
|
||||
double A, B, C, D, JD, MJD, day;
|
||||
|
||||
day = nd + UT/24.0;
|
||||
|
||||
|
||||
if ((nm == 1) || (nm == 2)){
|
||||
ny = ny - 1;
|
||||
nm = nm + 12;
|
||||
}
|
||||
|
||||
if (((double)ny+nm/12.0+day/365.25)>=(1582.0+10.0/12.0+15.0/365.25)){
|
||||
A = ((int)(ny / 100.0));
|
||||
B = 2.0 - A + (int)(A/4.0);
|
||||
}
|
||||
else{
|
||||
B = 0.0;
|
||||
}
|
||||
if (ny < 0.0){
|
||||
C = (int)((365.25*(double)ny) - 0.75);
|
||||
}
|
||||
else{
|
||||
C = (int)(365.25*(double)ny);
|
||||
}
|
||||
|
||||
D = (int)(30.6001*(double)(nm+1));
|
||||
|
||||
|
||||
JD = B + C + D + day + 1720994.5;
|
||||
return(JD);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* This routine handles button presses.
|
||||
*/
|
||||
void pressEvent(XButtonEvent *xev){
|
||||
|
||||
char Command[512];
|
||||
|
||||
|
||||
DblClkDelay = 0;
|
||||
if ((xev->button == Button1) && (xev->type == ButtonPress)){
|
||||
if (GotFirstClick1) GotDoubleClick1 = 1;
|
||||
else GotFirstClick1 = 1;
|
||||
} else if ((xev->button == Button2) && (xev->type == ButtonPress)){
|
||||
if (GotFirstClick2) GotDoubleClick2 = 1;
|
||||
else GotFirstClick2 = 1;
|
||||
} else if ((xev->button == Button3) && (xev->type == ButtonPress)){
|
||||
if (GotFirstClick3) GotDoubleClick3 = 1;
|
||||
else GotFirstClick3 = 1;
|
||||
}
|
||||
|
||||
/*
|
||||
* We got a double click on Mouse Button1 (i.e. the left one)
|
||||
*/
|
||||
if (GotDoubleClick1) {
|
||||
GotFirstClick1 = 0;
|
||||
GotDoubleClick1 = 0;
|
||||
sprintf(Command, "netscape -remote 'openURL(%s)' || netscape '%s' &", URL, URL);
|
||||
system(Command);
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* We got a double click on Mouse Button2 (i.e. the left one)
|
||||
*/
|
||||
if (GotDoubleClick2) {
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* We got a double click on Mouse Button3 (i.e. the left one)
|
||||
*/
|
||||
if (GotDoubleClick3) {
|
||||
GotFirstClick3 = 0;
|
||||
GotDoubleClick3 = 0;
|
||||
ForceUpdate2 = 1;
|
||||
}
|
||||
|
||||
|
||||
|
||||
return;
|
||||
|
||||
}
|
||||
|
BIN
wmspaceweather/wmSpaceWeather/wmSpaceWeather.o
Normal file
BIN
wmspaceweather/wmSpaceWeather/wmSpaceWeather.o
Normal file
Binary file not shown.
38
wmspaceweather/wmSpaceWeather/wmSpaceWeather_mask.xbm
Normal file
38
wmspaceweather/wmSpaceWeather/wmSpaceWeather_mask.xbm
Normal file
|
@ -0,0 +1,38 @@
|
|||
#define wmSpaceWeather_mask_width 64
|
||||
#define wmSpaceWeather_mask_height 64
|
||||
static char wmSpaceWeather_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,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,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};
|
BIN
wmspaceweather/wmSpaceWeather/wmSpaceWeather_master.gif
Normal file
BIN
wmspaceweather/wmSpaceWeather/wmSpaceWeather_master.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.3 KiB |
119
wmspaceweather/wmSpaceWeather/wmSpaceWeather_master.xpm
Normal file
119
wmspaceweather/wmSpaceWeather/wmSpaceWeather_master.xpm
Normal file
|
@ -0,0 +1,119 @@
|
|||
/* XPM */
|
||||
static char *wmSpaceWeather_master[] = {
|
||||
/* width height num_colors chars_per_pixel */
|
||||
" 153 91 21 1",
|
||||
/* colors */
|
||||
". c #000000",
|
||||
"# c #181818",
|
||||
"a c #201e1f",
|
||||
"b c #3c3c00",
|
||||
"c c #202020",
|
||||
"d c #00146f",
|
||||
"e c #00475d",
|
||||
"f c #4f0000",
|
||||
"g c #4e3300",
|
||||
"h c #3a75ff",
|
||||
"i c #00ff00",
|
||||
"j c #00a5dc",
|
||||
"k c #3aa6ff",
|
||||
"l c #ff0000",
|
||||
"m c #ff7700",
|
||||
"n c #cfcf00",
|
||||
"o c #ffff00",
|
||||
"p c #98a0a8",
|
||||
"q c #999aff",
|
||||
"r c #c8c8c8",
|
||||
"s c #666666",
|
||||
/* pixels */
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp..alla...................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp..lrll...................................................................................",
|
||||
"pppp........................................................pppp..llll...................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..alla...................................................................................",
|
||||
"pppp.accccccqqqcaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.ccqqqcccccaaaaaaaaaaassaaaassaaaaaaaaaaaaaaaaaaaaaaaaarpppp..aooa.assa..............................................................................",
|
||||
"pppp.cqcccqccccaaqaaaaaaasrssaasrssaaaaaaaaaaaaaaaaaaaaaaaarpppp..oroo.srss..............................................................................",
|
||||
"pppp.cqqqqqccccaaaaaaaaaassssaassssaaaaaaaaaaaaaaaaaaaaaaaarpppp..oooo.ssss..............................................................................",
|
||||
"pppp.cqccccccccaaqaaaaaaaassaaaassaaaaaaaaaaaaaaaaaaaaaaaaarpppp..aooa.assa..............................................................................",
|
||||
"pppp.ccqqqcccccaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.ccccccccccaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..aiia...................................................................................",
|
||||
"pppp.ccccccccccaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..irii...................................................................................",
|
||||
"pppp.ccccccccqcaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..iiii...................................................................................",
|
||||
"pppp.cccccccqqqaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..aiia...................................................................................",
|
||||
"pppp.cqcqqcccqcaaaaaaaassaaaassaaaassaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.cqqccqccccaaqaaaasrssaasrssaasrssaaaaaaaaaaaaaaaaaaaaarpppp..iiii###ooo##m###m#l###l................................................................",
|
||||
"pppp.cqqccqccccaaaaaaassssaassssaassssaaaaaaaaaaaaaaaaaaaaarpppp..#i##i#o###o#m###m#l###l................................................................",
|
||||
"pppp.cqcqqcccccaaqaaaaassaaaassaaaassaaaaaaaaaaaaaaaaaaaaaarpppp..#i##i#o#####mm#mm##l#l#................................................................",
|
||||
"pppp.cqccccccccaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..#iii##o#####m#m#m###l##................................................................",
|
||||
"pppp.cqccccccccaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..#i##i#o#####m###m##l#l#................................................................",
|
||||
"pppp.cqccccccccaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..#i##i#o###o#m###m#l###l................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..iiii###ooo##m###m#l###l................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aqaaaqaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..##k#####k####kkk##kkkkk####k##kkkkk###kk##kkkkk##kkk###kkk######.......................",
|
||||
"pppp.aqaaaqaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..#k#k###kk###k###k#####k###kk##k######k########k#k###k#k###k#####.......................",
|
||||
"pppp.aaqaqaaaaaqaqqaaaqqqaaqaaaqaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..k###k#k#k#######k####k###k#k##k#kk##k########k##k###k#k##kk#####.......................",
|
||||
"pppp.aaaqaaaqqaqqaaqaaaaaqaqaaaqaqaaaaaaaaaaaaaaaaaaaaaaaaarpppp..k###k###k#####kk####kk##k##k##kk##k#k#kk#####k###kkk###kk#k#####.......................",
|
||||
"pppp.aaqaqaaaaaqaaaaaaqqqqaqaaqqaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..k###k###k####k########k#kkkkk#####k#kk##k###k###k###k#####k#####.......................",
|
||||
"pppp.aqaaaqaaaaqaaaaaqaaaqaaqqaqaqaaaaaaaaaaaaaaaaaaaaaaaaarpppp..#k#k####k###k#####k###k####k##k###k#k###k##k####k###k####k####k#.......................",
|
||||
"pppp.aqaaaqaaaaqaaaaaaqqqqaaaaaqaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..##k###kkkkk#kkkkk##kkk#####k###kkk###kkk###k#####kkk###kk####kkk.......................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaqaaaqaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp..##############################################################k#.......................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaqqqaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppprrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrpppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
"pppp........................................................pppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.fffffafffffafffffafffffafffffafffffafffffafffffaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.fffffafffffafffffafffffafffffafffffafffffafffffaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.fffffafffffafffffafffffafffffafffffafffffafffffaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.fffffafffffafffffafffffafffffafffffafffffafffffaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.fffffafffffafffffafffffafffffafffffafffffafffffaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.bbbbbabbbbbabbbbbabbbbbabbbbbabbbbbabbbbbabbbbbaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaaaaaaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaahhaarpppp.........................................................................................",
|
||||
"pppp.eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaahrhharpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaahhhharpppp.........................................................................................",
|
||||
"pppp.eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaaahhaarpppp.........................................................................................",
|
||||
"pppp.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarpppp.........................................................................................",
|
||||
"pppp.eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaaaaaaarpppp.........................................................................................",
|
||||
"pppprrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrpppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
"pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp.........................................................................................",
|
||||
".........................................................................................................................................................",
|
||||
".........................................................................................................................................................",
|
||||
".........................................................................................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.....................................................................................................",
|
||||
".....fffffafffffafffffafffffafffffafffffafffffafffff.lllll...............................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa...............................................................................................",
|
||||
".....fffffafffffafffffafffffafffffafffffafffffafffff.lllll...............................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa...............................................................................................",
|
||||
".....fffffafffffafffffafffffafffffafffffafffffafffff.lllll...............................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa...............................................................................................",
|
||||
".....fffffafffffafffffafffffafffffafffffafffffafffff.lllll...............................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa...............................................................................................",
|
||||
".....fffffafffffafffffafffffafffffafffffafffffafffff.lllll..amma.agga....................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa..mrmm.grgg....................................................................................",
|
||||
".....bbbbbabbbbbabbbbbabbbbbabbbbbabbbbbabbbbbabbbbb.nnnnn..mmmm.gggg....................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa..amma.agga....................................................................................",
|
||||
".....eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeee.jjjjj..aaaa.aaaa....................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa..aaaa.aaaa....................................................................................",
|
||||
".....eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeee.jjjjj..ahha.adda....................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa..hrhh.drdd....................................................................................",
|
||||
".....eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeee.jjjjj..hhhh.dddd....................................................................................",
|
||||
".....aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaa..ahha.adda....................................................................................",
|
||||
".....eeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeeeaeeeee.jjjjj...............................................................................................",
|
||||
".........................................................................................................................................................",
|
||||
".........................................................................................................................................................",
|
||||
".........................................................................................................................................................",
|
||||
"cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc............................................................................."
|
||||
};
|
366
wmspaceweather/wmgeneral/wmgeneral.c
Normal file
366
wmspaceweather/wmgeneral/wmgeneral.c
Normal file
|
@ -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 <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
#include <ctype.h>
|
||||
#include <stdarg.h>
|
||||
|
||||
#include <X11/Xlib.h>
|
||||
#include <X11/xpm.h>
|
||||
#include <X11/extensions/shape.h>
|
||||
|
||||
#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<MAX_MOUSE_REGION && !found; i++) {
|
||||
if (mouse_region[i].enable &&
|
||||
x <= mouse_region[i].right &&
|
||||
x >= 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);
|
||||
|
||||
}
|
50
wmspaceweather/wmgeneral/wmgeneral.h
Normal file
50
wmspaceweather/wmgeneral/wmgeneral.h
Normal file
|
@ -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
|
BIN
wmspaceweather/wmgeneral/wmgeneral.o
Normal file
BIN
wmspaceweather/wmgeneral/wmgeneral.o
Normal file
Binary file not shown.
Loading…
Reference in a new issue