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

com.ascert.open.ohio.Ohio Maven / Gradle / Ivy

Go to download

An open source emulator supporting 3270 and potentially later 5250 terminal types.

There is a newer version: 1.7.2
Show newest version
/*
 * Java interfaces for Open Host Interface Objects (OHIO)
 *      https://tools.ietf.org/html/draft-ietf-tn3270e-ohio-01
 *
 * Copyright (C) 2016, Ascert LLC
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */
package com.ascert.open.ohio;

import java.util.EnumSet;

/**
 * Base interface for OHIO classes.
 *
 * Much of the terminology and types in OHIO are very 3270 specific, but can be leveraged and applied for other device types with a form
 * mode ot block mode capability e.g. screen interactions, field attributes etc. This class is a starting point to move towards allowing
 * other device types to be suppored through the OHIO. In the present form it is very much a quick derivation of the org.ohio classes, with
 * many parts still 3270 specific and abstractions such as the OHIO_AID enums which really need more thought.
 *
 * OHIO really started life as a C/C++ API abstraction for 3270 terminals. At some stage a set of roughly euiqvalent Java API classes
 * (org.ohio.*) were created although these do not seem to have become widely used or maintained. The original sources can be found in
 * various places e.g. https://sourceforge.net/projects/os-ohio
 * 
 * There are terminal specifics in here that ideally would be abstracted out into separate classes and/or packages e.g. 3270 and 6530 
 * F-key codes. It's also possible that OHIO itself is largely redundant these days, and we should just move to using direct open.term
 * interfaces.
 *
 */
public interface Ohio
{

    public enum OHIO_DIRECTION
    {
        OHIO_DIRECTION_FORWARD, // Forward (beginning towards end)
        OHIO_DIRECTION_BACKWARD     // Backward (end towards beginning)
    };

    public enum OHIO_TYPE
    {
        OHIO_TYPE_UNKNOWN, // Unknown host
        OHIO_TYPE_3270, // IBM 3270 host
        OHIO_TYPE_5250, // IBM 5250 host
        OHIO_TYPE_6530               // NSK 6530 host
    };

    public enum OHIO_STATE
    {
        OHIO_STATE_DISCONNECTED, // The communication link to the host is disconnected
        OHIO_STATE_CONNECTED        // The communication link to the host is connected.    
    };

    public enum OHIO_PLANE
    {
        OHIO_PLANE_TEXT, // Indicates Text Plane (character data)
        OHIO_PLANE_COLOR, // Indicates Color Plane (standard HLLAPI CGA color values)
        OHIO_PLANE_FIELD, // Indicates Field Attribute Plane (field attribute bytes)
        OHIO_PLANE_EXTENDED         // Indicates Extended Plane (extended attribute bytes)
    };

    // Colors need a mapped numeric value for use when decoding binary
    // data used in the Ohio Color Plane.
    // Note: literal values used are taken from OS-OHI project - unclear at thus stage
    // if those were in turn taken from HLLAPI, or derived elsewhere
    public enum OHIO_COLOR
    {
        OHIO_COLOR_BLACK(0),
        OHIO_COLOR_BLUE(1),
        OHIO_COLOR_GREEN(2),
        OHIO_COLOR_CYAN(3),
        OHIO_COLOR_RED(4),
        OHIO_COLOR_MAGENTA(5),
        OHIO_COLOR_WHITE(7),
        OHIO_COLOR_YELLOW(14);

        //TODO - need to review whether this should be more correctly a byte or char
        private final int colorValue;

        OHIO_COLOR(int colorValue)
        {
            this.colorValue = colorValue;
        }

        public int getColorValue()
        {
            return colorValue;
        }

        //TODO: not sure if we will need this 
        //public boolean equals(Object obj)
        //{
        //}
    };

    // These values are returned in the Ohio Extended Field Plane. As with OHIO_COLOR,
    // they need numeric values for use when decoding the returned data.
    //TODO - seems to be a mix of masks and values. Need to revisit this!
    public enum OHIO_EXTENDED
    {
        OHIO_EXTENDED_HILITE(0xC0), // Bitmask for Highlighting Bits
        OHIO_EXTENDED_COLOR(0x38), // Bitmask for Color Bits
        OHIO_EXTENDED_RESERVED(0x07), // Bitmask for Reserved Bits
        OHIO_EXTENDED_HILITE_NORMAL(0), // Normal highlighting
        OHIO_EXTENDED_HILITE_BLINK(1), // Blinking highlighting
        OHIO_EXTENDED_HILITE_REVERSEVIDEO(2), // Reverse Video highlighting
        OHIO_EXTENDED_HILITE_UNDERSCORE(3), // Underscore highlighting
        //TODO - feels like these should be shifted??
        OHIO_EXTENDED_COLOR_DEFAULT(0),
        OHIO_EXTENDED_COLOR_BLUE(1),
        OHIO_EXTENDED_COLOR_RED(2),
        OHIO_EXTENDED_COLOR_PINK(3),
        OHIO_EXTENDED_COLOR_GREEN(4),
        OHIO_EXTENDED_COLOR_TURQUOISE(5),
        OHIO_EXTENDED_COLOR_YELLOW(6),
        OHIO_EXTENDED_COLOR_WHITE(7);
        //TODO - non standard, left in but commented out for now until 
        //       we have real 5250 emulation to work from. Also unclear
        //       what correct mechanism is for non-standard extensions.
        //OHIO_EXTENDED_5250_REVERSE(0x80),
        //OHIO_EXTENDED_5250_UNDERLINE(0x40),
        //OHIO_EXTENDED_5250_BLINK(0x20),
        //OHIO_EXTENDED_5250_COL_SEP(0x10)

        //TODO - need to review whether this should be more correctly a byte or char
        private final int extAttrVal;

        OHIO_EXTENDED(int extAttrVal)
        {
            this.extAttrVal = extAttrVal;
        }

        public int getExtAttrValue()
        {
            return extAttrVal;
        }

    };

    // These values are returned in the Ohio Field Attributes. As with OHIO_COLOR,
    // they need numeric values for use when decoding the returned data.
    //TODO - seems to be a mix of masks and values. Need to revisit this!
    public enum OHIO_FIELD
    {
        OHIO_FIELD_ATTRIBUTE(0xC0), // Bitmask for field attribute
        OHIO_FIELD_PROTECTED(0x20), // Protected field
        OHIO_FIELD_NUMERIC(0x10), // Numeric field
        OHIO_FIELD_PEN_SELECTABLE(0x08), // Pen selectable field      
        OHIO_FIELD_HIGH_INTENSITY(0x04), // High intensity field
        OHIO_FIELD_HIDDEN(0x0C), // Hidden field
        OHIO_FIELD_RESERVED(0x02), // Reserved field
        OHIO_FIELD_MODIFIED(0x01);          // Modified field

        //TODO - need to review whether this should be more correctly a byte or char
        private final int attrVal;

        OHIO_FIELD(int attrVal)
        {
            this.attrVal = attrVal;
        }

        public int getAttrValue()
        {
            return attrVal;
        }

    };

    public enum OHIO_UPDATE
    {
        OHIO_UPDATE_CLIENT, // Update initiated by client
        OHIO_UPDATE_HOST                // Update initiated by host
    };

    //TODO - no idea what these values mean!
    public enum OHIO_OWNER
    {
        OHIO_OWNER_UNKNOWN, // Uninitialized
        OHIO_OWNER_APP, // Application or 5250 host
        OHIO_OWNER_MYJOB, // 3270 - Myjob
        OHIO_OWNER_NVT, // 3270 in NVT mode
        OHIO_OWNER_UNOWNED, // 3270 - Unowned
        OHIO_OWNER_SSCP                 // 3270 - SSCP
    };

    public enum OHIO_INPUTINHIBITED
    {
        OHIO_INPUTINHIBITED_NOTINHIBITED, // Input not inhibited
        OHIO_INPUTINHIBITED_SYSTEM_WAIT, // Input inhibited by a System Wait state ("X SYSTEM" or "X []")
        OHIO_INPUTINHIBITED_COMMCHECK, // Input inhibited by a communications check state ("X COMMxxx")
        OHIO_INPUTINHIBITED_PROGCHECK, // Input inhibited by a program check state ("X PROGxxx")
        OHIO_INPUTINHIBITED_MACHINECHECK, // Input inhibited by a machine check state ("X MACHxxx")
        OHIO_INPUTINHIBITED_OTHER           // Input inhibited by something other than above states
    };

    //OHIO_AID - not in original IETF spec, but necessary
    //           http://www.ingenuityworking.com/knowledge/w/knowledgebase/ibm-3270-emulation-data-flow.aspx
    // DO NOT CHANGE THE MNEMONICS - other areas of code may rely on them for lookup and/or translation
    public enum OHIO_AID
    {
        OHIO_AID_3270_SYSREQ(0xF0, "sysreq"),
        OHIO_AID_3270_PF1(0xF1, "pf1"),
        OHIO_AID_3270_PF2(0xF2, "pf2"),
        OHIO_AID_3270_PF3(0xF3, "pf3"),
        OHIO_AID_3270_PF4(0xF4, "pf4"),
        OHIO_AID_3270_PF5(0xF5, "pf5"),
        OHIO_AID_3270_PF6(0xF6, "pf6"),
        OHIO_AID_3270_PF7(0xF7, "pf7"),
        OHIO_AID_3270_PF8(0xF8, "pf8"),
        OHIO_AID_3270_PF9(0xF9, "pf9"),
        OHIO_AID_3270_PF10(0x7A, "pf10"),
        OHIO_AID_3270_PF11(0x7B, "pf11"),
        OHIO_AID_3270_PF12(0x7C, "pf12"),
        OHIO_AID_3270_PF13(0xC1, "pf13"),
        OHIO_AID_3270_PF14(0xC2, "pf14"),
        OHIO_AID_3270_PF15(0xC3, "pf15"),
        OHIO_AID_3270_PF16(0xC4, "pf16"),
        OHIO_AID_3270_PF17(0xC5, "pf17"),
        OHIO_AID_3270_PF18(0xC6, "pf18"),
        OHIO_AID_3270_PF19(0xC7, "pf19"),
        OHIO_AID_3270_PF20(0xC8, "pf20"),
        OHIO_AID_3270_PF21(0xC9, "pf21"),
        OHIO_AID_3270_PF22(0x4A, "pf22"),
        OHIO_AID_3270_PF23(0x4B, "pf23"),
        OHIO_AID_3270_PF24(0x4C, "pf24"),
        OHIO_AID_3270_PA1(0x6C, "pa1"),
        OHIO_AID_3270_PA2(0x6E, "pa2"),
        OHIO_AID_3270_PA3(0x6B, "pa3"),
        OHIO_AID_3270_CLEAR(0x6D, "clear"),
        OHIO_AID_3270_CLEAR_PARTITION(0x6A, "clrptn"),
        OHIO_AID_3270_ENTER(0x7D, "enter"),
        // TODO - No inclusion yet of AIDs for IBM 5250.

        OHIO_FKEY_6530_F1(0x40, "F1"),
        OHIO_FKEY_6530_F2(0x41, "F2"),
        OHIO_FKEY_6530_F3(0x42, "F3"),
        OHIO_FKEY_6530_F4(0x43, "F4"),
        OHIO_FKEY_6530_F5(0x44, "F5"),
        OHIO_FKEY_6530_F6(0x45, "F6"),
        OHIO_FKEY_6530_F7(0x46, "F7"),
        OHIO_FKEY_6530_F8(0x47, "F8"),
        OHIO_FKEY_6530_F9(0x48, "F9"),
        OHIO_FKEY_6530_F10(0x49, "F10"),
        OHIO_FKEY_6530_F11(0x4a, "F11"),
        OHIO_FKEY_6530_F12(0x4b, "F12"),
        OHIO_FKEY_6530_F13(0x4c, "F13"),
        OHIO_FKEY_6530_F14(0x4d, "F14"),
        OHIO_FKEY_6530_F15(0x4e, "F15"),
        OHIO_FKEY_6530_F16(0x4f, "F16"),
        OHIO_FKEY_6530_UP(0x50, "RollUp"),
        OHIO_FKEY_6530_DOWN(0x51, "RollDown"),
        OHIO_FKEY_6530_PGDOWN(0x52, "NextPage"),
        OHIO_FKEY_6530_PGUP(0x53, "PrevPage"),
        OHIO_FKEY_6530_INS(0x54, "InsDel"),
        OHIO_FKEY_6530_ENTER(0x56, "Return"),
        OHIO_FKEY_6530_EOF(0x57, "CtlY"),
        OHIO_FKEY_6530_SF1(0x60, "SF1"),
        OHIO_FKEY_6530_SF2(0x61, "SF2"),
        OHIO_FKEY_6530_SF3(0x62, "SF3"),
        OHIO_FKEY_6530_SF4(0x63, "SF4"),
        OHIO_FKEY_6530_SF5(0x64, "SF5"),
        OHIO_FKEY_6530_SF6(0x65, "SF6"),
        OHIO_FKEY_6530_SF7(0x66, "SF7"),
        OHIO_FKEY_6530_SF8(0x67, "SF8"),
        OHIO_FKEY_6530_SF9(0x68, "SF9"),
        OHIO_FKEY_6530_SF10(0x69, "SF10"),
        OHIO_FKEY_6530_SF11(0x6A, "SF11"),
        OHIO_FKEY_6530_SF12(0x6B, "SF12"),
        OHIO_FKEY_6530_SF13(0x6C, "SF13"),
        OHIO_FKEY_6530_SF14(0x6D, "SF14"),
        OHIO_FKEY_6530_SF15(0x6E, "SF15"),
        OHIO_FKEY_6530_SF16(0x6F, "SF16"),
        OHIO_FKEY_6530_Sh_UP(0x70, "ShiftRollUp"),
        OHIO_FKEY_6530_Sh_DOWN(0x71, "ShiftRollDown"),
        OHIO_FKEY_6530_Alt_PGDOWN(0x72, "ShiftNextPage"),
        OHIO_FKEY_6530_Alt_PGUP(0x73, "ShiftPrevPage"),
        OHIO_FKEY_6530_DEL(0x74, "ShiftInsDel"),
        OHIO_FKEY_6530_Sh_ENTER(0x76, "ShiftReturn");

        private final int aidValue;
        private final String aidMnemonic;

        OHIO_AID(int aidValue, String aidMnemonic)
        {
            this.aidValue = aidValue;
            this.aidMnemonic = aidMnemonic;
        }

        public int getAidValue()
        {
            return aidValue;
        }

        public String getAidMnemonic()
        {
            return aidMnemonic;
        }

        public static EnumSet getAidSet(OHIO_TYPE typ)
        {
            switch (typ)
            {
                case OHIO_TYPE_3270:
                    return EnumSet.range(OHIO_AID_3270_SYSREQ, OHIO_AID_3270_ENTER);
                case OHIO_TYPE_6530:
                    return EnumSet.range(OHIO_FKEY_6530_F1, OHIO_FKEY_6530_Sh_ENTER);
            }

            return EnumSet.noneOf(OHIO_AID.class);
        }

        public static OHIO_AID getOhioAid(int aidValue, OHIO_TYPE typ)
        {
            EnumSet aidSet = getAidSet(typ);

            for (Ohio.OHIO_AID aid : aidSet)
            {
                if (aid.getAidValue() == aidValue)
                {
                    return aid;
                }
            }

            return null;
        }
    }

    /**
     * Returns the OHIO version level of this implementation.
     *
     * @return The OHIO version level.
     *
     */
    default String getOhioVersion()
    {
        return "OHIO 1.10";
    }

    /**
     * Returns the name of the vendor providing this OHIO implementation.
     *
     * @return The OHIO vender name
     */
    default String getVendorName()
    {
        return "Ascert LLC";
    }

    /**
     * Returns the vendor product version that is providing the OHIO implementation.
     *
     * @return The vender procuct version
     */
    default String getVendorProductVersion()
    {
        return "com.ascert.open.ohio 1.10";
    }

    /**
     * The vendor object that provides non-standard, vendor specific extensions to the OHIO object.
     *
     * @return the vendor specific implementation of this object.
     */
    default Object getVendorObject()
    {
        return null;
    }

    // Create an OhioPosition object.
    //       row     The row coordinate.
    //       col     The column coordinate.
    default OhioPosition CreateOhioPosition(int row, int col)
    {
        return new OhioPosition(row, col);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy