summaryrefslogtreecommitdiffstats
path: root/Demo/sockets/mcast.py
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1992-11-16 16:54:45 (GMT)
committerGuido van Rossum <guido@python.org>1992-11-16 16:54:45 (GMT)
commitbd07b31d8283f08a6f1e68c232aa88c3ccaa0953 (patch)
tree510853ca986ae429cd64ed4df7ee4001838a0c27 /Demo/sockets/mcast.py
parent21974798ced0eafef0b331a69f96222400859232 (diff)
downloadcpython-bd07b31d8283f08a6f1e68c232aa88c3ccaa0953.zip
cpython-bd07b31d8283f08a6f1e68c232aa88c3ccaa0953.tar.gz
cpython-bd07b31d8283f08a6f1e68c232aa88c3ccaa0953.tar.bz2
Restructured into several subroutines.
Diffstat (limited to 'Demo/sockets/mcast.py')
-rwxr-xr-xDemo/sockets/mcast.py76
1 files changed, 57 insertions, 19 deletions
diff --git a/Demo/sockets/mcast.py b/Demo/sockets/mcast.py
index c2bcaef..4011383 100755
--- a/Demo/sockets/mcast.py
+++ b/Demo/sockets/mcast.py
@@ -14,14 +14,23 @@ import struct
import regsub
from socket import *
from SOCKET import *
-from IN import * # Local module, SGI specific!!!
+from IN import * # SGI specific!!! (Sorry)
-sender = sys.argv[1:]
-s = socket(AF_INET, SOCK_DGRAM)
+# Main program
+def main():
+ flags = sys.argv[1:]
+ #
+ if flags:
+ sender(flags[0])
+ else:
+ receiver()
+
-if sender:
- if sys.argv[1] == '-b':
+# Sender subroutine (only one per local area network)
+def sender(flag):
+ s = socket(AF_INET, SOCK_DGRAM)
+ if flag == '-b':
s.setsockopt(SOL_SOCKET, SO_BROADCAST, 1)
mygroup = '<broadcast>'
else:
@@ -33,27 +42,56 @@ if sender:
## data = data + (1400 - len(data)) * '\0'
s.sendto(data, (mygroup, MYPORT))
time.sleep(1)
-else:
- # Allow multiple copies of this program on one machine
- s.setsockopt(SOL_SOCKET, SO_REUSEPORT, 1) # (Not strictly needed)
- # Bind the socket to my port
- s.bind('', MYPORT)
- # Construct binary group address from MYGROUP converted to bytes
- bytes = eval(regsub.gsub('\.', ',', MYGROUP))
+# Receiver subroutine (as many as you like)
+def receiver():
+ # Open and initialize the socket
+ s = openmcastsock(MYGROUP, MYPORT)
+ #
+ # Loop, printing any data we receive
+ while 1:
+ data, sender = s.recvfrom(1500)
+ while data[-1:] == '\0': data = data[:-1] # Strip trailing \0's
+ print sender, ':', `data`
+
+
+# Open a UDP socket, bind it to a port and select a multicast group
+def openmcastsock(group, port):
+ # Import modules used only here
+ import regsub
+ import socket
+ import struct
+ from SOCKET import *
+ from IN import *
+ #
+ # Create a socket
+ s = socket.socket(AF_INET, SOCK_DGRAM)
+ #
+ # Allow multiple copies of this program on one machine
+ # (not strictly needed)
+ s.setsockopt(SOL_SOCKET, SO_REUSEPORT, 1)
+ #
+ # Bind it to the port
+ s.bind('', port)
+ #
+ # Look up multicast group address in name server
+ # (doesn't hurt if it is already in ddd.ddd.ddd.ddd format)
+ group = socket.gethostbyname(group)
+ #
+ # Construct binary group address
+ bytes = eval(regsub.gsub('\.', ',', group))
grpaddr = 0
for byte in bytes: grpaddr = (grpaddr << 8) | byte
-
+ #
# Construct struct mreq from grpaddr and ifaddr
ifaddr = INADDR_ANY
mreq = struct.pack('ll', grpaddr, ifaddr)
-
+ #
# Add group membership
s.setsockopt(IPPROTO_IP, IP_ADD_MEMBERSHIP, mreq)
+ #
+ return s
- # Loop, printing any data we receive
- while 1:
- data, sender = s.recvfrom(1500)
- while data[-1:] == '\0': data = data[:-1] # Strip trailing \0's
- print sender, ':', `data`
+
+main()