home *** CD-ROM | disk | FTP | other *** search
/ PC World Komputer 1995 November / PCWK1195.iso / inne / win95 / sieciowe / hotja32.lzh / hotjava / classsrc / net / socketoutputstream.java < prev    next >
Text File  |  1995-08-11  |  2KB  |  66 lines

  1. /*
  2.  * @(#)SocketOutputStream.java    1.10 95/05/10 Jonathan Payne
  3.  *
  4.  * Copyright (c) 1994 Sun Microsystems, Inc. All Rights Reserved.
  5.  *
  6.  * Permission to use, copy, modify, and distribute this software
  7.  * and its documentation for NON-COMMERCIAL purposes and without
  8.  * fee is hereby granted provided that this copyright notice
  9.  * appears in all copies. Please refer to the file "copyright.html"
  10.  * for further important copyright and licensing information.
  11.  *
  12.  * SUN MAKES NO REPRESENTATIONS OR WARRANTIES ABOUT THE SUITABILITY OF
  13.  * THE SOFTWARE, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
  14.  * TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
  15.  * PARTICULAR PURPOSE, OR NON-INFRINGEMENT. SUN SHALL NOT BE LIABLE FOR
  16.  * ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
  17.  * DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES.
  18.  */
  19.  
  20. package net;
  21.  
  22. import  java.io.*;
  23. import  java.util.*;
  24.  
  25. /**
  26.  * This class implements the output (write) side of BSD style UDP sockets.
  27.  * Other protocols such as TCP, ICMP, ARP, etc are not supported at this
  28.  * time. 
  29.  * @version 1.10, 10 May 1995
  30.  * @author Jonathan Payne
  31.  */
  32. class SocketOutputStream extends FileOutputStream {
  33.     private Socket owner;
  34.     
  35.     public SocketOutputStream(Socket owner, int sock) {
  36.     super(sock);
  37.     this.owner = owner;
  38.     }
  39.  
  40.     byte temp[] = new byte[1];
  41.  
  42.     /** write  a byte to the socket. */
  43.     public void write(int b) {
  44.     temp[0] = (byte) b;
  45.     write(temp, 0, 1);
  46.     }
  47.  
  48.     /** 
  49.      * Write contents of buffer <i>b</i> to the socket.
  50.      */
  51.     public void write(byte b[]) {
  52.     write(b, 0, b.length);
  53.     }
  54.  
  55.     /** 
  56.      * Write <i>length</i> bytes from buffer <i>b</i> starting at offset 
  57.      * <i>len</i>
  58.      */
  59.     public native void write(byte b[], int off, int len);
  60.  
  61.     /** override finalize, the fd is closed by the Socket */
  62.     protected void finalize() {
  63.     }
  64. }
  65.  
  66.