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

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

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (AS/400 Toolbox for Java - OSS version)                              
//                                                                             
// Filename: InternalErrorException.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;



/**
   Represents an exception
   that indicates that an internal error has occurred.  Instances
   of this class represent problems in the supplied code.  Contact your
   service representative to report the problem.
**/
public class InternalErrorException extends RuntimeException
implements ReturnCodeException {
    static final long serialVersionUID = 4L;

    private int rc_;  // Return code associated with this exception

    //  Handles loading the appropriate resource bundle
    private static ResourceBundleLoader loader_;


    // Return code values used by this class.
    // If a value is added here, it must also be added to MRI.properties.
    /**
       The return code indicating that  
       the server job cannot support the level of data streams that the client
       is using.
    **/
    public static final int DATA_STREAM_LEVEL_NOT_VALID = 1;
    /**
       The return code indicating that  
       the data stream received from the server job was not of the
       type or format expected.
    **/
    public static final int DATA_STREAM_UNKNOWN = 2;
    /**
       The return code indicating that  
       the password has not been encrypted properly (pre-V2R2 encryption may
       have been used).
    **/
    public static final int PASSWORD_IMPROPERLY_ENCRYPTED = 3;
    /**
       The return code indicating that  
       a protocol error occurred while communicating with the system.
    **/
    public static final int PROTOCOL_ERROR = 4;
    /**
       The return code indicating that  
       the server job received a data stream that had 
       data or a format that was not valid.
    **/
    public static final int SYNTAX_ERROR = 5;
    /**
       The return code indicating that  
       the exact cause of the failure is not known.  The detailed message
       may contain additional information.
    **/
    public static final int UNKNOWN = 6;
    /**
       The return code indicating that  
       the server job cannot support this version of the client.
    **/
    public static final int VRM_NOT_VALID = 7;
    /**
       The return code indicating that  
       the security manager is in a state that is not valid.
    **/
    public static final int SECURITY_INVALID_STATE = 8;
    /**
       The return code indicating that  
       an unexpected return code was received.
    **/
    public static final int UNEXPECTED_RETURN_CODE = 9;    
    /**
       The return code indicating that  
       an unexpected exception was received.
    **/
    public static final int UNEXPECTED_EXCEPTION = 10;  // @D0A



    /**
       Constructs an InternalErrorException object.
       It indicates that an internal error has occurred.
       @param returnCode The return code which identifies the message to be returned.
    **/
    public InternalErrorException(int returnCode) {	// @D1C
        // Create the message
        super(loader_.getText(getMRIKey(returnCode)));
        rc_ =  returnCode;

    }

    /**
      Constructs an InternalErrorException object. It indicates that
      an internal error has occurred.  The value is displayed at the end
      of the message.
      @param returnCode The return code which identifies the message to be displayed.
      @param value  The value to display at the end of the message
    **/
    InternalErrorException(int returnCode, int value) {
        // Create the message
        super(loader_.getText(getMRIKey(returnCode)) + " - " + String.valueOf(value));
        rc_ = returnCode;
    }

    /**
      Constructs an InternalErrorException object. It indicates that
      an internal error has occurred.  The string and value are displayed
      at the end of the message.
      @param returnCode The return code which identifies the message to be displayed.
      @param text  The string to add to the end of the message
                   Note: This parameter does not get translated.
      @param value The value to display at the end of the message
    **/
    InternalErrorException(int returnCode, String text, int value) {
        super(loader_.getText(getMRIKey(returnCode)) + " " + text + " - " + String.valueOf(value));
        rc_ = returnCode;
    }

    /**
      Constructs an InternalErrorException object. It indicates that
      an internal error has occurred.  The string is displayed
      at the end of the message.
      @param returnCode The return code which identifies the message to be displayed.
      @param text  The string to add to the end of the message
                   Note: This parameter does not get translated.
      @param exception The exception that caused this internal error. 
      If text is exception.getMessage(), use InternalErrorException(int,Exception)
      instead 
    **/
    InternalErrorException(int returnCode, String text, Throwable exception) {
        super(loader_.getText(getMRIKey(returnCode)) + " " + text);
        //
        // Set the cause, catching the error if not JDK 1.4
        // 
        if (exception != null) { 
        try {
          initCause(exception); 
        } catch (Throwable t) { 
        }
        }
        rc_ = returnCode;
    }

    /**
    Constructs an InternalErrorException object. It indicates that
    an internal error has occurred.  The string is displayed
    at the end of the message.
    @param returnCode The return code which identifies the message to be displayed.
    @param text  The string to add to the end of the message
                 Note: This parameter does not get translated.
  **/
  InternalErrorException(int returnCode, Throwable exception ) {
      super(loader_.getText(getMRIKey(returnCode)) + " " + exception.getMessage());
      //
      // Set the cause, catching the error if not JDK 1.4
      //
      if (exception != null) { 
      try {
        initCause(exception); 
      } catch (Throwable t) { 
      }
      }
      rc_ = returnCode;
  }

    
    /**
       Constructs an InternalErrorException object.
       It indicates that an internal error has occurred.
       @param pathname The pathname of the object or file, where the error was encountered.
                       Note: This parameter does not get translated.
       @param returnCode The return code which identifies the message to be returned.
    **/
    InternalErrorException(String pathname, int returnCode) { 
        // Create the message.
        super(pathname + ": " + loader_.getText(getMRIKey(returnCode)));
        rc_ =  returnCode;
    }



    
    /**
       Returns the text associated with the return code.
       @param returnCode  The return code associated with this exception.
       @return The text string which describes the error.
    **/
    // This method is required so the message can be created and sent in super()
    static String getMRIKey (int returnCode) {
        switch (returnCode) {
        case DATA_STREAM_LEVEL_NOT_VALID:
            return "EXC_DATA_STREAM_LEVEL_NOT_VALID";
        case DATA_STREAM_UNKNOWN:
            return "EXC_DATA_STREAM_UNKNOWN";
        case PASSWORD_IMPROPERLY_ENCRYPTED:
            return "EXC_PASSWORD_IMPROPERLY_ENCRYPTED";
        case PROTOCOL_ERROR:
            return "EXC_PROTOCOL_ERROR";
        case SYNTAX_ERROR:
            return "EXC_SYNTAX_ERROR";
        case UNKNOWN :
            return "EXC_UNKNOWN";
        case VRM_NOT_VALID:
            return "EXC_VRM_NOT_VALID";
        case SECURITY_INVALID_STATE:
            return "EXC_SECURITY_INVALID_STATE";
        case UNEXPECTED_RETURN_CODE:
            return "EXC_UNEXPECTED_RETURN_CODE";
        case UNEXPECTED_EXCEPTION:                        // @D0A
            return "EXC_UNEXPECTED_EXCEPTION";         // @D0A
        default:
            return "EXC_UNKNOWN";   // Bad return code was provided.
        }
    }


    /**
       Returns the return code associated with this exception.
       @return The return code.
    **/
    public int getReturnCode () {
        return rc_;
    }




}  // End of InternalErrorException




© 2015 - 2025 Weber Informatics LLC | Privacy Policy