From deeb9c4852c699ad26a5d81cdf13176cb6c2e114 Mon Sep 17 00:00:00 2001 From: k clair Date: Tue, 9 Oct 2012 12:55:01 -0700 Subject: add previously generated debian packaging files --- ping-0.2/AUTHORS | 8 + ping-0.2/COPYING | 339 +++++++++++++++++++++ ping-0.2/MANIFEST.in | 4 + ping-0.2/README | 9 + ping-0.2/build/lib.linux-x86_64-2.6/ping.py | 273 +++++++++++++++++ ping-0.2/build/lib/ping.py | 273 +++++++++++++++++ ping-0.2/debian/README.Debian | 6 + ping-0.2/debian/README.source | 9 + ping-0.2/debian/changelog | 5 + ping-0.2/debian/compat | 1 + ping-0.2/debian/control | 23 ++ ping-0.2/debian/copyright | 42 +++ ping-0.2/debian/docs | 1 + ping-0.2/debian/emacsen-install.ex | 45 +++ ping-0.2/debian/emacsen-remove.ex | 15 + ping-0.2/debian/emacsen-startup.ex | 25 ++ ping-0.2/debian/files | 1 + ping-0.2/debian/init.d.ex | 154 ++++++++++ ping-0.2/debian/manpage.1.ex | 59 ++++ ping-0.2/debian/manpage.sgml.ex | 154 ++++++++++ ping-0.2/debian/manpage.xml.ex | 291 ++++++++++++++++++ ping-0.2/debian/menu.ex | 2 + ping-0.2/debian/postinst.ex | 39 +++ ping-0.2/debian/postrm.ex | 37 +++ ping-0.2/debian/preinst.ex | 35 +++ ping-0.2/debian/prerm.ex | 38 +++ ping-0.2/debian/python-ping.cron.d.ex | 4 + ping-0.2/debian/python-ping.debhelper.log | 45 +++ ping-0.2/debian/python-ping.default.ex | 10 + ping-0.2/debian/python-ping.doc-base.EX | 20 ++ ping-0.2/debian/python-ping.postinst.debhelper | 5 + ping-0.2/debian/python-ping.prerm.debhelper | 5 + ping-0.2/debian/python-ping.substvars | 4 + ping-0.2/debian/python-ping/DEBIAN/control | 20 ++ ping-0.2/debian/python-ping/DEBIAN/md5sums | 7 + ping-0.2/debian/python-ping/DEBIAN/postinst | 7 + ping-0.2/debian/python-ping/DEBIAN/prerm | 7 + .../python-ping/usr/share/doc/python-ping/README | 9 + .../usr/share/doc/python-ping/README.Debian | 6 + .../usr/share/doc/python-ping/changelog.Debian.gz | Bin 0 -> 176 bytes .../usr/share/doc/python-ping/copyright | 42 +++ .../usr/share/pyshared/ping-0.2.egg-info | 31 ++ .../debian/python-ping/usr/share/pyshared/ping.py | 273 +++++++++++++++++ .../usr/share/python-support/python-ping.public | 2 + ping-0.2/debian/rules | 13 + ping-0.2/debian/source/format | 1 + ping-0.2/debian/watch.ex | 23 ++ ping-0.2/ping.py | 273 +++++++++++++++++ ping-0.2/ping.pyc | Bin 0 -> 7966 bytes ping-0.2/setup.py | 53 ++++ python-ping_0.2-1.debian.tar.gz | Bin 0 -> 11225 bytes python-ping_0.2-1.dsc | 39 +++ python-ping_0.2-1_all.deb | Bin 0 -> 6356 bytes python-ping_0.2-1_amd64.build | 145 +++++++++ python-ping_0.2-1_amd64.changes | 53 ++++ python-ping_0.2.orig.tar.gz | Bin 0 -> 10979 bytes 56 files changed, 2985 insertions(+) create mode 100644 ping-0.2/AUTHORS create mode 100644 ping-0.2/COPYING create mode 100644 ping-0.2/MANIFEST.in create mode 100644 ping-0.2/README create mode 100644 ping-0.2/build/lib.linux-x86_64-2.6/ping.py create mode 100644 ping-0.2/build/lib/ping.py create mode 100644 ping-0.2/debian/README.Debian create mode 100644 ping-0.2/debian/README.source create mode 100644 ping-0.2/debian/changelog create mode 100644 ping-0.2/debian/compat create mode 100644 ping-0.2/debian/control create mode 100644 ping-0.2/debian/copyright create mode 100644 ping-0.2/debian/docs create mode 100644 ping-0.2/debian/emacsen-install.ex create mode 100644 ping-0.2/debian/emacsen-remove.ex create mode 100644 ping-0.2/debian/emacsen-startup.ex create mode 100644 ping-0.2/debian/files create mode 100644 ping-0.2/debian/init.d.ex create mode 100644 ping-0.2/debian/manpage.1.ex create mode 100644 ping-0.2/debian/manpage.sgml.ex create mode 100644 ping-0.2/debian/manpage.xml.ex create mode 100644 ping-0.2/debian/menu.ex create mode 100644 ping-0.2/debian/postinst.ex create mode 100644 ping-0.2/debian/postrm.ex create mode 100644 ping-0.2/debian/preinst.ex create mode 100644 ping-0.2/debian/prerm.ex create mode 100644 ping-0.2/debian/python-ping.cron.d.ex create mode 100644 ping-0.2/debian/python-ping.debhelper.log create mode 100644 ping-0.2/debian/python-ping.default.ex create mode 100644 ping-0.2/debian/python-ping.doc-base.EX create mode 100644 ping-0.2/debian/python-ping.postinst.debhelper create mode 100644 ping-0.2/debian/python-ping.prerm.debhelper create mode 100644 ping-0.2/debian/python-ping.substvars create mode 100644 ping-0.2/debian/python-ping/DEBIAN/control create mode 100644 ping-0.2/debian/python-ping/DEBIAN/md5sums create mode 100755 ping-0.2/debian/python-ping/DEBIAN/postinst create mode 100755 ping-0.2/debian/python-ping/DEBIAN/prerm create mode 100644 ping-0.2/debian/python-ping/usr/share/doc/python-ping/README create mode 100644 ping-0.2/debian/python-ping/usr/share/doc/python-ping/README.Debian create mode 100644 ping-0.2/debian/python-ping/usr/share/doc/python-ping/changelog.Debian.gz create mode 100644 ping-0.2/debian/python-ping/usr/share/doc/python-ping/copyright create mode 100644 ping-0.2/debian/python-ping/usr/share/pyshared/ping-0.2.egg-info create mode 100644 ping-0.2/debian/python-ping/usr/share/pyshared/ping.py create mode 100644 ping-0.2/debian/python-ping/usr/share/python-support/python-ping.public create mode 100755 ping-0.2/debian/rules create mode 100644 ping-0.2/debian/source/format create mode 100644 ping-0.2/debian/watch.ex create mode 100644 ping-0.2/ping.py create mode 100644 ping-0.2/ping.pyc create mode 100644 ping-0.2/setup.py create mode 100644 python-ping_0.2-1.debian.tar.gz create mode 100644 python-ping_0.2-1.dsc create mode 100644 python-ping_0.2-1_all.deb create mode 100644 python-ping_0.2-1_amd64.build create mode 100644 python-ping_0.2-1_amd64.changes create mode 100644 python-ping_0.2.orig.tar.gz diff --git a/ping-0.2/AUTHORS b/ping-0.2/AUTHORS new file mode 100644 index 0000000..6ad0f14 --- /dev/null +++ b/ping-0.2/AUTHORS @@ -0,0 +1,8 @@ +This library is a fork of the python-ping library created by George Notaras +and released under the GNU GPLv2 license. + +This fork was created by Pierre Bourdon . + +Contributors: + - Georgi Kolev contributed a way to specify the packet size and a quiet ping + function returning statistics (avg and max round trip time) diff --git a/ping-0.2/COPYING b/ping-0.2/COPYING new file mode 100644 index 0000000..d511905 --- /dev/null +++ b/ping-0.2/COPYING @@ -0,0 +1,339 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 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 Lesser 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 + + 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) + + 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., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 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) year 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 Lesser General +Public License instead of this License. diff --git a/ping-0.2/MANIFEST.in b/ping-0.2/MANIFEST.in new file mode 100644 index 0000000..7009aab --- /dev/null +++ b/ping-0.2/MANIFEST.in @@ -0,0 +1,4 @@ +include README +include COPYING +include AUTHORS +include setup.py diff --git a/ping-0.2/README b/ping-0.2/README new file mode 100644 index 0000000..b3cccd7 --- /dev/null +++ b/ping-0.2/README @@ -0,0 +1,9 @@ +This library is a fork of George Notaras' python-ping library, which is +an implementation of the standard ICMP ping in pure Python. + +As it uses raw ICMP sockets, you need to be root to use the functions +exported by the ping module. + +This fork by Pierre Bourdon adds a setup.py file in order to permit an +easier distribution of the package. The license of the library remains +unchanged (GPLv2), see COPYING. diff --git a/ping-0.2/build/lib.linux-x86_64-2.6/ping.py b/ping-0.2/build/lib.linux-x86_64-2.6/ping.py new file mode 100644 index 0000000..8c4a4bd --- /dev/null +++ b/ping-0.2/build/lib.linux-x86_64-2.6/ping.py @@ -0,0 +1,273 @@ +#!/usr/bin/env python + +""" + A pure python ping implementation using raw socket. + + + Note that ICMP messages can only be sent from processes running as root. + + + Derived from ping.c distributed in Linux's netkit. That code is + copyright (c) 1989 by The Regents of the University of California. + That code is in turn derived from code written by Mike Muuss of the + US Army Ballistic Research Laboratory in December, 1983 and + placed in the public domain. They have my thanks. + + Bugs are naturally mine. I'd be glad to hear about them. There are + certainly word - size dependenceies here. + + Copyright (c) Matthew Dixon Cowles, . + Distributable under the terms of the GNU General Public License + version 2. Provided with no warranties of any sort. + + Original Version from Matthew Dixon Cowles: + -> ftp://ftp.visi.com/users/mdc/ping.py + + Rewrite by Jens Diemer: + -> http://www.python-forum.de/post-69122.html#69122 + + Rewrite by George Notaras: + -> http://www.g-loaded.eu/2009/10/30/python-ping/ + + Fork by Pierre Bourdon: + -> http://bitbucket.org/delroth/python-ping/ + + Revision history + ~~~~~~~~~~~~~~~~ + + November 22, 1997 + ----------------- + Initial hack. Doesn't do much, but rather than try to guess + what features I (or others) will want in the future, I've only + put in what I need now. + + December 16, 1997 + ----------------- + For some reason, the checksum bytes are in the wrong order when + this is run under Solaris 2.X for SPARC but it works right under + Linux x86. Since I don't know just what's wrong, I'll swap the + bytes always and then do an htons(). + + December 4, 2000 + ---------------- + Changed the struct.pack() calls to pack the checksum and ID as + unsigned. My thanks to Jerome Poincheval for the fix. + + May 30, 2007 + ------------ + little rewrite by Jens Diemer: + - change socket asterisk import to a normal import + - replace time.time() with time.clock() + - delete "return None" (or change to "return" only) + - in checksum() rename "str" to "source_string" + + November 8, 2009 + ---------------- + Improved compatibility with GNU/Linux systems. + + Fixes by: + * George Notaras -- http://www.g-loaded.eu + Reported by: + * Chris Hallman -- http://cdhallman.blogspot.com + + Changes in this release: + - Re-use time.time() instead of time.clock(). The 2007 implementation + worked only under Microsoft Windows. Failed on GNU/Linux. + time.clock() behaves differently under the two OSes[1]. + + [1] http://docs.python.org/library/time.html#time.clock + + September 25, 2010 + ------------------ + Little modifications by Georgi Kolev: + - Added quiet_ping function. + - returns percent lost packages, max round trip time, avrg round trip + time + - Added packet size to verbose_ping & quiet_ping functions. + - Bump up version to 0.2 + +""" + +__version__ = "0.2" + +import os +import select +import socket +import struct +import sys +import time + +# From /usr/include/linux/icmp.h; your milage may vary. +ICMP_ECHO_REQUEST = 8 # Seems to be the same on Solaris. + + +def checksum(source_string): + """ + I'm not too confident that this is right but testing seems + to suggest that it gives the same answers as in_cksum in ping.c + """ + sum = 0 + count_to = (len(source_string) / 2) * 2 + for count in xrange(0, count_to, 2): + this = ord(source_string[count + 1]) * 256 + ord(source_string[count]) + sum = sum + this + sum = sum & 0xffffffff # Necessary? + + if count_to < len(source_string): + sum = sum + ord(source_string[len(source_string) - 1]) + sum = sum & 0xffffffff # Necessary? + + sum = (sum >> 16) + (sum & 0xffff) + sum = sum + (sum >> 16) + answer = ~sum + answer = answer & 0xffff + + # Swap bytes. Bugger me if I know why. + answer = answer >> 8 | (answer << 8 & 0xff00) + + return answer + + +def receive_one_ping(my_socket, id, timeout): + """ + Receive the ping from the socket. + """ + time_left = timeout + while True: + started_select = time.time() + what_ready = select.select([my_socket], [], [], time_left) + how_long_in_select = (time.time() - started_select) + if what_ready[0] == []: # Timeout + return + + time_received = time.time() + received_packet, addr = my_socket.recvfrom(1024) + icmpHeader = received_packet[20:28] + type, code, checksum, packet_id, sequence = struct.unpack( + "bbHHh", icmpHeader + ) + if packet_id == id: + bytes = struct.calcsize("d") + time_sent = struct.unpack("d", received_packet[28:28 + bytes])[0] + return time_received - time_sent + + time_left = time_left - how_long_in_select + if time_left <= 0: + return + + +def send_one_ping(my_socket, dest_addr, id, psize): + """ + Send one ping to the given >dest_addr<. + """ + dest_addr = socket.gethostbyname(dest_addr) + + # Remove header size from packet size + psize = psize - 8 + + # Header is type (8), code (8), checksum (16), id (16), sequence (16) + my_checksum = 0 + + # Make a dummy heder with a 0 checksum. + header = struct.pack("bbHHh", ICMP_ECHO_REQUEST, 0, my_checksum, id, 1) + bytes = struct.calcsize("d") + data = (psize - bytes) * "Q" + data = struct.pack("d", time.time()) + data + + # Calculate the checksum on the data and the dummy header. + my_checksum = checksum(header + data) + + # Now that we have the right checksum, we put that in. It's just easier + # to make up a new header than to stuff it into the dummy. + header = struct.pack( + "bbHHh", ICMP_ECHO_REQUEST, 0, socket.htons(my_checksum), id, 1 + ) + packet = header + data + my_socket.sendto(packet, (dest_addr, 1)) # Don't know about the 1 + + +def do_one(dest_addr, timeout, psize): + """ + Returns either the delay (in seconds) or none on timeout. + """ + icmp = socket.getprotobyname("icmp") + try: + my_socket = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp) + except socket.error, (errno, msg): + if errno == 1: + # Operation not permitted + msg = msg + ( + " - Note that ICMP messages can only be sent from processes" + " running as root." + ) + raise socket.error(msg) + raise # raise the original error + + my_id = os.getpid() & 0xFFFF + + send_one_ping(my_socket, dest_addr, my_id, psize) + delay = receive_one_ping(my_socket, my_id, timeout) + + my_socket.close() + return delay + + +def verbose_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + """ + for i in xrange(count): + print "ping %s with ..." % dest_addr, + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay == None: + print "failed. (timeout within %ssec.)" % timeout + else: + delay = delay * 1000 + print "get ping in %0.4fms" % delay + print + + +def quiet_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + Returns `percent' lost packages, `max' round trip time + and `avrg' round trip time. + """ + mrtt = None + artt = None + lost = 0 + plist = [] + + for i in xrange(count): + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay != None: + delay = delay * 1000 + plist.append(delay) + + # Find lost package percent + percent_lost = 100 - (len(plist) * 100 / count) + + # Find max and avg round trip time + if plist: + mrtt = max(plist) + artt = sum(plist) / len(plist) + + return percent_lost, mrtt, artt + +if __name__ == '__main__': + verbose_ping("heise.de") + verbose_ping("google.com") + verbose_ping("a-test-url-taht-is-not-available.com") + verbose_ping("192.168.1.1") diff --git a/ping-0.2/build/lib/ping.py b/ping-0.2/build/lib/ping.py new file mode 100644 index 0000000..8c4a4bd --- /dev/null +++ b/ping-0.2/build/lib/ping.py @@ -0,0 +1,273 @@ +#!/usr/bin/env python + +""" + A pure python ping implementation using raw socket. + + + Note that ICMP messages can only be sent from processes running as root. + + + Derived from ping.c distributed in Linux's netkit. That code is + copyright (c) 1989 by The Regents of the University of California. + That code is in turn derived from code written by Mike Muuss of the + US Army Ballistic Research Laboratory in December, 1983 and + placed in the public domain. They have my thanks. + + Bugs are naturally mine. I'd be glad to hear about them. There are + certainly word - size dependenceies here. + + Copyright (c) Matthew Dixon Cowles, . + Distributable under the terms of the GNU General Public License + version 2. Provided with no warranties of any sort. + + Original Version from Matthew Dixon Cowles: + -> ftp://ftp.visi.com/users/mdc/ping.py + + Rewrite by Jens Diemer: + -> http://www.python-forum.de/post-69122.html#69122 + + Rewrite by George Notaras: + -> http://www.g-loaded.eu/2009/10/30/python-ping/ + + Fork by Pierre Bourdon: + -> http://bitbucket.org/delroth/python-ping/ + + Revision history + ~~~~~~~~~~~~~~~~ + + November 22, 1997 + ----------------- + Initial hack. Doesn't do much, but rather than try to guess + what features I (or others) will want in the future, I've only + put in what I need now. + + December 16, 1997 + ----------------- + For some reason, the checksum bytes are in the wrong order when + this is run under Solaris 2.X for SPARC but it works right under + Linux x86. Since I don't know just what's wrong, I'll swap the + bytes always and then do an htons(). + + December 4, 2000 + ---------------- + Changed the struct.pack() calls to pack the checksum and ID as + unsigned. My thanks to Jerome Poincheval for the fix. + + May 30, 2007 + ------------ + little rewrite by Jens Diemer: + - change socket asterisk import to a normal import + - replace time.time() with time.clock() + - delete "return None" (or change to "return" only) + - in checksum() rename "str" to "source_string" + + November 8, 2009 + ---------------- + Improved compatibility with GNU/Linux systems. + + Fixes by: + * George Notaras -- http://www.g-loaded.eu + Reported by: + * Chris Hallman -- http://cdhallman.blogspot.com + + Changes in this release: + - Re-use time.time() instead of time.clock(). The 2007 implementation + worked only under Microsoft Windows. Failed on GNU/Linux. + time.clock() behaves differently under the two OSes[1]. + + [1] http://docs.python.org/library/time.html#time.clock + + September 25, 2010 + ------------------ + Little modifications by Georgi Kolev: + - Added quiet_ping function. + - returns percent lost packages, max round trip time, avrg round trip + time + - Added packet size to verbose_ping & quiet_ping functions. + - Bump up version to 0.2 + +""" + +__version__ = "0.2" + +import os +import select +import socket +import struct +import sys +import time + +# From /usr/include/linux/icmp.h; your milage may vary. +ICMP_ECHO_REQUEST = 8 # Seems to be the same on Solaris. + + +def checksum(source_string): + """ + I'm not too confident that this is right but testing seems + to suggest that it gives the same answers as in_cksum in ping.c + """ + sum = 0 + count_to = (len(source_string) / 2) * 2 + for count in xrange(0, count_to, 2): + this = ord(source_string[count + 1]) * 256 + ord(source_string[count]) + sum = sum + this + sum = sum & 0xffffffff # Necessary? + + if count_to < len(source_string): + sum = sum + ord(source_string[len(source_string) - 1]) + sum = sum & 0xffffffff # Necessary? + + sum = (sum >> 16) + (sum & 0xffff) + sum = sum + (sum >> 16) + answer = ~sum + answer = answer & 0xffff + + # Swap bytes. Bugger me if I know why. + answer = answer >> 8 | (answer << 8 & 0xff00) + + return answer + + +def receive_one_ping(my_socket, id, timeout): + """ + Receive the ping from the socket. + """ + time_left = timeout + while True: + started_select = time.time() + what_ready = select.select([my_socket], [], [], time_left) + how_long_in_select = (time.time() - started_select) + if what_ready[0] == []: # Timeout + return + + time_received = time.time() + received_packet, addr = my_socket.recvfrom(1024) + icmpHeader = received_packet[20:28] + type, code, checksum, packet_id, sequence = struct.unpack( + "bbHHh", icmpHeader + ) + if packet_id == id: + bytes = struct.calcsize("d") + time_sent = struct.unpack("d", received_packet[28:28 + bytes])[0] + return time_received - time_sent + + time_left = time_left - how_long_in_select + if time_left <= 0: + return + + +def send_one_ping(my_socket, dest_addr, id, psize): + """ + Send one ping to the given >dest_addr<. + """ + dest_addr = socket.gethostbyname(dest_addr) + + # Remove header size from packet size + psize = psize - 8 + + # Header is type (8), code (8), checksum (16), id (16), sequence (16) + my_checksum = 0 + + # Make a dummy heder with a 0 checksum. + header = struct.pack("bbHHh", ICMP_ECHO_REQUEST, 0, my_checksum, id, 1) + bytes = struct.calcsize("d") + data = (psize - bytes) * "Q" + data = struct.pack("d", time.time()) + data + + # Calculate the checksum on the data and the dummy header. + my_checksum = checksum(header + data) + + # Now that we have the right checksum, we put that in. It's just easier + # to make up a new header than to stuff it into the dummy. + header = struct.pack( + "bbHHh", ICMP_ECHO_REQUEST, 0, socket.htons(my_checksum), id, 1 + ) + packet = header + data + my_socket.sendto(packet, (dest_addr, 1)) # Don't know about the 1 + + +def do_one(dest_addr, timeout, psize): + """ + Returns either the delay (in seconds) or none on timeout. + """ + icmp = socket.getprotobyname("icmp") + try: + my_socket = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp) + except socket.error, (errno, msg): + if errno == 1: + # Operation not permitted + msg = msg + ( + " - Note that ICMP messages can only be sent from processes" + " running as root." + ) + raise socket.error(msg) + raise # raise the original error + + my_id = os.getpid() & 0xFFFF + + send_one_ping(my_socket, dest_addr, my_id, psize) + delay = receive_one_ping(my_socket, my_id, timeout) + + my_socket.close() + return delay + + +def verbose_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + """ + for i in xrange(count): + print "ping %s with ..." % dest_addr, + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay == None: + print "failed. (timeout within %ssec.)" % timeout + else: + delay = delay * 1000 + print "get ping in %0.4fms" % delay + print + + +def quiet_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + Returns `percent' lost packages, `max' round trip time + and `avrg' round trip time. + """ + mrtt = None + artt = None + lost = 0 + plist = [] + + for i in xrange(count): + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay != None: + delay = delay * 1000 + plist.append(delay) + + # Find lost package percent + percent_lost = 100 - (len(plist) * 100 / count) + + # Find max and avg round trip time + if plist: + mrtt = max(plist) + artt = sum(plist) / len(plist) + + return percent_lost, mrtt, artt + +if __name__ == '__main__': + verbose_ping("heise.de") + verbose_ping("google.com") + verbose_ping("a-test-url-taht-is-not-available.com") + verbose_ping("192.168.1.1") diff --git a/ping-0.2/debian/README.Debian b/ping-0.2/debian/README.Debian new file mode 100644 index 0000000..59e8175 --- /dev/null +++ b/ping-0.2/debian/README.Debian @@ -0,0 +1,6 @@ +python-ping for Debian +---------------------- + + + + -- Kristina Clair Wed, 03 Oct 2012 11:59:08 -0700 diff --git a/ping-0.2/debian/README.source b/ping-0.2/debian/README.source new file mode 100644 index 0000000..0be4803 --- /dev/null +++ b/ping-0.2/debian/README.source @@ -0,0 +1,9 @@ +python-ping for Debian +---------------------- + + + + + + diff --git a/ping-0.2/debian/changelog b/ping-0.2/debian/changelog new file mode 100644 index 0000000..156db40 --- /dev/null +++ b/ping-0.2/debian/changelog @@ -0,0 +1,5 @@ +python-ping (0.2-1) unstable; urgency=low + + * Initial release (Closes: #nnnn) + + -- Kristina Clair Wed, 03 Oct 2012 11:59:08 -0700 diff --git a/ping-0.2/debian/compat b/ping-0.2/debian/compat new file mode 100644 index 0000000..7f8f011 --- /dev/null +++ b/ping-0.2/debian/compat @@ -0,0 +1 @@ +7 diff --git a/ping-0.2/debian/control b/ping-0.2/debian/control new file mode 100644 index 0000000..48c946b --- /dev/null +++ b/ping-0.2/debian/control @@ -0,0 +1,23 @@ +Source: python-ping +Maintainer: Kristina Clair +Section: python +Priority: optional +Build-Depends: debhelper (>= 7), python-support (>= 0.8.4) +Standards-Version: 3.8.4 + +Package: python-ping +Architecture: all +Depends: ${misc:Depends}, ${python:Depends} +XB-Python-Version: ${python:Versions} +Provides: ${python:Provides} +Description: An implementation of ICMP ping in Python + This library is a fork of George Notaras' python-ping library, which is + an implementation of the standard ICMP ping in pure Python. + . + As it uses raw ICMP sockets, you need to be root to use the functions + exported by the ping module. + . + This fork by Pierre Bourdon adds a setup.py file in order to permit an + easier distribution of the package. The license of the library remains + unchanged (GPLv2), see COPYING. + . diff --git a/ping-0.2/debian/copyright b/ping-0.2/debian/copyright new file mode 100644 index 0000000..a979dc1 --- /dev/null +++ b/ping-0.2/debian/copyright @@ -0,0 +1,42 @@ +This work was packaged for Debian by: + + Kristina Clair on Wed, 03 Oct 2012 11:45:53 -0700 + +It was downloaded from: + + http://pypi.python.org/pypi/ping/ + +Upstream Author(s): + + Pierre Bourdon + Georgi Kolev + +Copyright: + + Copyright (C) Pierre Bourdon + +License: + + This package is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License version 2 as + published by the Free Software Foundation. + + This package 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, see + +On Debian systems, the complete text of the GNU General +Public License version 2 can be found in "/usr/share/common-licenses/GPL-2". + +The Debian packaging is: + + Copyright (C) 2012 Kristina Clair + + 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. diff --git a/ping-0.2/debian/docs b/ping-0.2/debian/docs new file mode 100644 index 0000000..e845566 --- /dev/null +++ b/ping-0.2/debian/docs @@ -0,0 +1 @@ +README diff --git a/ping-0.2/debian/emacsen-install.ex b/ping-0.2/debian/emacsen-install.ex new file mode 100644 index 0000000..5e9eec8 --- /dev/null +++ b/ping-0.2/debian/emacsen-install.ex @@ -0,0 +1,45 @@ +#! /bin/sh -e +# /usr/lib/emacsen-common/packages/install/python-ping + +# Written by Jim Van Zandt , borrowing heavily +# from the install scripts for gettext by Santiago Vila +# and octave by Dirk Eddelbuettel . + +FLAVOR=$1 +PACKAGE=python-ping + +if [ ${FLAVOR} = emacs ]; then exit 0; fi + +echo install/${PACKAGE}: Handling install for emacsen flavor ${FLAVOR} + +#FLAVORTEST=`echo $FLAVOR | cut -c-6` +#if [ ${FLAVORTEST} = xemacs ] ; then +# SITEFLAG="-no-site-file" +#else +# SITEFLAG="--no-site-file" +#fi +FLAGS="${SITEFLAG} -q -batch -l path.el -f batch-byte-compile" + +ELDIR=/usr/share/emacs/site-lisp/${PACKAGE} +ELCDIR=/usr/share/${FLAVOR}/site-lisp/${PACKAGE} + +# Install-info-altdir does not actually exist. +# Maybe somebody will write it. +if test -x /usr/sbin/install-info-altdir; then + echo install/${PACKAGE}: install Info links for ${FLAVOR} + install-info-altdir --quiet --section "" "" --dirname=${FLAVOR} /usr/share/info/${PACKAGE}.info.gz +fi + +install -m 755 -d ${ELCDIR} +cd ${ELDIR} +FILES=`echo *.el` +cp ${FILES} ${ELCDIR} +cd ${ELCDIR} + +cat << EOF > path.el +(setq load-path (cons "." load-path) byte-compile-warnings nil) +EOF +${FLAVOR} ${FLAGS} ${FILES} +rm -f *.el path.el + +exit 0 diff --git a/ping-0.2/debian/emacsen-remove.ex b/ping-0.2/debian/emacsen-remove.ex new file mode 100644 index 0000000..ff854d0 --- /dev/null +++ b/ping-0.2/debian/emacsen-remove.ex @@ -0,0 +1,15 @@ +#!/bin/sh -e +# /usr/lib/emacsen-common/packages/remove/python-ping + +FLAVOR=$1 +PACKAGE=python-ping + +if [ ${FLAVOR} != emacs ]; then + if test -x /usr/sbin/install-info-altdir; then + echo remove/${PACKAGE}: removing Info links for ${FLAVOR} + install-info-altdir --quiet --remove --dirname=${FLAVOR} /usr/share/info/python-ping.info.gz + fi + + echo remove/${PACKAGE}: purging byte-compiled files for ${FLAVOR} + rm -rf /usr/share/${FLAVOR}/site-lisp/${PACKAGE} +fi diff --git a/ping-0.2/debian/emacsen-startup.ex b/ping-0.2/debian/emacsen-startup.ex new file mode 100644 index 0000000..eeb713c --- /dev/null +++ b/ping-0.2/debian/emacsen-startup.ex @@ -0,0 +1,25 @@ +;; -*-emacs-lisp-*- +;; +;; Emacs startup file, e.g. /etc/emacs/site-start.d/50python-ping.el +;; for the Debian python-ping package +;; +;; Originally contributed by Nils Naumann +;; Modified by Dirk Eddelbuettel +;; Adapted for dh-make by Jim Van Zandt + +;; The python-ping package follows the Debian/GNU Linux 'emacsen' policy and +;; byte-compiles its elisp files for each 'emacs flavor' (emacs19, +;; xemacs19, emacs20, xemacs20...). The compiled code is then +;; installed in a subdirectory of the respective site-lisp directory. +;; We have to add this to the load-path: +(let ((package-dir (concat "/usr/share/" + (symbol-name flavor) + "/site-lisp/python-ping"))) +;; If package-dir does not exist, the python-ping package must have +;; removed but not purged, and we should skip the setup. + (when (file-directory-p package-dir) + (setq load-path (cons package-dir load-path)) + (autoload 'python-ping-mode "python-ping-mode" + "Major mode for editing python-ping files." t) + (add-to-list 'auto-mode-alist '("\\.python-ping$" . python-ping-mode)))) + diff --git a/ping-0.2/debian/files b/ping-0.2/debian/files new file mode 100644 index 0000000..8529412 --- /dev/null +++ b/ping-0.2/debian/files @@ -0,0 +1 @@ +python-ping_0.2-1_all.deb python optional diff --git a/ping-0.2/debian/init.d.ex b/ping-0.2/debian/init.d.ex new file mode 100644 index 0000000..6f77eba --- /dev/null +++ b/ping-0.2/debian/init.d.ex @@ -0,0 +1,154 @@ +#!/bin/sh +### BEGIN INIT INFO +# Provides: python-ping +# Required-Start: $network $local_fs +# Required-Stop: +# Default-Start: 2 3 4 5 +# Default-Stop: 0 1 6 +# Short-Description: +# Description: +# <...> +# <...> +### END INIT INFO + +# Author: Kristina Clair + +# PATH should only include /usr/* if it runs after the mountnfs.sh script +PATH=/sbin:/usr/sbin:/bin:/usr/bin +DESC=python-ping # Introduce a short description here +NAME=python-ping # Introduce the short server's name here +DAEMON=/usr/sbin/python-ping # Introduce the server's location here +DAEMON_ARGS="" # Arguments to run the daemon with +PIDFILE=/var/run/$NAME.pid +SCRIPTNAME=/etc/init.d/$NAME + +# Exit if the package is not installed +[ -x $DAEMON ] || exit 0 + +# Read configuration variable file if it is present +[ -r /etc/default/$NAME ] && . /etc/default/$NAME + +# Load the VERBOSE setting and other rcS variables +. /lib/init/vars.sh + +# Define LSB log_* functions. +# Depend on lsb-base (>= 3.0-6) to ensure that this file is present. +. /lib/lsb/init-functions + +# +# Function that starts the daemon/service +# +do_start() +{ + # Return + # 0 if daemon has been started + # 1 if daemon was already running + # 2 if daemon could not be started + start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \ + || return 1 + start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \ + $DAEMON_ARGS \ + || return 2 + # Add code here, if necessary, that waits for the process to be ready + # to handle requests from services started subsequently which depend + # on this one. As a last resort, sleep for some time. +} + +# +# Function that stops the daemon/service +# +do_stop() +{ + # Return + # 0 if daemon has been stopped + # 1 if daemon was already stopped + # 2 if daemon could not be stopped + # other if a failure occurred + start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME + RETVAL="$?" + [ "$RETVAL" = 2 ] && return 2 + # Wait for children to finish too if this is a daemon that forks + # and if the daemon is only ever run from this initscript. + # If the above conditions are not satisfied then add some other code + # that waits for the process to drop all resources that could be + # needed by services started subsequently. A last resort is to + # sleep for some time. + start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON + [ "$?" = 2 ] && return 2 + # Many daemons don't delete their pidfiles when they exit. + rm -f $PIDFILE + return "$RETVAL" +} + +# +# Function that sends a SIGHUP to the daemon/service +# +do_reload() { + # + # If the daemon can reload its configuration without + # restarting (for example, when it is sent a SIGHUP), + # then implement that here. + # + start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME + return 0 +} + +case "$1" in + start) + [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC " "$NAME" + do_start + case "$?" in + 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;; + 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;; + esac + ;; + stop) + [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME" + do_stop + case "$?" in + 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;; + 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;; + esac + ;; + status) + status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $? + ;; + #reload|force-reload) + # + # If do_reload() is not implemented then leave this commented out + # and leave 'force-reload' as an alias for 'restart'. + # + #log_daemon_msg "Reloading $DESC" "$NAME" + #do_reload + #log_end_msg $? + #;; + restart|force-reload) + # + # If the "reload" option is implemented then remove the + # 'force-reload' alias + # + log_daemon_msg "Restarting $DESC" "$NAME" + do_stop + case "$?" in + 0|1) + do_start + case "$?" in + 0) log_end_msg 0 ;; + 1) log_end_msg 1 ;; # Old process is still running + *) log_end_msg 1 ;; # Failed to start + esac + ;; + *) + # Failed to stop + log_end_msg 1 + ;; + esac + ;; + *) + #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2 + echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2 + exit 3 + ;; +esac + +: diff --git a/ping-0.2/debian/manpage.1.ex b/ping-0.2/debian/manpage.1.ex new file mode 100644 index 0000000..a5a91fa --- /dev/null +++ b/ping-0.2/debian/manpage.1.ex @@ -0,0 +1,59 @@ +.\" Hey, EMACS: -*- nroff -*- +.\" First parameter, NAME, should be all caps +.\" Second parameter, SECTION, should be 1-8, maybe w/ subsection +.\" other parameters are allowed: see man(7), man(1) +.TH PYTHON-PING SECTION "October 3, 2012" +.\" Please adjust this date whenever revising the manpage. +.\" +.\" Some roff macros, for reference: +.\" .nh disable hyphenation +.\" .hy enable hyphenation +.\" .ad l left justify +.\" .ad b justify to both left and right margins +.\" .nf disable filling +.\" .fi enable filling +.\" .br insert line break +.\" .sp insert n+1 empty lines +.\" for manpage-specific macros, see man(7) +.SH NAME +python-ping \- program to do something +.SH SYNOPSIS +.B python-ping +.RI [ options ] " files" ... +.br +.B bar +.RI [ options ] " files" ... +.SH DESCRIPTION +This manual page documents briefly the +.B python-ping +and +.B bar +commands. +.PP +.\" TeX users may be more comfortable with the \fB\fP and +.\" \fI\fP escape sequences to invode bold face and italics, +.\" respectively. +\fBpython-ping\fP is a program that... +.SH OPTIONS +These programs follow the usual GNU command line syntax, with long +options starting with two dashes (`-'). +A summary of options is included below. +For a complete description, see the Info files. +.TP +.B \-h, \-\-help +Show summary of options. +.TP +.B \-v, \-\-version +Show version of program. +.SH SEE ALSO +.BR bar (1), +.BR baz (1). +.br +The programs are documented fully by +.IR "The Rise and Fall of a Fooish Bar" , +available via the Info system. +.SH AUTHOR +python-ping was written by . +.PP +This manual page was written by Kristina Clair , +for the Debian project (and may be used by others). diff --git a/ping-0.2/debian/manpage.sgml.ex b/ping-0.2/debian/manpage.sgml.ex new file mode 100644 index 0000000..e13bc35 --- /dev/null +++ b/ping-0.2/debian/manpage.sgml.ex @@ -0,0 +1,154 @@ + manpage.1'. You may view + the manual page with: `docbook-to-man manpage.sgml | nroff -man | + less'. A typical entry in a Makefile or Makefile.am is: + +manpage.1: manpage.sgml + docbook-to-man $< > $@ + + + The docbook-to-man binary is found in the docbook-to-man package. + Please remember that if you create the nroff version in one of the + debian/rules file targets (such as build), you will need to include + docbook-to-man in your Build-Depends control field. + + --> + + + FIRSTNAME"> + SURNAME"> + + October 3, 2012"> + + SECTION"> + kclair@leap.se"> + + PYTHON-PING"> + + + Debian"> + GNU"> + GPL"> +]> + + + +
+ &dhemail; +
+ + &dhfirstname; + &dhsurname; + + + 2003 + &dhusername; + + &dhdate; +
+ + &dhucpackage; + + &dhsection; + + + &dhpackage; + + program to do something + + + + &dhpackage; + + + + + + + + DESCRIPTION + + This manual page documents briefly the + &dhpackage; and bar + commands. + + This manual page was written for the &debian; distribution + because the original program does not have a manual page. + Instead, it has documentation in the &gnu; + Info format; see below. + + &dhpackage; is a program that... + + + + OPTIONS + + These programs follow the usual &gnu; command line syntax, + with long options starting with two dashes (`-'). A summary of + options is included below. For a complete description, see the + Info files. + + + + + + + + Show summary of options. + + + + + + + + Show version of program. + + + + + + SEE ALSO + + bar (1), baz (1). + + The programs are documented fully by The Rise and + Fall of a Fooish Bar available via the + Info system. + + + AUTHOR + + This manual page was written by &dhusername; &dhemail; for + the &debian; system (and may be used by others). Permission is + granted to copy, distribute and/or modify this document under + the terms of the &gnu; General Public License, Version 2 any + later version published by the Free Software Foundation. + + + On Debian systems, the complete text of the GNU General Public + License can be found in /usr/share/common-licenses/GPL. + + + +
+ + diff --git a/ping-0.2/debian/manpage.xml.ex b/ping-0.2/debian/manpage.xml.ex new file mode 100644 index 0000000..8d8cc6d --- /dev/null +++ b/ping-0.2/debian/manpage.xml.ex @@ -0,0 +1,291 @@ + +.
will be generated. You may view the +manual page with: nroff -man .
| less'. A typical entry +in a Makefile or Makefile.am is: + +DB2MAN = /usr/share/sgml/docbook/stylesheet/xsl/docbook-xsl/manpages/docbook.xsl +XP = xsltproc -''-nonet -''-param man.charmap.use.subset "0" + +manpage.1: manpage.xml + $(XP) $(DB2MAN) $< + +The xsltproc binary is found in the xsltproc package. The XSL files are in +docbook-xsl. A description of the parameters you can use can be found in the +docbook-xsl-doc-* packages. Please remember that if you create the nroff +version in one of the debian/rules file targets (such as build), you will need +to include xsltproc and docbook-xsl in your Build-Depends control field. +Alternatively use the xmlto command/package. That will also automatically +pull in xsltproc and docbook-xsl. + +Notes for using docbook2x: docbook2x-man does not automatically create the +AUTHOR(S) and COPYRIGHT sections. In this case, please add them manually as + ... . + +To disable the automatic creation of the AUTHOR(S) and COPYRIGHT sections +read /usr/share/doc/docbook-xsl/doc/manpages/authors.html. This file can be +found in the docbook-xsl-doc-html package. + +Validation can be done using: `xmllint -''-noout -''-valid manpage.xml` + +General documentation about man-pages and man-page-formatting: +man(1), man(7), http://www.tldp.org/HOWTO/Man-Page/ + +--> + + + + + + + + + + + + + +]> + + + + &dhtitle; + &dhpackage; + + + &dhfirstname; + &dhsurname; + Wrote this manpage for the Debian system. +
+ &dhemail; +
+
+
+ + 2007 + &dhusername; + + + This manual page was written for the Debian system + (and may be used by others). + Permission is granted to copy, distribute and/or modify this + document under the terms of the GNU General Public License, + Version 2 or (at your option) any later version published by + the Free Software Foundation. + On Debian systems, the complete text of the GNU General Public + License can be found in + /usr/share/common-licenses/GPL. + +
+ + &dhucpackage; + &dhsection; + + + &dhpackage; + program to do something + + + + &dhpackage; + + + + + + + + + this + + + + + + + + this + that + + + + + &dhpackage; + + + + + + + + + + + + + + + + + + + DESCRIPTION + This manual page documents briefly the + &dhpackage; and bar + commands. + This manual page was written for the Debian distribution + because the original program does not have a manual page. + Instead, it has documentation in the GNU + info + 1 + format; see below. + &dhpackage; is a program that... + + + OPTIONS + The program follows the usual GNU command line syntax, + with long options starting with two dashes (`-'). A summary of + options is included below. For a complete description, see the + + info + 1 + files. + + + + + + + Does this and that. + + + + + + + Show summary of options. + + + + + + + Show version of program. + + + + + + FILES + + + /etc/foo.conf + + The system-wide configuration file to control the + behaviour of &dhpackage;. See + + foo.conf + 5 + for further details. + + + + ${HOME}/.foo.conf + + The per-user configuration file to control the + behaviour of &dhpackage;. See + + foo.conf + 5 + for further details. + + + + + + ENVIONMENT + + + FOO_CONF + + If used, the defined file is used as configuration + file (see also ). + + + + + + DIAGNOSTICS + The following diagnostics may be issued + on stderr: + + + Bad configuration file. Exiting. + + The configuration file seems to contain a broken configuration + line. Use the option, to get more info. + + + + + &dhpackage; provides some return codes, that can + be used in scripts: + + Code + Diagnostic + + 0 + Program exited successfully. + + + 1 + The configuration file seems to be broken. + + + + + + BUGS + The program is currently limited to only work + with the foobar library. + The upstreams BTS can be found + at . + + + SEE ALSO + + + bar + 1 + , + baz + 1 + , + foo.conf + 5 + + The programs are documented fully by The Rise and + Fall of a Fooish Bar available via the + info + 1 + system. + +
+ diff --git a/ping-0.2/debian/menu.ex b/ping-0.2/debian/menu.ex new file mode 100644 index 0000000..3820e61 --- /dev/null +++ b/ping-0.2/debian/menu.ex @@ -0,0 +1,2 @@ +?package(python-ping):needs="X11|text|vc|wm" section="Applications/see-menu-manual"\ + title="python-ping" command="/usr/bin/python-ping" diff --git a/ping-0.2/debian/postinst.ex b/ping-0.2/debian/postinst.ex new file mode 100644 index 0000000..3bcfde3 --- /dev/null +++ b/ping-0.2/debian/postinst.ex @@ -0,0 +1,39 @@ +#!/bin/sh +# postinst script for python-ping +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `configure' +# * `abort-upgrade' +# * `abort-remove' `in-favour' +# +# * `abort-remove' +# * `abort-deconfigure' `in-favour' +# `removing' +# +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + configure) + ;; + + abort-upgrade|abort-remove|abort-deconfigure) + ;; + + *) + echo "postinst called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/ping-0.2/debian/postrm.ex b/ping-0.2/debian/postrm.ex new file mode 100644 index 0000000..6a4d8e8 --- /dev/null +++ b/ping-0.2/debian/postrm.ex @@ -0,0 +1,37 @@ +#!/bin/sh +# postrm script for python-ping +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `remove' +# * `purge' +# * `upgrade' +# * `failed-upgrade' +# * `abort-install' +# * `abort-install' +# * `abort-upgrade' +# * `disappear' +# +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + purge|remove|upgrade|failed-upgrade|abort-install|abort-upgrade|disappear) + ;; + + *) + echo "postrm called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/ping-0.2/debian/preinst.ex b/ping-0.2/debian/preinst.ex new file mode 100644 index 0000000..6b6daa5 --- /dev/null +++ b/ping-0.2/debian/preinst.ex @@ -0,0 +1,35 @@ +#!/bin/sh +# preinst script for python-ping +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `install' +# * `install' +# * `upgrade' +# * `abort-upgrade' +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + install|upgrade) + ;; + + abort-upgrade) + ;; + + *) + echo "preinst called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/ping-0.2/debian/prerm.ex b/ping-0.2/debian/prerm.ex new file mode 100644 index 0000000..d397c4c --- /dev/null +++ b/ping-0.2/debian/prerm.ex @@ -0,0 +1,38 @@ +#!/bin/sh +# prerm script for python-ping +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `remove' +# * `upgrade' +# * `failed-upgrade' +# * `remove' `in-favour' +# * `deconfigure' `in-favour' +# `removing' +# +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + remove|upgrade|deconfigure) + ;; + + failed-upgrade) + ;; + + *) + echo "prerm called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/ping-0.2/debian/python-ping.cron.d.ex b/ping-0.2/debian/python-ping.cron.d.ex new file mode 100644 index 0000000..1cd8ea1 --- /dev/null +++ b/ping-0.2/debian/python-ping.cron.d.ex @@ -0,0 +1,4 @@ +# +# Regular cron jobs for the python-ping package +# +0 4 * * * root [ -x /usr/bin/python-ping_maintenance ] && /usr/bin/python-ping_maintenance diff --git a/ping-0.2/debian/python-ping.debhelper.log b/ping-0.2/debian/python-ping.debhelper.log new file mode 100644 index 0000000..2d06fcd --- /dev/null +++ b/ping-0.2/debian/python-ping.debhelper.log @@ -0,0 +1,45 @@ +dh_auto_configure +dh_auto_build +dh_auto_test +dh_prep +dh_installdirs +dh_auto_install +dh_install +dh_installdocs +dh_installchangelogs +dh_installexamples +dh_installman +dh_installcatalogs +dh_installcron +dh_installdebconf +dh_installemacsen +dh_installifupdown +dh_installinfo +dh_pysupport +dh_installinit +dh_installmenu +dh_installmime +dh_installmodules +dh_installlogcheck +dh_installlogrotate +dh_installpam +dh_installppp +dh_installudev +dh_installwm +dh_installxfonts +dh_bugfiles +dh_lintian +dh_gconf +dh_icons +dh_perl +dh_usrlocal +dh_link +dh_compress +dh_fixperms +dh_strip +dh_makeshlibs +dh_shlibdeps +dh_installdeb +dh_gencontrol +dh_md5sums +dh_builddeb diff --git a/ping-0.2/debian/python-ping.default.ex b/ping-0.2/debian/python-ping.default.ex new file mode 100644 index 0000000..d63db49 --- /dev/null +++ b/ping-0.2/debian/python-ping.default.ex @@ -0,0 +1,10 @@ +# Defaults for python-ping initscript +# sourced by /etc/init.d/python-ping +# installed at /etc/default/python-ping by the maintainer scripts + +# +# This is a POSIX shell fragment +# + +# Additional options that are passed to the Daemon. +DAEMON_OPTS="" diff --git a/ping-0.2/debian/python-ping.doc-base.EX b/ping-0.2/debian/python-ping.doc-base.EX new file mode 100644 index 0000000..6478de5 --- /dev/null +++ b/ping-0.2/debian/python-ping.doc-base.EX @@ -0,0 +1,20 @@ +Document: python-ping +Title: Debian python-ping Manual +Author: +Abstract: This manual describes what python-ping is + and how it can be used to + manage online manuals on Debian systems. +Section: unknown + +Format: debiandoc-sgml +Files: /usr/share/doc/python-ping/python-ping.sgml.gz + +Format: postscript +Files: /usr/share/doc/python-ping/python-ping.ps.gz + +Format: text +Files: /usr/share/doc/python-ping/python-ping.text.gz + +Format: HTML +Index: /usr/share/doc/python-ping/html/index.html +Files: /usr/share/doc/python-ping/html/*.html diff --git a/ping-0.2/debian/python-ping.postinst.debhelper b/ping-0.2/debian/python-ping.postinst.debhelper new file mode 100644 index 0000000..47b9418 --- /dev/null +++ b/ping-0.2/debian/python-ping.postinst.debhelper @@ -0,0 +1,5 @@ +# Automatically added by dh_pysupport +if which update-python-modules >/dev/null 2>&1; then + update-python-modules python-ping.public +fi +# End automatically added section diff --git a/ping-0.2/debian/python-ping.prerm.debhelper b/ping-0.2/debian/python-ping.prerm.debhelper new file mode 100644 index 0000000..431bd96 --- /dev/null +++ b/ping-0.2/debian/python-ping.prerm.debhelper @@ -0,0 +1,5 @@ +# Automatically added by dh_pysupport +if which update-python-modules >/dev/null 2>&1; then + update-python-modules -c python-ping.public +fi +# End automatically added section diff --git a/ping-0.2/debian/python-ping.substvars b/ping-0.2/debian/python-ping.substvars new file mode 100644 index 0000000..7c033c4 --- /dev/null +++ b/ping-0.2/debian/python-ping.substvars @@ -0,0 +1,4 @@ +python:Versions=2.5, 2.6 +python:Provides=python2.5-ping, python2.6-ping +python:Depends=python, python-support (>= 0.90.0) +misc:Depends= diff --git a/ping-0.2/debian/python-ping/DEBIAN/control b/ping-0.2/debian/python-ping/DEBIAN/control new file mode 100644 index 0000000..b97ec21 --- /dev/null +++ b/ping-0.2/debian/python-ping/DEBIAN/control @@ -0,0 +1,20 @@ +Package: python-ping +Version: 0.2-1 +Architecture: all +Maintainer: Kristina Clair +Installed-Size: 76 +Depends: python, python-support (>= 0.90.0) +Provides: python2.5-ping, python2.6-ping +Section: python +Priority: optional +Description: An implementation of ICMP ping in Python + This library is a fork of George Notaras' python-ping library, which is + an implementation of the standard ICMP ping in pure Python. + . + As it uses raw ICMP sockets, you need to be root to use the functions + exported by the ping module. + . + This fork by Pierre Bourdon adds a setup.py file in order to permit an + easier distribution of the package. The license of the library remains + unchanged (GPLv2), see COPYING. +Python-Version: 2.5, 2.6 diff --git a/ping-0.2/debian/python-ping/DEBIAN/md5sums b/ping-0.2/debian/python-ping/DEBIAN/md5sums new file mode 100644 index 0000000..21aca8b --- /dev/null +++ b/ping-0.2/debian/python-ping/DEBIAN/md5sums @@ -0,0 +1,7 @@ +0851268cfa5f0ed91ecddae6d42e10c4 usr/share/doc/python-ping/README +218257068617a420552b25445a495b01 usr/share/doc/python-ping/README.Debian +9de4874a2f489523a5128c8255aa2457 usr/share/doc/python-ping/changelog.Debian.gz +27543d7b5ce6a9f6319cff1d1d5a7a0b usr/share/doc/python-ping/copyright +b246e4f2dcf66e20c6353b89c3df912a usr/share/pyshared/ping-0.2.egg-info +b9da1875bfb3013c16f66ed22edaa46f usr/share/pyshared/ping.py +4f51c996bcf5086cb0de223b62a146eb usr/share/python-support/python-ping.public diff --git a/ping-0.2/debian/python-ping/DEBIAN/postinst b/ping-0.2/debian/python-ping/DEBIAN/postinst new file mode 100755 index 0000000..6aa6c16 --- /dev/null +++ b/ping-0.2/debian/python-ping/DEBIAN/postinst @@ -0,0 +1,7 @@ +#!/bin/sh +set -e +# Automatically added by dh_pysupport +if which update-python-modules >/dev/null 2>&1; then + update-python-modules python-ping.public +fi +# End automatically added section diff --git a/ping-0.2/debian/python-ping/DEBIAN/prerm b/ping-0.2/debian/python-ping/DEBIAN/prerm new file mode 100755 index 0000000..99c6b3b --- /dev/null +++ b/ping-0.2/debian/python-ping/DEBIAN/prerm @@ -0,0 +1,7 @@ +#!/bin/sh +set -e +# Automatically added by dh_pysupport +if which update-python-modules >/dev/null 2>&1; then + update-python-modules -c python-ping.public +fi +# End automatically added section diff --git a/ping-0.2/debian/python-ping/usr/share/doc/python-ping/README b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/README new file mode 100644 index 0000000..b3cccd7 --- /dev/null +++ b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/README @@ -0,0 +1,9 @@ +This library is a fork of George Notaras' python-ping library, which is +an implementation of the standard ICMP ping in pure Python. + +As it uses raw ICMP sockets, you need to be root to use the functions +exported by the ping module. + +This fork by Pierre Bourdon adds a setup.py file in order to permit an +easier distribution of the package. The license of the library remains +unchanged (GPLv2), see COPYING. diff --git a/ping-0.2/debian/python-ping/usr/share/doc/python-ping/README.Debian b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/README.Debian new file mode 100644 index 0000000..59e8175 --- /dev/null +++ b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/README.Debian @@ -0,0 +1,6 @@ +python-ping for Debian +---------------------- + + + + -- Kristina Clair Wed, 03 Oct 2012 11:59:08 -0700 diff --git a/ping-0.2/debian/python-ping/usr/share/doc/python-ping/changelog.Debian.gz b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/changelog.Debian.gz new file mode 100644 index 0000000..5e6b245 Binary files /dev/null and b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/changelog.Debian.gz differ diff --git a/ping-0.2/debian/python-ping/usr/share/doc/python-ping/copyright b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/copyright new file mode 100644 index 0000000..a979dc1 --- /dev/null +++ b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/copyright @@ -0,0 +1,42 @@ +This work was packaged for Debian by: + + Kristina Clair on Wed, 03 Oct 2012 11:45:53 -0700 + +It was downloaded from: + + http://pypi.python.org/pypi/ping/ + +Upstream Author(s): + + Pierre Bourdon + Georgi Kolev + +Copyright: + + Copyright (C) Pierre Bourdon + +License: + + This package is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License version 2 as + published by the Free Software Foundation. + + This package 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, see + +On Debian systems, the complete text of the GNU General +Public License version 2 can be found in "/usr/share/common-licenses/GPL-2". + +The Debian packaging is: + + Copyright (C) 2012 Kristina Clair + + 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. diff --git a/ping-0.2/debian/python-ping/usr/share/pyshared/ping-0.2.egg-info b/ping-0.2/debian/python-ping/usr/share/pyshared/ping-0.2.egg-info new file mode 100644 index 0000000..bdcd4f1 --- /dev/null +++ b/ping-0.2/debian/python-ping/usr/share/pyshared/ping-0.2.egg-info @@ -0,0 +1,31 @@ +Metadata-Version: 1.0 +Name: ping +Version: 0.2 +Summary: An implementation of ICMP ping in Python +Home-page: http://bitbucket.org/delroth/python-ping/ +Author: Pierre Bourdon +Author-email: delroth@gmail.com +License: GPL2 +Download-URL: http://bitbucket.org/delroth/python-ping/downloads/python-ping-0.2.tar.gz +Description: This library is a fork of George Notaras' python-ping library, which is + an implementation of the standard ICMP ping in pure Python. + + As it uses raw ICMP sockets, you need to be root to use the functions + exported by the ping module. + + This fork by Pierre Bourdon adds a setup.py file in order to permit an + easier distribution of the package. The license of the library remains + unchanged (GPLv2), see COPYING. + +Keywords: ping icmp network latency +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: Intended Audience :: System Administrators +Classifier: License :: OSI Approved :: GNU General Public License (GPL) +Classifier: Operating System :: Microsoft :: Windows +Classifier: Operating System :: Unix +Classifier: Programming Language :: Python :: 2 +Classifier: Topic :: Internet +Classifier: Topic :: System :: Networking +Classifier: Topic :: System :: Networking :: Monitoring diff --git a/ping-0.2/debian/python-ping/usr/share/pyshared/ping.py b/ping-0.2/debian/python-ping/usr/share/pyshared/ping.py new file mode 100644 index 0000000..8c4a4bd --- /dev/null +++ b/ping-0.2/debian/python-ping/usr/share/pyshared/ping.py @@ -0,0 +1,273 @@ +#!/usr/bin/env python + +""" + A pure python ping implementation using raw socket. + + + Note that ICMP messages can only be sent from processes running as root. + + + Derived from ping.c distributed in Linux's netkit. That code is + copyright (c) 1989 by The Regents of the University of California. + That code is in turn derived from code written by Mike Muuss of the + US Army Ballistic Research Laboratory in December, 1983 and + placed in the public domain. They have my thanks. + + Bugs are naturally mine. I'd be glad to hear about them. There are + certainly word - size dependenceies here. + + Copyright (c) Matthew Dixon Cowles, . + Distributable under the terms of the GNU General Public License + version 2. Provided with no warranties of any sort. + + Original Version from Matthew Dixon Cowles: + -> ftp://ftp.visi.com/users/mdc/ping.py + + Rewrite by Jens Diemer: + -> http://www.python-forum.de/post-69122.html#69122 + + Rewrite by George Notaras: + -> http://www.g-loaded.eu/2009/10/30/python-ping/ + + Fork by Pierre Bourdon: + -> http://bitbucket.org/delroth/python-ping/ + + Revision history + ~~~~~~~~~~~~~~~~ + + November 22, 1997 + ----------------- + Initial hack. Doesn't do much, but rather than try to guess + what features I (or others) will want in the future, I've only + put in what I need now. + + December 16, 1997 + ----------------- + For some reason, the checksum bytes are in the wrong order when + this is run under Solaris 2.X for SPARC but it works right under + Linux x86. Since I don't know just what's wrong, I'll swap the + bytes always and then do an htons(). + + December 4, 2000 + ---------------- + Changed the struct.pack() calls to pack the checksum and ID as + unsigned. My thanks to Jerome Poincheval for the fix. + + May 30, 2007 + ------------ + little rewrite by Jens Diemer: + - change socket asterisk import to a normal import + - replace time.time() with time.clock() + - delete "return None" (or change to "return" only) + - in checksum() rename "str" to "source_string" + + November 8, 2009 + ---------------- + Improved compatibility with GNU/Linux systems. + + Fixes by: + * George Notaras -- http://www.g-loaded.eu + Reported by: + * Chris Hallman -- http://cdhallman.blogspot.com + + Changes in this release: + - Re-use time.time() instead of time.clock(). The 2007 implementation + worked only under Microsoft Windows. Failed on GNU/Linux. + time.clock() behaves differently under the two OSes[1]. + + [1] http://docs.python.org/library/time.html#time.clock + + September 25, 2010 + ------------------ + Little modifications by Georgi Kolev: + - Added quiet_ping function. + - returns percent lost packages, max round trip time, avrg round trip + time + - Added packet size to verbose_ping & quiet_ping functions. + - Bump up version to 0.2 + +""" + +__version__ = "0.2" + +import os +import select +import socket +import struct +import sys +import time + +# From /usr/include/linux/icmp.h; your milage may vary. +ICMP_ECHO_REQUEST = 8 # Seems to be the same on Solaris. + + +def checksum(source_string): + """ + I'm not too confident that this is right but testing seems + to suggest that it gives the same answers as in_cksum in ping.c + """ + sum = 0 + count_to = (len(source_string) / 2) * 2 + for count in xrange(0, count_to, 2): + this = ord(source_string[count + 1]) * 256 + ord(source_string[count]) + sum = sum + this + sum = sum & 0xffffffff # Necessary? + + if count_to < len(source_string): + sum = sum + ord(source_string[len(source_string) - 1]) + sum = sum & 0xffffffff # Necessary? + + sum = (sum >> 16) + (sum & 0xffff) + sum = sum + (sum >> 16) + answer = ~sum + answer = answer & 0xffff + + # Swap bytes. Bugger me if I know why. + answer = answer >> 8 | (answer << 8 & 0xff00) + + return answer + + +def receive_one_ping(my_socket, id, timeout): + """ + Receive the ping from the socket. + """ + time_left = timeout + while True: + started_select = time.time() + what_ready = select.select([my_socket], [], [], time_left) + how_long_in_select = (time.time() - started_select) + if what_ready[0] == []: # Timeout + return + + time_received = time.time() + received_packet, addr = my_socket.recvfrom(1024) + icmpHeader = received_packet[20:28] + type, code, checksum, packet_id, sequence = struct.unpack( + "bbHHh", icmpHeader + ) + if packet_id == id: + bytes = struct.calcsize("d") + time_sent = struct.unpack("d", received_packet[28:28 + bytes])[0] + return time_received - time_sent + + time_left = time_left - how_long_in_select + if time_left <= 0: + return + + +def send_one_ping(my_socket, dest_addr, id, psize): + """ + Send one ping to the given >dest_addr<. + """ + dest_addr = socket.gethostbyname(dest_addr) + + # Remove header size from packet size + psize = psize - 8 + + # Header is type (8), code (8), checksum (16), id (16), sequence (16) + my_checksum = 0 + + # Make a dummy heder with a 0 checksum. + header = struct.pack("bbHHh", ICMP_ECHO_REQUEST, 0, my_checksum, id, 1) + bytes = struct.calcsize("d") + data = (psize - bytes) * "Q" + data = struct.pack("d", time.time()) + data + + # Calculate the checksum on the data and the dummy header. + my_checksum = checksum(header + data) + + # Now that we have the right checksum, we put that in. It's just easier + # to make up a new header than to stuff it into the dummy. + header = struct.pack( + "bbHHh", ICMP_ECHO_REQUEST, 0, socket.htons(my_checksum), id, 1 + ) + packet = header + data + my_socket.sendto(packet, (dest_addr, 1)) # Don't know about the 1 + + +def do_one(dest_addr, timeout, psize): + """ + Returns either the delay (in seconds) or none on timeout. + """ + icmp = socket.getprotobyname("icmp") + try: + my_socket = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp) + except socket.error, (errno, msg): + if errno == 1: + # Operation not permitted + msg = msg + ( + " - Note that ICMP messages can only be sent from processes" + " running as root." + ) + raise socket.error(msg) + raise # raise the original error + + my_id = os.getpid() & 0xFFFF + + send_one_ping(my_socket, dest_addr, my_id, psize) + delay = receive_one_ping(my_socket, my_id, timeout) + + my_socket.close() + return delay + + +def verbose_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + """ + for i in xrange(count): + print "ping %s with ..." % dest_addr, + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay == None: + print "failed. (timeout within %ssec.)" % timeout + else: + delay = delay * 1000 + print "get ping in %0.4fms" % delay + print + + +def quiet_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + Returns `percent' lost packages, `max' round trip time + and `avrg' round trip time. + """ + mrtt = None + artt = None + lost = 0 + plist = [] + + for i in xrange(count): + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay != None: + delay = delay * 1000 + plist.append(delay) + + # Find lost package percent + percent_lost = 100 - (len(plist) * 100 / count) + + # Find max and avg round trip time + if plist: + mrtt = max(plist) + artt = sum(plist) / len(plist) + + return percent_lost, mrtt, artt + +if __name__ == '__main__': + verbose_ping("heise.de") + verbose_ping("google.com") + verbose_ping("a-test-url-taht-is-not-available.com") + verbose_ping("192.168.1.1") diff --git a/ping-0.2/debian/python-ping/usr/share/python-support/python-ping.public b/ping-0.2/debian/python-ping/usr/share/python-support/python-ping.public new file mode 100644 index 0000000..fe3edd6 --- /dev/null +++ b/ping-0.2/debian/python-ping/usr/share/python-support/python-ping.public @@ -0,0 +1,2 @@ +/usr/share/pyshared/ping-0.2.egg-info +/usr/share/pyshared/ping.py diff --git a/ping-0.2/debian/rules b/ping-0.2/debian/rules new file mode 100755 index 0000000..b760bee --- /dev/null +++ b/ping-0.2/debian/rules @@ -0,0 +1,13 @@ +#!/usr/bin/make -f +# -*- makefile -*- +# Sample debian/rules that uses debhelper. +# This file was originally written by Joey Hess and Craig Small. +# As a special exception, when this file is copied by dh-make into a +# dh-make output file, you may use that output file without restriction. +# This special exception was added by Craig Small in version 0.37 of dh-make. + +# Uncomment this to turn on verbose mode. +#export DH_VERBOSE=1 + +%: + dh $@ diff --git a/ping-0.2/debian/source/format b/ping-0.2/debian/source/format new file mode 100644 index 0000000..163aaf8 --- /dev/null +++ b/ping-0.2/debian/source/format @@ -0,0 +1 @@ +3.0 (quilt) diff --git a/ping-0.2/debian/watch.ex b/ping-0.2/debian/watch.ex new file mode 100644 index 0000000..c280a37 --- /dev/null +++ b/ping-0.2/debian/watch.ex @@ -0,0 +1,23 @@ +# Example watch control file for uscan +# Rename this file to "watch" and then you can run the "uscan" command +# to check for upstream updates and more. +# See uscan(1) for format + +# Compulsory line, this is a version 3 file +version=3 + +# Uncomment to examine a Webpage +# +#http://www.example.com/downloads.php python-ping-(.*)\.tar\.gz + +# Uncomment to examine a Webserver directory +#http://www.example.com/pub/python-ping-(.*)\.tar\.gz + +# Uncommment to examine a FTP server +#ftp://ftp.example.com/pub/python-ping-(.*)\.tar\.gz debian uupdate + +# Uncomment to find new files on sourceforge, for devscripts >= 2.9 +# http://sf.net/python-ping/python-ping-(.*)\.tar\.gz + +# Uncomment to find new files on GooglePages +# http://example.googlepages.com/foo.html python-ping-(.*)\.tar\.gz diff --git a/ping-0.2/ping.py b/ping-0.2/ping.py new file mode 100644 index 0000000..8c4a4bd --- /dev/null +++ b/ping-0.2/ping.py @@ -0,0 +1,273 @@ +#!/usr/bin/env python + +""" + A pure python ping implementation using raw socket. + + + Note that ICMP messages can only be sent from processes running as root. + + + Derived from ping.c distributed in Linux's netkit. That code is + copyright (c) 1989 by The Regents of the University of California. + That code is in turn derived from code written by Mike Muuss of the + US Army Ballistic Research Laboratory in December, 1983 and + placed in the public domain. They have my thanks. + + Bugs are naturally mine. I'd be glad to hear about them. There are + certainly word - size dependenceies here. + + Copyright (c) Matthew Dixon Cowles, . + Distributable under the terms of the GNU General Public License + version 2. Provided with no warranties of any sort. + + Original Version from Matthew Dixon Cowles: + -> ftp://ftp.visi.com/users/mdc/ping.py + + Rewrite by Jens Diemer: + -> http://www.python-forum.de/post-69122.html#69122 + + Rewrite by George Notaras: + -> http://www.g-loaded.eu/2009/10/30/python-ping/ + + Fork by Pierre Bourdon: + -> http://bitbucket.org/delroth/python-ping/ + + Revision history + ~~~~~~~~~~~~~~~~ + + November 22, 1997 + ----------------- + Initial hack. Doesn't do much, but rather than try to guess + what features I (or others) will want in the future, I've only + put in what I need now. + + December 16, 1997 + ----------------- + For some reason, the checksum bytes are in the wrong order when + this is run under Solaris 2.X for SPARC but it works right under + Linux x86. Since I don't know just what's wrong, I'll swap the + bytes always and then do an htons(). + + December 4, 2000 + ---------------- + Changed the struct.pack() calls to pack the checksum and ID as + unsigned. My thanks to Jerome Poincheval for the fix. + + May 30, 2007 + ------------ + little rewrite by Jens Diemer: + - change socket asterisk import to a normal import + - replace time.time() with time.clock() + - delete "return None" (or change to "return" only) + - in checksum() rename "str" to "source_string" + + November 8, 2009 + ---------------- + Improved compatibility with GNU/Linux systems. + + Fixes by: + * George Notaras -- http://www.g-loaded.eu + Reported by: + * Chris Hallman -- http://cdhallman.blogspot.com + + Changes in this release: + - Re-use time.time() instead of time.clock(). The 2007 implementation + worked only under Microsoft Windows. Failed on GNU/Linux. + time.clock() behaves differently under the two OSes[1]. + + [1] http://docs.python.org/library/time.html#time.clock + + September 25, 2010 + ------------------ + Little modifications by Georgi Kolev: + - Added quiet_ping function. + - returns percent lost packages, max round trip time, avrg round trip + time + - Added packet size to verbose_ping & quiet_ping functions. + - Bump up version to 0.2 + +""" + +__version__ = "0.2" + +import os +import select +import socket +import struct +import sys +import time + +# From /usr/include/linux/icmp.h; your milage may vary. +ICMP_ECHO_REQUEST = 8 # Seems to be the same on Solaris. + + +def checksum(source_string): + """ + I'm not too confident that this is right but testing seems + to suggest that it gives the same answers as in_cksum in ping.c + """ + sum = 0 + count_to = (len(source_string) / 2) * 2 + for count in xrange(0, count_to, 2): + this = ord(source_string[count + 1]) * 256 + ord(source_string[count]) + sum = sum + this + sum = sum & 0xffffffff # Necessary? + + if count_to < len(source_string): + sum = sum + ord(source_string[len(source_string) - 1]) + sum = sum & 0xffffffff # Necessary? + + sum = (sum >> 16) + (sum & 0xffff) + sum = sum + (sum >> 16) + answer = ~sum + answer = answer & 0xffff + + # Swap bytes. Bugger me if I know why. + answer = answer >> 8 | (answer << 8 & 0xff00) + + return answer + + +def receive_one_ping(my_socket, id, timeout): + """ + Receive the ping from the socket. + """ + time_left = timeout + while True: + started_select = time.time() + what_ready = select.select([my_socket], [], [], time_left) + how_long_in_select = (time.time() - started_select) + if what_ready[0] == []: # Timeout + return + + time_received = time.time() + received_packet, addr = my_socket.recvfrom(1024) + icmpHeader = received_packet[20:28] + type, code, checksum, packet_id, sequence = struct.unpack( + "bbHHh", icmpHeader + ) + if packet_id == id: + bytes = struct.calcsize("d") + time_sent = struct.unpack("d", received_packet[28:28 + bytes])[0] + return time_received - time_sent + + time_left = time_left - how_long_in_select + if time_left <= 0: + return + + +def send_one_ping(my_socket, dest_addr, id, psize): + """ + Send one ping to the given >dest_addr<. + """ + dest_addr = socket.gethostbyname(dest_addr) + + # Remove header size from packet size + psize = psize - 8 + + # Header is type (8), code (8), checksum (16), id (16), sequence (16) + my_checksum = 0 + + # Make a dummy heder with a 0 checksum. + header = struct.pack("bbHHh", ICMP_ECHO_REQUEST, 0, my_checksum, id, 1) + bytes = struct.calcsize("d") + data = (psize - bytes) * "Q" + data = struct.pack("d", time.time()) + data + + # Calculate the checksum on the data and the dummy header. + my_checksum = checksum(header + data) + + # Now that we have the right checksum, we put that in. It's just easier + # to make up a new header than to stuff it into the dummy. + header = struct.pack( + "bbHHh", ICMP_ECHO_REQUEST, 0, socket.htons(my_checksum), id, 1 + ) + packet = header + data + my_socket.sendto(packet, (dest_addr, 1)) # Don't know about the 1 + + +def do_one(dest_addr, timeout, psize): + """ + Returns either the delay (in seconds) or none on timeout. + """ + icmp = socket.getprotobyname("icmp") + try: + my_socket = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp) + except socket.error, (errno, msg): + if errno == 1: + # Operation not permitted + msg = msg + ( + " - Note that ICMP messages can only be sent from processes" + " running as root." + ) + raise socket.error(msg) + raise # raise the original error + + my_id = os.getpid() & 0xFFFF + + send_one_ping(my_socket, dest_addr, my_id, psize) + delay = receive_one_ping(my_socket, my_id, timeout) + + my_socket.close() + return delay + + +def verbose_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + """ + for i in xrange(count): + print "ping %s with ..." % dest_addr, + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay == None: + print "failed. (timeout within %ssec.)" % timeout + else: + delay = delay * 1000 + print "get ping in %0.4fms" % delay + print + + +def quiet_ping(dest_addr, timeout = 2, count = 4, psize = 64): + """ + Send `count' ping with `psize' size to `dest_addr' with + the given `timeout' and display the result. + Returns `percent' lost packages, `max' round trip time + and `avrg' round trip time. + """ + mrtt = None + artt = None + lost = 0 + plist = [] + + for i in xrange(count): + try: + delay = do_one(dest_addr, timeout, psize) + except socket.gaierror, e: + print "failed. (socket error: '%s')" % e[1] + break + + if delay != None: + delay = delay * 1000 + plist.append(delay) + + # Find lost package percent + percent_lost = 100 - (len(plist) * 100 / count) + + # Find max and avg round trip time + if plist: + mrtt = max(plist) + artt = sum(plist) / len(plist) + + return percent_lost, mrtt, artt + +if __name__ == '__main__': + verbose_ping("heise.de") + verbose_ping("google.com") + verbose_ping("a-test-url-taht-is-not-available.com") + verbose_ping("192.168.1.1") diff --git a/ping-0.2/ping.pyc b/ping-0.2/ping.pyc new file mode 100644 index 0000000..6e2aa98 Binary files /dev/null and b/ping-0.2/ping.pyc differ diff --git a/ping-0.2/setup.py b/ping-0.2/setup.py new file mode 100644 index 0000000..04a4eb7 --- /dev/null +++ b/ping-0.2/setup.py @@ -0,0 +1,53 @@ +#!/usr/bin/env python +#-*- encoding: utf-8 -*- +""" +setup.py +Distutils setup script. + +Copyright (c) 2010 Pierre Bourdon + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License version 2 as +published by the Free Software Foundation. + +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, see . +""" + +from distutils.core import setup +from ping import __version__ + +setup( + name="ping", + version=__version__, + py_modules=[ + 'ping' + ], + + author="Pierre Bourdon", + author_email="delroth@gmail.com", + description="An implementation of ICMP ping in Python", + long_description=open('README').read(), + license="GPL2", + keywords="ping icmp network latency", + url="http://bitbucket.org/delroth/python-ping/", + download_url="http://bitbucket.org/delroth/python-ping/downloads/python-ping-%s.tar.gz" % __version__, + + classifiers=[ + "Development Status :: 5 - Production/Stable", + "Intended Audience :: Developers", + "Intended Audience :: System Administrators", + "License :: OSI Approved :: GNU General Public License (GPL)", + "Operating System :: Microsoft :: Windows", + "Operating System :: Unix", + "Programming Language :: Python :: 2", + "Topic :: Internet", + "Topic :: System :: Networking", + "Topic :: System :: Networking :: Monitoring", + ], +) diff --git a/python-ping_0.2-1.debian.tar.gz b/python-ping_0.2-1.debian.tar.gz new file mode 100644 index 0000000..0d2ebbc Binary files /dev/null and b/python-ping_0.2-1.debian.tar.gz differ diff --git a/python-ping_0.2-1.dsc b/python-ping_0.2-1.dsc new file mode 100644 index 0000000..ece38e4 --- /dev/null +++ b/python-ping_0.2-1.dsc @@ -0,0 +1,39 @@ +-----BEGIN PGP SIGNED MESSAGE----- +Hash: SHA1 + +Format: 3.0 (quilt) +Source: python-ping +Binary: python-ping +Architecture: all +Version: 0.2-1 +Maintainer: Kristina Clair +Standards-Version: 3.8.4 +Build-Depends: debhelper (>= 7), python-support (>= 0.8.4) +Checksums-Sha1: + 54b7ece233794e06193bfc0983117259c554eed0 10979 python-ping_0.2.orig.tar.gz + 75f5a6bb4302e3be2ad827053d2b562c719c9adc 11225 python-ping_0.2-1.debian.tar.gz +Checksums-Sha256: + ecb32294c2af8ae075de4a3743f568db376480ad81c2e010a7f1ce1cee7b030f 10979 python-ping_0.2.orig.tar.gz + c80a002fabe73635d7449106aaeb9c30369c6ec034297fcd9253a758edabedfc 11225 python-ping_0.2-1.debian.tar.gz +Files: + 57228e54268390ca2fef5181d5568e38 10979 python-ping_0.2.orig.tar.gz + 65ef7c284d45cad2c5b74a49348eae4b 11225 python-ping_0.2-1.debian.tar.gz + +-----BEGIN PGP SIGNATURE----- +Version: GnuPG v1.4.10 (GNU/Linux) +Comment: GPGTools - http://gpgtools.org + +iQIcBAEBAgAGBQJQbItwAAoJEJ6m/xxX04TjZ2sQAJmBmP7E8og9okK2A+tI+u3v +heH4t2SXd3L380Q30i0vIb+iA6iUCh11Ba15D3CO6+UT2JoFq6TSCNk+xdq95oHf +AeW7KVDR/BoT44PexZ/akSz9rPWKJfe2fLobEMmGY2Y5Lwe19fqiea/48DxCJHip +C6LWBrGokh5LRfQz5f5dIcpgUIJ7M5pRvW3IJhG68fQvf9RAwAY8CjAxkleibF7w +b8Y7INuI595mI+jzBrmBrs/F9orEaQj1+Wuqyo/cDwcglQ+oy3VigZPrCXj7xr/f +tO83eRkWim/uE5hocKufyQVz9Pd7fAf8Gk3NwaS9xDMWKNOzph62ab1MI1GybIOd +MCV8KniDHOm3zHc5klInpOUvW5mN8GdCixKRzc4tnlamhFIQFotdY6MwfVcWvfaP +NeWkzgfjOfhEgsZZxRM9wonQWghbuFXFyRnI1+oIfNSLRRSSh3Egj/mdlq3wpLAZ +D384AHxjoy0ynr8zPpu4m54qSfg6XiHTUKzo311FwwmBjaQm+NVbkLIuaKCnCJ7Q +z6X7X0A8vt+HIjkUvbEUcKIE59p8YJtwySx9XZ5vUbs8i65Awjo/6jqP7Vmvzdv2 +ojyW1tpdEFuY/mCpYWsSrm3v1SNavCRshFL92ZouW5HdVFfRggQ3J3c7TvbRbVpP +BTsim4Ef3lxXhLSJwVeS +=4n+5 +-----END PGP SIGNATURE----- diff --git a/python-ping_0.2-1_all.deb b/python-ping_0.2-1_all.deb new file mode 100644 index 0000000..393916e Binary files /dev/null and b/python-ping_0.2-1_all.deb differ diff --git a/python-ping_0.2-1_amd64.build b/python-ping_0.2-1_amd64.build new file mode 100644 index 0000000..c9b6708 --- /dev/null +++ b/python-ping_0.2-1_amd64.build @@ -0,0 +1,145 @@ + dpkg-buildpackage -rfakeroot -D -us -uc +dpkg-buildpackage: export CFLAGS from dpkg-buildflags (origin: vendor): -g -O2 +dpkg-buildpackage: export CPPFLAGS from dpkg-buildflags (origin: vendor): +dpkg-buildpackage: export CXXFLAGS from dpkg-buildflags (origin: vendor): -g -O2 +dpkg-buildpackage: export FFLAGS from dpkg-buildflags (origin: vendor): -g -O2 +dpkg-buildpackage: export LDFLAGS from dpkg-buildflags (origin: vendor): +dpkg-buildpackage: source package python-ping +dpkg-buildpackage: source version 0.2-1 +dpkg-buildpackage: source changed by Kristina Clair + dpkg-source --before-build ping-0.2 +dpkg-buildpackage: host architecture amd64 + fakeroot debian/rules clean +dh clean + dh_testdir + dh_auto_clean +running clean +'build/lib' does not exist -- can't clean it +'build/bdist.linux-x86_64' does not exist -- can't clean it +'build/scripts-2.5' does not exist -- can't clean it +running clean +'build/lib.linux-x86_64-2.6' does not exist -- can't clean it +'build/bdist.linux-x86_64' does not exist -- can't clean it +'build/scripts-2.6' does not exist -- can't clean it + dh_clean + dpkg-source -b ping-0.2 +dpkg-source: info: using source format `3.0 (quilt)' +dpkg-source: info: building python-ping using existing ./python-ping_0.2.orig.tar.gz +dpkg-source: info: building python-ping in python-ping_0.2-1.debian.tar.gz +dpkg-source: info: building python-ping in python-ping_0.2-1.dsc + debian/rules build +dh build + dh_testdir + dh_auto_configure + dh_auto_build +running build +running build_py +creating build +creating build/lib +copying ping.py -> build/lib +running build +running build_py +creating build/lib.linux-x86_64-2.6 +copying ping.py -> build/lib.linux-x86_64-2.6 + dh_auto_test + fakeroot debian/rules binary +dh binary + dh_testroot + dh_prep + dh_installdirs + dh_auto_install +running install +running build +running build_py +running install_lib +creating /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr +creating /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib +creating /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.5 +creating /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.5/site-packages +copying build/lib/ping.py -> /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.5/site-packages +running install_egg_info +Writing /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.5/site-packages/ping-0.2.egg-info +running install +running build +running build_py +running install_lib +creating /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.6 +creating /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.6/dist-packages +copying build/lib.linux-x86_64-2.6/ping.py -> /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.6/dist-packages +running install_egg_info +Writing /home/kclair/dev/leap/build-deb/deps/python-ping/ping-0.2/debian/python-ping/usr/lib/python2.6/dist-packages/ping-0.2.egg-info + dh_install + dh_installdocs + dh_installchangelogs + dh_installexamples + dh_installman + dh_installcatalogs + dh_installcron + dh_installdebconf + dh_installemacsen + dh_installifupdown + dh_installinfo + dh_pysupport + dh_installinit + dh_installmenu + dh_installmime + dh_installmodules + dh_installlogcheck + dh_installlogrotate + dh_installpam + dh_installppp + dh_installudev + dh_installwm + dh_installxfonts + dh_bugfiles + dh_lintian + dh_gconf + dh_icons + dh_perl + dh_usrlocal + dh_link + dh_compress + dh_fixperms + dh_strip + dh_makeshlibs + dh_shlibdeps + dh_installdeb + dh_gencontrol + dh_md5sums + dh_builddeb +dpkg-deb: warning: 'debian/python-ping/DEBIAN/control' contains user-defined field 'Python-Version' +dpkg-deb: warning: ignoring 1 warning about the control file(s) + +dpkg-deb: building package `python-ping' in `../python-ping_0.2-1_all.deb'. + dpkg-genchanges >../python-ping_0.2-1_amd64.changes +dpkg-genchanges: including full source code in upload + dpkg-source --after-build ping-0.2 +dpkg-buildpackage: full upload (original source is included) +Now running lintian... +W: python-ping source: dh-make-template-in-source debian/emacsen-startup.ex +W: python-ping source: dh-make-template-in-source debian/python-ping.default.ex +W: python-ping source: dh-make-template-in-source debian/init.d.ex +W: python-ping source: dh-make-template-in-source debian/manpage.1.ex +W: python-ping source: dh-make-template-in-source debian/postinst.ex +W: python-ping source: dh-make-template-in-source debian/python-ping.doc-base.EX +W: python-ping source: dh-make-template-in-source debian/menu.ex +W: python-ping source: dh-make-template-in-source debian/watch.ex +W: python-ping source: dh-make-template-in-source debian/manpage.sgml.ex +W: python-ping source: dh-make-template-in-source debian/emacsen-install.ex +W: python-ping source: dh-make-template-in-source debian/emacsen-remove.ex +W: python-ping source: dh-make-template-in-source debian/manpage.xml.ex +W: python-ping source: dh-make-template-in-source debian/python-ping.cron.d.ex +W: python-ping source: dh-make-template-in-source debian/postrm.ex +W: python-ping source: dh-make-template-in-source debian/preinst.ex +W: python-ping source: dh-make-template-in-source debian/prerm.ex +W: python-ping source: ancient-standards-version 3.8.4 (current is 3.9.1) +W: python-ping: readme-debian-contains-debmake-template +W: python-ping: new-package-should-close-itp-bug +W: python-ping: wrong-bug-number-in-closes l3:#nnnn +Finished running lintian. +Now signing changes and any dsc files... + signfile python-ping_0.2-1.dsc Kristina Clair + + signfile python-ping_0.2-1_amd64.changes Kristina Clair + +Successfully signed dsc and changes files diff --git a/python-ping_0.2-1_amd64.changes b/python-ping_0.2-1_amd64.changes new file mode 100644 index 0000000..95c1755 --- /dev/null +++ b/python-ping_0.2-1_amd64.changes @@ -0,0 +1,53 @@ +-----BEGIN PGP SIGNED MESSAGE----- +Hash: SHA1 + +Format: 1.8 +Date: Wed, 03 Oct 2012 11:59:08 -0700 +Source: python-ping +Binary: python-ping +Architecture: source all +Version: 0.2-1 +Distribution: unstable +Urgency: low +Maintainer: Kristina Clair +Changed-By: Kristina Clair +Description: + python-ping - An implementation of ICMP ping in Python +Changes: + python-ping (0.2-1) unstable; urgency=low + . + * Initial release (Closes: #nnnn) +Checksums-Sha1: + 053169e567e00dab3a5c0fdef646a40082e8c0d5 1689 python-ping_0.2-1.dsc + 54b7ece233794e06193bfc0983117259c554eed0 10979 python-ping_0.2.orig.tar.gz + 75f5a6bb4302e3be2ad827053d2b562c719c9adc 11225 python-ping_0.2-1.debian.tar.gz + 05bd9123809f4281c266a3c936aa0ddceec9b79e 6356 python-ping_0.2-1_all.deb +Checksums-Sha256: + ee0a257b2f5b6d9315b527cf27c34ff3ca046e3921c5a5176e9056c8fa7b969b 1689 python-ping_0.2-1.dsc + ecb32294c2af8ae075de4a3743f568db376480ad81c2e010a7f1ce1cee7b030f 10979 python-ping_0.2.orig.tar.gz + c80a002fabe73635d7449106aaeb9c30369c6ec034297fcd9253a758edabedfc 11225 python-ping_0.2-1.debian.tar.gz + 04c3b83ca611546abd5c15e6f28e300aefd878b0493685f46f4ca76636e6a760 6356 python-ping_0.2-1_all.deb +Files: + b5d8cf120d1c2f3d9c23a7a07de9d263 1689 python optional python-ping_0.2-1.dsc + 57228e54268390ca2fef5181d5568e38 10979 python optional python-ping_0.2.orig.tar.gz + 65ef7c284d45cad2c5b74a49348eae4b 11225 python optional python-ping_0.2-1.debian.tar.gz + af0da519f645b37c1ac3491a4a3365b8 6356 python optional python-ping_0.2-1_all.deb + +-----BEGIN PGP SIGNATURE----- +Version: GnuPG v1.4.10 (GNU/Linux) +Comment: GPGTools - http://gpgtools.org + +iQIcBAEBAgAGBQJQbIt1AAoJEJ6m/xxX04TjGakQAIkpZ94pHsPkchxbsyVBqchF +fC20xFqVUmQZF4BbdFzIAKi0R1WIouQbt4QgclyHCj0eYJ2U2nD16JdPIw60UQ59 +/j2lOj5hY6Vt/GoJoDpGE9Vouh+4dpx29lXYecN7wXRhWF3JcAcnCeemahXSfce+ +Jj3GjgK9M2M4kltDjVvwS/PN9dIT0/wvtUoasl9fjBSt9so5jv2aZWa13++7Yhtp +1S8KX2bY1+fncqnqmabSlBm7wO3qfKgtTwOVB2H7IyVW5wacFaWq75uxmkBW2jcH +YowirD8iq6X5eA41diE01i1qnymI/yZT1BXTwoeLfz72n+y2DJX6K/VDUIEznfKY +/oiT2igEhZ4iXtT2ej7y9DF6sVRVVZN1zRXCv8GVB7wNjh7twmrSDm7Z+YMyDQu5 +Bf5Hi1KQAfdsklT4TthSoNZU3PwXFNtN2ww/58jG3AJNqQMAnM7F/SQkMpJIY7F1 +NfQEgfEEfdq4NbTLbVGypfdRgJT/fL61rtO78zrSQZvEJ9X3Lz1d/E7FEP9PBeEO +jvB9tYp7pOTk5pneU/Bs0EhJUEl04HwWEbdc52Xc5jhUAlFi9eHErwvptHyXlgmb +dVzQazPNl6Fxjbo4oQil+XZhLXFNuN7Uf9c60Wm9ai4BVpDxd9Bnd5uOtOz3Xhic +adsc/j/TI1mUNOcEvJiD +=2bPn +-----END PGP SIGNATURE----- diff --git a/python-ping_0.2.orig.tar.gz b/python-ping_0.2.orig.tar.gz new file mode 100644 index 0000000..23a5b46 Binary files /dev/null and b/python-ping_0.2.orig.tar.gz differ -- cgit v1.2.3