All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.com.ibm.as400.access.AS400PortMapDS Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                                 
//                                                                             
// Filename: AS400PortMapDS.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2001 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.io.IOException;
import java.io.OutputStream;

// A class representing a "port map" request data stream.  This is a special request class that does not derive from the DataStream class.  The DataStream class defines data streams that originate from or are destined to a server job.
class AS400PortMapDS
{
  private static final String copyright = "Copyright (C) 1997-2001 International Business Machines Corporation and others.";

    byte[] data_;
    private int connectionID_;

    // Create request, data is name of server in ASCII.
    AS400PortMapDS(String server)
    {
        // Cheat conversion from Unicode to ASCII by casting away the high byte.
        // Server names use an acceptable restricted character set.
        char[] uniChars = server.toCharArray();
        data_ = new byte[uniChars.length];
        for (int i = 0; i < uniChars.length; ++i)
        {
            data_[i] = (byte)uniChars[i];
        }
    }

    // Set the connection ID associated with this data stream.
    // @param  connectionID  the connection ID.
    void setConnectionID(int connectionID)
    {
      connectionID_ = connectionID;
    }

    // Send request to the port mapper.
    void write(OutputStream out) throws IOException
    {
        if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "Sending port mapper request..."); //@P0C
        synchronized(out)
        {
            out.write(data_);
            out.flush();
        }
        if (Trace.traceOn_) Trace.log(Trace.DATASTREAM, "Data stream sent (connID="+connectionID_+") ...", data_); //@P0C
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy