summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authork clair <kclair@riseup.net>2012-10-09 12:55:01 -0700
committerk clair <kclair@riseup.net>2012-10-09 12:55:01 -0700
commitdeeb9c4852c699ad26a5d81cdf13176cb6c2e114 (patch)
treee77c87015b276f80f9d727ffeb7e9904adc74dbd
parente7f841ebffe2a1631a3bd8056b2aa2182184fc8a (diff)
add previously generated debian packaging files
-rw-r--r--ping-0.2/AUTHORS8
-rw-r--r--ping-0.2/COPYING339
-rw-r--r--ping-0.2/MANIFEST.in4
-rw-r--r--ping-0.2/README9
-rw-r--r--ping-0.2/build/lib.linux-x86_64-2.6/ping.py273
-rw-r--r--ping-0.2/build/lib/ping.py273
-rw-r--r--ping-0.2/debian/README.Debian6
-rw-r--r--ping-0.2/debian/README.source9
-rw-r--r--ping-0.2/debian/changelog5
-rw-r--r--ping-0.2/debian/compat1
-rw-r--r--ping-0.2/debian/control23
-rw-r--r--ping-0.2/debian/copyright42
-rw-r--r--ping-0.2/debian/docs1
-rw-r--r--ping-0.2/debian/emacsen-install.ex45
-rw-r--r--ping-0.2/debian/emacsen-remove.ex15
-rw-r--r--ping-0.2/debian/emacsen-startup.ex25
-rw-r--r--ping-0.2/debian/files1
-rw-r--r--ping-0.2/debian/init.d.ex154
-rw-r--r--ping-0.2/debian/manpage.1.ex59
-rw-r--r--ping-0.2/debian/manpage.sgml.ex154
-rw-r--r--ping-0.2/debian/manpage.xml.ex291
-rw-r--r--ping-0.2/debian/menu.ex2
-rw-r--r--ping-0.2/debian/postinst.ex39
-rw-r--r--ping-0.2/debian/postrm.ex37
-rw-r--r--ping-0.2/debian/preinst.ex35
-rw-r--r--ping-0.2/debian/prerm.ex38
-rw-r--r--ping-0.2/debian/python-ping.cron.d.ex4
-rw-r--r--ping-0.2/debian/python-ping.debhelper.log45
-rw-r--r--ping-0.2/debian/python-ping.default.ex10
-rw-r--r--ping-0.2/debian/python-ping.doc-base.EX20
-rw-r--r--ping-0.2/debian/python-ping.postinst.debhelper5
-rw-r--r--ping-0.2/debian/python-ping.prerm.debhelper5
-rw-r--r--ping-0.2/debian/python-ping.substvars4
-rw-r--r--ping-0.2/debian/python-ping/DEBIAN/control20
-rw-r--r--ping-0.2/debian/python-ping/DEBIAN/md5sums7
-rwxr-xr-xping-0.2/debian/python-ping/DEBIAN/postinst7
-rwxr-xr-xping-0.2/debian/python-ping/DEBIAN/prerm7
-rw-r--r--ping-0.2/debian/python-ping/usr/share/doc/python-ping/README9
-rw-r--r--ping-0.2/debian/python-ping/usr/share/doc/python-ping/README.Debian6
-rw-r--r--ping-0.2/debian/python-ping/usr/share/doc/python-ping/changelog.Debian.gzbin0 -> 176 bytes
-rw-r--r--ping-0.2/debian/python-ping/usr/share/doc/python-ping/copyright42
-rw-r--r--ping-0.2/debian/python-ping/usr/share/pyshared/ping-0.2.egg-info31
-rw-r--r--ping-0.2/debian/python-ping/usr/share/pyshared/ping.py273
-rw-r--r--ping-0.2/debian/python-ping/usr/share/python-support/python-ping.public2
-rwxr-xr-xping-0.2/debian/rules13
-rw-r--r--ping-0.2/debian/source/format1
-rw-r--r--ping-0.2/debian/watch.ex23
-rw-r--r--ping-0.2/ping.py273
-rw-r--r--ping-0.2/ping.pycbin0 -> 7966 bytes
-rw-r--r--ping-0.2/setup.py53
-rw-r--r--python-ping_0.2-1.debian.tar.gzbin0 -> 11225 bytes
-rw-r--r--python-ping_0.2-1.dsc39
-rw-r--r--python-ping_0.2-1_all.debbin0 -> 6356 bytes
-rw-r--r--python-ping_0.2-1_amd64.build145
-rw-r--r--python-ping_0.2-1_amd64.changes53
-rw-r--r--python-ping_0.2.orig.tar.gzbin0 -> 10979 bytes
56 files changed, 2985 insertions, 0 deletions
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 <delroth@gmail.com>.
+
+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.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License along
+ with this program; if not, write to the Free Software Foundation, Inc.,
+ 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.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU 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, <http://www.visi.com/~mdc/>.
+ 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, <http://www.visi.com/~mdc/>.
+ 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
+----------------------
+
+<possible notes regarding this package - if none, delete this file>
+
+ -- Kristina Clair <kclair@leap.se> 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
+----------------------
+
+<this file describes information about the source package, see Debian policy
+manual section 4.14. You WILL either need to modify or delete this file>
+
+
+
+
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) <nnnn is the bug number of your ITP>
+
+ -- Kristina Clair <kclair@leap.se> 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 <kclair@leap.se>
+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 <kclair@leap.se> 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 <http://www.gnu.org/licenses/>
+
+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 <kclair@leap.se>
+
+ 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 <jrv@debian.org>, borrowing heavily
+# from the install scripts for gettext by Santiago Vila
+# <sanvila@ctv.es> and octave by Dirk Eddelbuettel <edd@debian.org>.
+
+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 <naumann@unileoben.ac.at>
+;; Modified by Dirk Eddelbuettel <edd@debian.org>
+;; Adapted for dh-make by Jim Van Zandt <jrv@debian.org>
+
+;; 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: <Enter a short description of the sortware>
+# Description: <Enter a long description of the software>
+# <...>
+# <...>
+### END INIT INFO
+
+# Author: Kristina Clair <kclair@leap.se>
+
+# 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 <n> 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<whatever>\fP and
+.\" \fI<whatever>\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 <upstream author>.
+.PP
+This manual page was written by Kristina Clair <kclair@leap.se>,
+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 @@
+<!doctype refentry PUBLIC "-//OASIS//DTD DocBook V4.1//EN" [
+
+<!-- Process this file with docbook-to-man to generate an nroff manual
+ page: `docbook-to-man manpage.sgml > 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.
+
+ -->
+
+ <!-- Fill in your name for FIRSTNAME and SURNAME. -->
+ <!ENTITY dhfirstname "<firstname>FIRSTNAME</firstname>">
+ <!ENTITY dhsurname "<surname>SURNAME</surname>">
+ <!-- Please adjust the date whenever revising the manpage. -->
+ <!ENTITY dhdate "<date>October 3, 2012</date>">
+ <!-- SECTION should be 1-8, maybe w/ subsection other parameters are
+ allowed: see man(7), man(1). -->
+ <!ENTITY dhsection "<manvolnum>SECTION</manvolnum>">
+ <!ENTITY dhemail "<email>kclair@leap.se</email>">
+ <!ENTITY dhusername "Kristina Clair">
+ <!ENTITY dhucpackage "<refentrytitle>PYTHON-PING</refentrytitle>">
+ <!ENTITY dhpackage "python-ping">
+
+ <!ENTITY debian "<productname>Debian</productname>">
+ <!ENTITY gnu "<acronym>GNU</acronym>">
+ <!ENTITY gpl "&gnu; <acronym>GPL</acronym>">
+]>
+
+<refentry>
+ <refentryinfo>
+ <address>
+ &dhemail;
+ </address>
+ <author>
+ &dhfirstname;
+ &dhsurname;
+ </author>
+ <copyright>
+ <year>2003</year>
+ <holder>&dhusername;</holder>
+ </copyright>
+ &dhdate;
+ </refentryinfo>
+ <refmeta>
+ &dhucpackage;
+
+ &dhsection;
+ </refmeta>
+ <refnamediv>
+ <refname>&dhpackage;</refname>
+
+ <refpurpose>program to do something</refpurpose>
+ </refnamediv>
+ <refsynopsisdiv>
+ <cmdsynopsis>
+ <command>&dhpackage;</command>
+
+ <arg><option>-e <replaceable>this</replaceable></option></arg>
+
+ <arg><option>--example <replaceable>that</replaceable></option></arg>
+ </cmdsynopsis>
+ </refsynopsisdiv>
+ <refsect1>
+ <title>DESCRIPTION</title>
+
+ <para>This manual page documents briefly the
+ <command>&dhpackage;</command> and <command>bar</command>
+ commands.</para>
+
+ <para>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;
+ <application>Info</application> format; see below.</para>
+
+ <para><command>&dhpackage;</command> is a program that...</para>
+
+ </refsect1>
+ <refsect1>
+ <title>OPTIONS</title>
+
+ <para>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
+ <application>Info</application> files.</para>
+
+ <variablelist>
+ <varlistentry>
+ <term><option>-h</option>
+ <option>--help</option>
+ </term>
+ <listitem>
+ <para>Show summary of options.</para>
+ </listitem>
+ </varlistentry>
+ <varlistentry>
+ <term><option>-v</option>
+ <option>--version</option>
+ </term>
+ <listitem>
+ <para>Show version of program.</para>
+ </listitem>
+ </varlistentry>
+ </variablelist>
+ </refsect1>
+ <refsect1>
+ <title>SEE ALSO</title>
+
+ <para>bar (1), baz (1).</para>
+
+ <para>The programs are documented fully by <citetitle>The Rise and
+ Fall of a Fooish Bar</citetitle> available via the
+ <application>Info</application> system.</para>
+ </refsect1>
+ <refsect1>
+ <title>AUTHOR</title>
+
+ <para>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.
+ </para>
+ <para>
+ On Debian systems, the complete text of the GNU General Public
+ License can be found in /usr/share/common-licenses/GPL.
+ </para>
+
+ </refsect1>
+</refentry>
+
+<!-- Keep this comment at the end of the file
+Local variables:
+mode: sgml
+sgml-omittag:t
+sgml-shorttag:t
+sgml-minimize-attributes:nil
+sgml-always-quote-attributes:t
+sgml-indent-step:2
+sgml-indent-data:t
+sgml-parent-document:nil
+sgml-default-dtd-file:nil
+sgml-exposed-tags:nil
+sgml-local-catalogs:nil
+sgml-local-ecat-files:nil
+End:
+-->
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 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
+"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+
+<!--
+
+`xsltproc -''-nonet \
+ -''-param man.charmap.use.subset "0" \
+ -''-param make.year.ranges "1" \
+ -''-param make.single.year.ranges "1" \
+ /usr/share/xml/docbook/stylesheet/docbook-xsl/manpages/docbook.xsl \
+ manpage.xml'
+
+A manual page <package>.<section> will be generated. You may view the
+manual page with: nroff -man <package>.<section> | 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
+<refsect1> ... </refsect1>.
+
+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/
+
+-->
+
+ <!-- Fill in your name for FIRSTNAME and SURNAME. -->
+ <!ENTITY dhfirstname "FIRSTNAME">
+ <!ENTITY dhsurname "SURNAME">
+ <!-- dhusername could also be set to "&dhfirstname; &dhsurname;". -->
+ <!ENTITY dhusername "Kristina Clair">
+ <!ENTITY dhemail "kclair@leap.se">
+ <!-- SECTION should be 1-8, maybe w/ subsection other parameters are
+ allowed: see man(7), man(1) and
+ http://www.tldp.org/HOWTO/Man-Page/q2.html. -->
+ <!ENTITY dhsection "SECTION">
+ <!-- TITLE should be something like "User commands" or similar (see
+ http://www.tldp.org/HOWTO/Man-Page/q2.html). -->
+ <!ENTITY dhtitle "python-ping User Manual">
+ <!ENTITY dhucpackage "PYTHON-PING">
+ <!ENTITY dhpackage "python-ping">
+]>
+
+<refentry>
+ <refentryinfo>
+ <title>&dhtitle;</title>
+ <productname>&dhpackage;</productname>
+ <authorgroup>
+ <author>
+ <firstname>&dhfirstname;</firstname>
+ <surname>&dhsurname;</surname>
+ <contrib>Wrote this manpage for the Debian system.</contrib>
+ <address>
+ <email>&dhemail;</email>
+ </address>
+ </author>
+ </authorgroup>
+ <copyright>
+ <year>2007</year>
+ <holder>&dhusername;</holder>
+ </copyright>
+ <legalnotice>
+ <para>This manual page was written for the Debian system
+ (and may be used by others).</para>
+ <para>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.</para>
+ <para>On Debian systems, the complete text of the GNU General Public
+ License can be found in
+ <filename>/usr/share/common-licenses/GPL</filename>.</para>
+ </legalnotice>
+ </refentryinfo>
+ <refmeta>
+ <refentrytitle>&dhucpackage;</refentrytitle>
+ <manvolnum>&dhsection;</manvolnum>
+ </refmeta>
+ <refnamediv>
+ <refname>&dhpackage;</refname>
+ <refpurpose>program to do something</refpurpose>
+ </refnamediv>
+ <refsynopsisdiv>
+ <cmdsynopsis>
+ <command>&dhpackage;</command>
+ <!-- These are several examples, how syntaxes could look -->
+ <arg choice="plain"><option>-e <replaceable>this</replaceable></option></arg>
+ <arg choice="opt"><option>--example=<parameter>that</parameter></option></arg>
+ <arg choice="opt">
+ <group choice="req">
+ <arg choice="plain"><option>-e</option></arg>
+ <arg choice="plain"><option>--example</option></arg>
+ </group>
+ <replaceable class="option">this</replaceable>
+ </arg>
+ <arg choice="opt">
+ <group choice="req">
+ <arg choice="plain"><option>-e</option></arg>
+ <arg choice="plain"><option>--example</option></arg>
+ </group>
+ <group choice="req">
+ <arg choice="plain"><replaceable>this</replaceable></arg>
+ <arg choice="plain"><replaceable>that</replaceable></arg>
+ </group>
+ </arg>
+ </cmdsynopsis>
+ <cmdsynopsis>
+ <command>&dhpackage;</command>
+ <!-- Normally the help and version options make the programs stop
+ right after outputting the requested information. -->
+ <group choice="opt">
+ <arg choice="plain">
+ <group choice="req">
+ <arg choice="plain"><option>-h</option></arg>
+ <arg choice="plain"><option>--help</option></arg>
+ </group>
+ </arg>
+ <arg choice="plain">
+ <group choice="req">
+ <arg choice="plain"><option>-v</option></arg>
+ <arg choice="plain"><option>--version</option></arg>
+ </group>
+ </arg>
+ </group>
+ </cmdsynopsis>
+ </refsynopsisdiv>
+ <refsect1 id="description">
+ <title>DESCRIPTION</title>
+ <para>This manual page documents briefly the
+ <command>&dhpackage;</command> and <command>bar</command>
+ commands.</para>
+ <para>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 <citerefentry>
+ <refentrytitle>info</refentrytitle>
+ <manvolnum>1</manvolnum>
+ </citerefentry> format; see below.</para>
+ <para><command>&dhpackage;</command> is a program that...</para>
+ </refsect1>
+ <refsect1 id="options">
+ <title>OPTIONS</title>
+ <para>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
+ <citerefentry>
+ <refentrytitle>info</refentrytitle>
+ <manvolnum>1</manvolnum>
+ </citerefentry> files.</para>
+ <variablelist>
+ <!-- Use the variablelist.term.separator and the
+ variablelist.term.break.after parameters to
+ control the term elements. -->
+ <varlistentry>
+ <term><option>-e <replaceable>this</replaceable></option></term>
+ <term><option>--example=<replaceable>that</replaceable></option></term>
+ <listitem>
+ <para>Does this and that.</para>
+ </listitem>
+ </varlistentry>
+ <varlistentry>
+ <term><option>-h</option></term>
+ <term><option>--help</option></term>
+ <listitem>
+ <para>Show summary of options.</para>
+ </listitem>
+ </varlistentry>
+ <varlistentry>
+ <term><option>-v</option></term>
+ <term><option>--version</option></term>
+ <listitem>
+ <para>Show version of program.</para>
+ </listitem>
+ </varlistentry>
+ </variablelist>
+ </refsect1>
+ <refsect1 id="files">
+ <title>FILES</title>
+ <variablelist>
+ <varlistentry>
+ <term><filename>/etc/foo.conf</filename></term>
+ <listitem>
+ <para>The system-wide configuration file to control the
+ behaviour of <application>&dhpackage;</application>. See
+ <citerefentry>
+ <refentrytitle>foo.conf</refentrytitle>
+ <manvolnum>5</manvolnum>
+ </citerefentry> for further details.</para>
+ </listitem>
+ </varlistentry>
+ <varlistentry>
+ <term><filename>${HOME}/.foo.conf</filename></term>
+ <listitem>
+ <para>The per-user configuration file to control the
+ behaviour of <application>&dhpackage;</application>. See
+ <citerefentry>
+ <refentrytitle>foo.conf</refentrytitle>
+ <manvolnum>5</manvolnum>
+ </citerefentry> for further details.</para>
+ </listitem>
+ </varlistentry>
+ </variablelist>
+ </refsect1>
+ <refsect1 id="environment">
+ <title>ENVIONMENT</title>
+ <variablelist>
+ <varlistentry>
+ <term><envar>FOO_CONF</envar></term>
+ <listitem>
+ <para>If used, the defined file is used as configuration
+ file (see also <xref linkend="files"/>).</para>
+ </listitem>
+ </varlistentry>
+ </variablelist>
+ </refsect1>
+ <refsect1 id="diagnostics">
+ <title>DIAGNOSTICS</title>
+ <para>The following diagnostics may be issued
+ on <filename class="devicefile">stderr</filename>:</para>
+ <variablelist>
+ <varlistentry>
+ <term><errortext>Bad configuration file. Exiting.</errortext></term>
+ <listitem>
+ <para>The configuration file seems to contain a broken configuration
+ line. Use the <option>--verbose</option> option, to get more info.
+ </para>
+ </listitem>
+ </varlistentry>
+ </variablelist>
+ <para><command>&dhpackage;</command> provides some return codes, that can
+ be used in scripts:</para>
+ <segmentedlist>
+ <segtitle>Code</segtitle>
+ <segtitle>Diagnostic</segtitle>
+ <seglistitem>
+ <seg><errorcode>0</errorcode></seg>
+ <seg>Program exited successfully.</seg>
+ </seglistitem>
+ <seglistitem>
+ <seg><errorcode>1</errorcode></seg>
+ <seg>The configuration file seems to be broken.</seg>
+ </seglistitem>
+ </segmentedlist>
+ </refsect1>
+ <refsect1 id="bugs">
+ <!-- Or use this section to tell about upstream BTS. -->
+ <title>BUGS</title>
+ <para>The program is currently limited to only work
+ with the <package>foobar</package> library.</para>
+ <para>The upstreams <acronym>BTS</acronym> can be found
+ at <ulink url="http://bugzilla.foo.tld"/>.</para>
+ </refsect1>
+ <refsect1 id="see_also">
+ <title>SEE ALSO</title>
+ <!-- In alpabetical order. -->
+ <para><citerefentry>
+ <refentrytitle>bar</refentrytitle>
+ <manvolnum>1</manvolnum>
+ </citerefentry>, <citerefentry>
+ <refentrytitle>baz</refentrytitle>
+ <manvolnum>1</manvolnum>
+ </citerefentry>, <citerefentry>
+ <refentrytitle>foo.conf</refentrytitle>
+ <manvolnum>5</manvolnum>
+ </citerefentry></para>
+ <para>The programs are documented fully by <citetitle>The Rise and
+ Fall of a Fooish Bar</citetitle> available via the <citerefentry>
+ <refentrytitle>info</refentrytitle>
+ <manvolnum>1</manvolnum>
+ </citerefentry> system.</para>
+ </refsect1>
+</refentry>
+
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:
+# * <postinst> `configure' <most-recently-configured-version>
+# * <old-postinst> `abort-upgrade' <new version>
+# * <conflictor's-postinst> `abort-remove' `in-favour' <package>
+# <new-version>
+# * <postinst> `abort-remove'
+# * <deconfigured's-postinst> `abort-deconfigure' `in-favour'
+# <failed-install-package> <version> `removing'
+# <conflicting-package> <version>
+# 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:
+# * <postrm> `remove'
+# * <postrm> `purge'
+# * <old-postrm> `upgrade' <new-version>
+# * <new-postrm> `failed-upgrade' <old-version>
+# * <new-postrm> `abort-install'
+# * <new-postrm> `abort-install' <old-version>
+# * <new-postrm> `abort-upgrade' <old-version>
+# * <disappearer's-postrm> `disappear' <overwriter>
+# <overwriter-version>
+# 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:
+# * <new-preinst> `install'
+# * <new-preinst> `install' <old-version>
+# * <new-preinst> `upgrade' <old-version>
+# * <old-preinst> `abort-upgrade' <new-version>
+# 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:
+# * <prerm> `remove'
+# * <old-prerm> `upgrade' <new-version>
+# * <new-prerm> `failed-upgrade' <old-version>
+# * <conflictor's-prerm> `remove' `in-favour' <package> <new-version>
+# * <deconfigured's-prerm> `deconfigure' `in-favour'
+# <package-being-installed> <version> `removing'
+# <conflicting-package> <version>
+# 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: <insert document author here>
+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 <kclair@leap.se>
+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
+----------------------
+
+<possible notes regarding this package - if none, delete this file>
+
+ -- Kristina Clair <kclair@leap.se> 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
--- /dev/null
+++ b/ping-0.2/debian/python-ping/usr/share/doc/python-ping/changelog.Debian.gz
Binary files 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 <kclair@leap.se> 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 <http://www.gnu.org/licenses/>
+
+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 <kclair@leap.se>
+
+ 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, <http://www.visi.com/~mdc/>.
+ 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
+# <Webpage URL> <string match>
+#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, <http://www.visi.com/~mdc/>.
+ 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
--- /dev/null
+++ b/ping-0.2/ping.pyc
Binary files 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 <delroth@gmail.com>
+
+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 <http://www.gnu.org/licenses/>.
+"""
+
+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
--- /dev/null
+++ b/python-ping_0.2-1.debian.tar.gz
Binary files 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 <kclair@leap.se>
+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
--- /dev/null
+++ b/python-ping_0.2-1_all.deb
Binary files 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 <kclair@leap.se>
+ 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 <kclair@leap.se>
+
+ signfile python-ping_0.2-1_amd64.changes Kristina Clair <kclair@leap.se>
+
+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 <kclair@leap.se>
+Changed-By: Kristina Clair <kclair@leap.se>
+Description:
+ python-ping - An implementation of ICMP ping in Python
+Changes:
+ python-ping (0.2-1) unstable; urgency=low
+ .
+ * Initial release (Closes: #nnnn) <nnnn is the bug number of your ITP>
+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
--- /dev/null
+++ b/python-ping_0.2.orig.tar.gz
Binary files differ