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

src.org.python.modules.jffi.MemoryOp Maven / Gradle / Ivy

There is a newer version: 2.7.1.1
Show newest version

package org.python.modules.jffi;

import org.python.core.Py;
import org.python.core.PyObject;
import org.python.core.PyType;

/**
 * Defines memory operations for a primitive type
 */
abstract class MemoryOp {
    public static final MemoryOp INVALID = new InvalidOp();
    public static final MemoryOp VOID = new VoidOp();
    public static final MemoryOp BOOL = new BooleanOp();
    public static final MemoryOp INT8 = new Signed8();
    public static final MemoryOp UINT8 = new Unsigned8();
    public static final MemoryOp INT16 = new Signed16();
    public static final MemoryOp UINT16 = new Unsigned16();
    public static final MemoryOp INT32 = new Signed32();
    public static final MemoryOp UINT32 = new Unsigned32();
    public static final MemoryOp INT64 = new Signed64();
    public static final MemoryOp UINT64 = new Unsigned64();
    public static final MemoryOp FLOAT = new Float32();
    public static final MemoryOp DOUBLE = new Float64();
    public static final MemoryOp POINTER = new PointerOp(PointerCData.TYPE, CType.POINTER);
    public static final MemoryOp STRING = new StringOp();

    public static final MemoryOp getMemoryOp(NativeType type) {
        switch (type) {
            case VOID:
                return VOID;
            case BYTE:
                return INT8;
            case UBYTE:
                return UINT8;
            case SHORT:
                return INT16;
            case USHORT:
                return UINT16;
            case INT:
                return INT32;
            case UINT:
                return UINT32;
            case LONGLONG:
                return INT64;
            case ULONGLONG:
                return UINT64;
            case LONG:
                return com.kenai.jffi.Platform.getPlatform().longSize() == 32
                        ? INT32 : INT64;
            case ULONG:
                return com.kenai.jffi.Platform.getPlatform().longSize() == 32
                        ? UINT32 : UINT64;
            case FLOAT:
                return FLOAT;
            case DOUBLE:
                return DOUBLE;
            case POINTER:
                return POINTER;
            case STRING:
                return STRING;
            case BOOL:
                return BOOL;
            default:
                throw new UnsupportedOperationException("No MemoryOp for " + type);
        }
    }
    
    abstract PyObject get(Memory mem, long offset);
    abstract void put(Memory mem, long offset, PyObject value);

    private static final class InvalidOp extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            throw Py.TypeError("invalid memory access");
        }

        public final PyObject get(Memory mem, long offset) {
            throw Py.TypeError("invalid memory access");
        }
    }

    private static final class VoidOp extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            throw Py.TypeError("Attempting to write void to memory");
        }

        public final PyObject get(Memory mem, long offset) {
            throw Py.TypeError("Attempting to read void from memory");
        }
    }

    private static final class BooleanOp extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putInt(offset, value.__nonzero__() ? 1 : 0);
        }

        public final PyObject get(Memory mem, long offset) {
            return Py.newBoolean(mem.getInt(offset) != 0);
        }
    }

    static final class Signed8 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putByte(offset, Util.int8Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newSigned8(mem.getByte(offset));
        }
    }

    static final class Unsigned8 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putByte(offset, (byte) Util.uint8Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newUnsigned8(mem.getByte(offset));
        }
    }
    static final class Signed16 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putShort(offset, Util.int16Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newSigned16(mem.getShort(offset));
        }
    }
    static final class Unsigned16 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putShort(offset, (short) Util.uint16Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newUnsigned16(mem.getShort(offset));
        }
    }
    static final class Signed32 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putInt(offset, Util.int32Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newSigned32(mem.getInt(offset));
        }
    }
    static final class Unsigned32 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putInt(offset, (int) Util.uint32Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newUnsigned32(mem.getInt(offset));
        }
    }
    static final class Signed64 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putLong(offset, Util.int64Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newSigned64(mem.getLong(offset));
        }
    }
    static final class Unsigned64 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putLong(offset, Util.uint64Value(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Util.newUnsigned64(mem.getLong(offset));
        }
    }
    static final class Float32 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putFloat(offset, Util.floatValue(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Py.newFloat(mem.getFloat(offset));
        }
    }
    static final class Float64 extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            mem.putDouble(offset, Util.doubleValue(value));
        }

        public final PyObject get(Memory mem, long offset) {
            return Py.newFloat(mem.getDouble(offset));
        }
    }
    static final class PointerOp extends MemoryOp {
        private final PyType pytype;
        private final CType ctype;

        public PointerOp(PyType pytype, CType ctype) {
            this.pytype = pytype;
            this.ctype = ctype;
        }

        public final void put(Memory mem, long offset, PyObject value) {
            if (value instanceof Pointer) {
                mem.putAddress(offset, ((Pointer) value).getMemory().getAddress());
            } else if (value == Py.None) {
                mem.putAddress(offset, 0);
            } else {
                throw Py.RuntimeError("invalid pointer");
            }
        }

        public final PyObject get(Memory mem, long offset) {
            DirectMemory dm = new NativeMemory(mem.getAddress(offset));
            return new PointerCData(pytype, ctype, dm, INVALID);
        }
    }

    private static final class StringOp extends MemoryOp {
        public final void put(Memory mem, long offset, PyObject value) {
            throw Py.NotImplementedError("Cannot set String");
        }

        public final PyObject get(Memory mem, long offset) {
            throw Py.NotImplementedError("Cannot get String");
        }
    }

    static final class StructOp extends MemoryOp {

        private final PyType type;
        private final StructLayout layout;

        public StructOp(PyType type) {
            this.type = type;
            PyObject l = type.__getattr__("_jffi_type");
            if (!(l instanceof StructLayout)) {
                throw Py.TypeError("invalid _jffi_type for " + type.fastGetName() + "; should be instance of jffi.StructLayout");
            }
            this.layout = (StructLayout) l;
        }

        public StructOp(PyType type, StructLayout layout) {
            this.type = type;
            this.layout = layout;
        }

        public final void put(Memory mem, long offset, PyObject value) {
            throw Py.NotImplementedError("not implemented");
        }

        public final PyObject get(Memory mem, long offset) {
            return new Structure(type, layout, mem.slice(offset));
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy