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

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

The newest version!
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: IFSChangeAttrsReq.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-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;


/**
"Change attributes" request.
**/
class IFSChangeAttrsReq extends IFSDataStreamReq
{
  private static final int HEADER_LENGTH = 20;

  private static final int FILE_HANDLE_OFFSET = 22;
  private static final int CCSID_OFFSET = 26;  // CCSID of the filename
  private static final int WORKING_DIR_HANDLE_OFFSET = 28;
  private static final int ATTR_LIST_LEVEL_OFFSET = 32;
  private static final int CREATE_DATE_OFFSET = 34;
  private static final int MODIFY_DATE_OFFSET = 42;
  private static final int ACCESS_DATE_OFFSET = 50;
  private static final int SET_FLAGS_OFFSET = 58;
  private static final int FIXED_ATTRS_OFFSET = 60;
  private static final int FILE_SIZE_OFFSET = 64;

  // Additional field if datastreamLevel >= 16:
  private static final int LARGE_FILE_SIZE_OFFSET = 68;

/**
Construct a change attributes request.  Use this request to change
the size of the file by file handle (the file is open)
@param fileHandle handle of file to change
@param fileSize the desired file size in bytes
@param datastreamLevel the datastream level of the server
**/
  IFSChangeAttrsReq(int  fileHandle,
                    long fileSize,
                    int  datastreamLevel)
  {
    super(HEADER_LENGTH + getTemplateLength(datastreamLevel));  // No optional/variable fields are used here.
    setLength(data_.length);
    setTemplateLen(getTemplateLength(datastreamLevel));
    setReqRepID(0x000b);
    set32bit(fileHandle, FILE_HANDLE_OFFSET);
    set32bit(1, WORKING_DIR_HANDLE_OFFSET);
    set16bit(1, ATTR_LIST_LEVEL_OFFSET);
    setData(0L, CREATE_DATE_OFFSET);
    setData(0L, MODIFY_DATE_OFFSET);
    setData(0L, ACCESS_DATE_OFFSET);
    set16bit(1, SET_FLAGS_OFFSET);

    setFileSizeFields(fileSize, datastreamLevel);
  }

/**
Construct a change attributes request.  Use this form to change the
date/time stamps of the file by handle (the file is open).
@param fileHandle handle of file to change
@param createDate the desired creation date (measured in milliseconds since
January 1, 1970 00:00:00 GMT)
@param modifyDate the desired last modification date (measured in milliseconds since
January 1, 1970 00:00:00 GMT)
@param accessDate the desired last access date (measured in milliseconds since
January 1, 1970 00:00:00 GMT)
**/
  IFSChangeAttrsReq(int  fileHandle,
                    long createDate,
                    long modifyDate,
                    long accessDate,
                    int  datastreamLevel)
  {
    super(HEADER_LENGTH + getTemplateLength(datastreamLevel));  // No optional/variable fields are used here.
    setLength(data_.length);
    setTemplateLen(getTemplateLength(datastreamLevel));
    setReqRepID(0x000b);
    set32bit(fileHandle, FILE_HANDLE_OFFSET);
    set32bit(1, WORKING_DIR_HANDLE_OFFSET);
    set16bit(1, ATTR_LIST_LEVEL_OFFSET);
    setDate(createDate, CREATE_DATE_OFFSET);
    setDate(modifyDate, MODIFY_DATE_OFFSET);
    setDate(accessDate, ACCESS_DATE_OFFSET);
    set16bit(0, SET_FLAGS_OFFSET);
  }

/**
Construct a change attributes request.  Use this form to change
the size of the file by file name.
@param fileName the name of the file to change
@param fileNameCCSID file name CCSID
@param fileSize the desired file size in bytes
**/
  IFSChangeAttrsReq(byte[] fileName,
                    int    fileNameCCSID,
                    long   fileSize,
                    int    datastreamLevel)
  {
    super(HEADER_LENGTH + getTemplateLength(datastreamLevel) + 6 + fileName.length);
    setLength(data_.length);
    setTemplateLen(getTemplateLength(datastreamLevel));
    setReqRepID(0x000b);
    set32bit(0, FILE_HANDLE_OFFSET);
    set16bit(fileNameCCSID, CCSID_OFFSET);
    set32bit(1, WORKING_DIR_HANDLE_OFFSET);
    set16bit(1, ATTR_LIST_LEVEL_OFFSET);
    setData(0L, CREATE_DATE_OFFSET);
    setData(0L, MODIFY_DATE_OFFSET);
    setData(0L, ACCESS_DATE_OFFSET);
    set16bit(1, SET_FLAGS_OFFSET);

    setFileSizeFields(fileSize, datastreamLevel);

    // Set the LL.
    set32bit(fileName.length + 6, getFilenameLLOffset(datastreamLevel));

    // Set the code point.
    set16bit(0x0002, getFilenameCPOffset(datastreamLevel));

    // Set the file name characters.
    System.arraycopy(fileName, 0, data_, getFilenameOffset(datastreamLevel), fileName.length);
  }

/**
Construct a change attributes request.  Use this form to change the fixed attributes
of the file.
@param fileName the name of the file to change
@param fileNameCCSID file name CCSID
@param fixedAttributes the fixed attributes to set
@param stuff          an extra boolean that is ignored.  It is needed
                      so the signature of this constructor is unique.
**/
  IFSChangeAttrsReq(byte[]  fileName,                                      //@D1a
                    int     fileNameCCSID,                                 //@D1a
                    int     fixedAttributes,                               //@D1a
                    boolean extraneousDataToMakeSignatureUnique,           //@D1a
                    int     datastreamLevel)
  {                                                                        //@D1a
    super(HEADER_LENGTH + getTemplateLength(datastreamLevel) + 6 + fileName.length);          //@D1a
    setLength(data_.length);                                               //@D1a
    setTemplateLen(getTemplateLength(datastreamLevel));                                       //@D1a
    setReqRepID(0x000b);                                                   //@D1a
    set32bit(0, FILE_HANDLE_OFFSET);                                       //@D1a
    set16bit(fileNameCCSID, CCSID_OFFSET);                                 //@D1a
    set32bit(1, WORKING_DIR_HANDLE_OFFSET);                                //@D1a
    set16bit(1, ATTR_LIST_LEVEL_OFFSET);                                   //@D1a
    setData(0L, CREATE_DATE_OFFSET);                                       //@D1a
    setData(0L, MODIFY_DATE_OFFSET);                                       //@D1a
    setData(0L, ACCESS_DATE_OFFSET);                                       //@D1a
    set16bit(2, SET_FLAGS_OFFSET);                                         //@D1a
    set32bit(fixedAttributes, FIXED_ATTRS_OFFSET);                         //@D1a

    setFileSizeFields(0L, datastreamLevel);
                                                                           //@D1a
    // Set the LL.                                                         //@D1a
    set32bit(fileName.length + 6, getFilenameLLOffset(datastreamLevel));   //@D1a
                                                                           //@D1a
    // Set the code point.                                                 //@D1a
    set16bit(0x0002, getFilenameCPOffset(datastreamLevel));                //@D1a
                                                                           //@D1a
    // Set the file name characters.                                       //@D1a
    System.arraycopy(fileName, 0, data_, getFilenameOffset(datastreamLevel), fileName.length); //@D1a
  }                                                                        //@D1a
                                                                           //@D1a
                                                                           //@D1a

/**
Construct a change attributes request.  Use this form to change the
date/time stamp of the file by file name.
@param fileName the name of the file to change
@param fileNameCCSID file name CCSID
@param createDate the desired creation date (measured in milliseconds since
January 1, 1970 00:00:00 GMT)
@param modifyDate the desired last modification date (measured in milliseconds since
January 1, 1970 00:00:00 GMT)
@param accessDate the desired last access date (measured in milliseconds since
January 1, 1970 00:00:00 GMT)
**/
  IFSChangeAttrsReq(byte[] fileName,
                    int    fileNameCCSID,
                    long   createDate,
                    long   modifyDate,
                    long   accessDate,
                    int    datastreamLevel)
  {
    super(HEADER_LENGTH + getTemplateLength(datastreamLevel) + 6 + fileName.length);
    setLength(data_.length);
    setTemplateLen(getTemplateLength(datastreamLevel));
    setReqRepID(0x000b);
    set32bit(0, FILE_HANDLE_OFFSET);
    set16bit(fileNameCCSID, CCSID_OFFSET);
    set32bit(1, WORKING_DIR_HANDLE_OFFSET);
    set16bit(1, ATTR_LIST_LEVEL_OFFSET);
    setDate(createDate, CREATE_DATE_OFFSET);
    setDate(modifyDate, MODIFY_DATE_OFFSET);
    setDate(accessDate, ACCESS_DATE_OFFSET);
    set16bit(0, SET_FLAGS_OFFSET);

    // Set the LL.
    set32bit(fileName.length + 6, getFilenameLLOffset(datastreamLevel));

    // Set the code point.
    set16bit(0x0002, getFilenameCPOffset(datastreamLevel));

    // Set the file name characters.
    System.arraycopy(fileName, 0, data_, getFilenameOffset(datastreamLevel), fileName.length);
  }


/**
Construct a change attributes request.  Use this form to change the file data CCSID.
@param fileName the name of the file to change
@param fileNameCCSID file name CCSID
@param oa2Structure The updated OA2x structure.  This does not include the LLCP.
**/
  IFSChangeAttrsReq(byte[] fileName,
                    int    fileNameCCSID,
                    IFSObjAttrs2 oa2Structure,
                    int    datastreamLevel)
  {
    super(HEADER_LENGTH + getTemplateLength(datastreamLevel) + 6 + fileName.length + 6 + oa2Structure.length());
    setLength(data_.length);
    setTemplateLen(getTemplateLength(datastreamLevel));
    setReqRepID(0x000b);
    set32bit(0, FILE_HANDLE_OFFSET);
    set16bit(fileNameCCSID, CCSID_OFFSET);
    set32bit(1, WORKING_DIR_HANDLE_OFFSET);
    set16bit(5, ATTR_LIST_LEVEL_OFFSET);   // we're specifying an OA2b or OA2c
    set16bit(0, SET_FLAGS_OFFSET);

    // Set the filename LL.  (4 bytes)
    set32bit(fileName.length + 6, getFilenameLLOffset(datastreamLevel)); // include length of LLCP (6 bytes)

    // Set the filename code point.  (2 bytes)
    set16bit(0x0002, getFilenameCPOffset(datastreamLevel));

    // Set the filename characters.
    System.arraycopy(fileName, 0, data_, getFilenameOffset(datastreamLevel), fileName.length);

    // Set the OA2 structure's LL.  (4 bytes)
    int offset = getFilenameOffset(datastreamLevel) + fileName.length;
    set32bit(oa2Structure.getLength() + 6, offset); // include length of LLCP (6 bytes)

    // Set the OA2 structure's code point.  (2 bytes)
    set16bit(0x000F, offset + 4);

    // Set the OA2 structure (does not include the leading LLCP bytes).
    System.arraycopy(oa2Structure.getData(), 0, data_, offset + 6, oa2Structure.length());
  }

  private final static int getTemplateLength(int datastreamLevel)
  {
    return (datastreamLevel < 16 ? 48 : 56);
  }


  // Determine offset (from beginning of request) to the 4-byte File Name "LL" field.
  private final static int getFilenameLLOffset(int datastreamLevel)
  {
    return (datastreamLevel < 16 ? 68 : 76);
  }

  // Determine offset (from beginning of request) to the 2-byte File Name "CP" field.
  private final static int getFilenameCPOffset(int datastreamLevel)
  {
    return (datastreamLevel < 16 ? 72 : 80);
  }

  // Determine offset (from beginning of request) to the File Name value field (follows LL/CP).
  private final static int getFilenameOffset(int datastreamLevel)
  {
    return (datastreamLevel < 16 ? 74 : 82);
  }

  // Sets the values of the fields relating to file size.
  private final void setFileSizeFields(long fileSize, int datastreamLevel)
  {
    if (datastreamLevel < 16)
    { // Just set the old field.
      if (fileSize > (long)Integer.MAX_VALUE)
      {
        if (Trace.traceOn_) Trace.log(Trace.WARNING, "Specified fileSize value ("+fileSize+") exceeds maximum file length supported by system.");
        fileSize = (long)Integer.MAX_VALUE; // set to maximum possible 'int' value
      }
      set32bit((int)fileSize, FILE_SIZE_OFFSET);
    }
    else
    {
      // The old field must be zero.
      set32bit(0, FILE_SIZE_OFFSET);

      // Also set the new "large" field.
      set64bit(fileSize, LARGE_FILE_SIZE_OFFSET);
    }
  }

}








© 2015 - 2024 Weber Informatics LLC | Privacy Policy