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

com.bugvm.apple.coremidi.MIDIPort Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2013-2015 RoboVM AB
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.bugvm.apple.coremidi;

/**/
import java.io.*;
import java.nio.*;
import java.util.*;
import com.bugvm.objc.*;
import com.bugvm.objc.annotation.*;
import com.bugvm.objc.block.*;
import com.bugvm.rt.*;
import com.bugvm.rt.annotation.*;
import com.bugvm.rt.bro.*;
import com.bugvm.rt.bro.annotation.*;
import com.bugvm.rt.bro.ptr.*;
import com.bugvm.apple.foundation.*;
import com.bugvm.apple.corefoundation.*;
/**/
import com.bugvm.apple.coremidi.MIDIEndpoint.MIDIEndpointPtr;

/**/
/**/
/**/@Library("CoreMIDI")/**/
/**/public/**/ class /**/MIDIPort/**/ 
    extends /**/MIDIObject/**/ 
    /**//**/ {

    /**/public static class MIDIPortPtr extends Ptr {}/**/
    private static java.util.concurrent.atomic.AtomicLong refconId = new java.util.concurrent.atomic.AtomicLong();
    protected long localRefconId;
    private static LongMap readProcs = new LongMap<>();
    private static final java.lang.reflect.Method cbReadProc;
    
    static {
        try {
            cbReadProc = MIDIPort.class.getDeclaredMethod("cbReadProc", MIDIPacketList.class, long.class, long.class);
        } catch (Throwable e) {
            throw new Error(e);
        }
    }
    /**/static { Bro.bind(MIDIPort.class); }/**/
    /**//**/
    /**//**/
    /**//**/
    /**//**/
    @Callback
    private static void cbReadProc(MIDIPacketList pktlist, @Pointer long readProcRefCon, @Pointer long srcConnRefCon) {
        MIDIReadProc callback = null;
        synchronized (readProcs) {
            callback = readProcs.get(readProcRefCon);
        }
        callback.read(pktlist);
    }
    /**
     * @since Available in iOS 4.2 and later.
     */
    public static MIDIPort createInputPort(MIDIClient client, String portName, MIDIReadProc readProc) {
        long refconId = MIDIPort.refconId.getAndIncrement();
        MIDIPortPtr ptr = new MIDIPortPtr();
        MIDIError err = createInputPort(client, portName, new FunctionPtr(cbReadProc), refconId, ptr);
        if (err == MIDIError.No) {
            synchronized (readProcs) {
                readProcs.put(refconId, readProc);
            }
            MIDIPort port = ptr.get();
            port.localRefconId = refconId;
            return port;
        }
        return null;
    }
    /**
     * @since Available in iOS 4.2 and later.
     */
    public static MIDIPort createOutputPort(MIDIClient client, String portName) {
        long refconId = MIDIPort.refconId.getAndIncrement();
        MIDIPortPtr ptr = new MIDIPortPtr();
        createOutputPort(client, portName, ptr);
        MIDIPort port = ptr.get();
        port.localRefconId = refconId;
        return port;
    }
    /**
     * @since Available in iOS 4.2 and later.
     */
    public MIDIError connectSource(MIDIEndpoint source) {
        return connectSource(source, localRefconId);
    }
    /**/
    /**
     * @since Available in iOS 4.2 and later.
     */
    @Bridge(symbol="MIDIInputPortCreate", optional=true)
    protected static native MIDIError createInputPort(MIDIClient client, String portName, FunctionPtr readProc, @Pointer long refCon, MIDIPort.MIDIPortPtr outPort);
    /**
     * @since Available in iOS 4.2 and later.
     */
    @Bridge(symbol="MIDIOutputPortCreate", optional=true)
    protected static native MIDIError createOutputPort(MIDIClient client, String portName, MIDIPort.MIDIPortPtr outPort);
    /**
     * @since Available in iOS 4.2 and later.
     */
    @Bridge(symbol="MIDIPortDispose", optional=true)
    public native MIDIError dispose();
    /**
     * @since Available in iOS 4.2 and later.
     */
    @Bridge(symbol="MIDIPortConnectSource", optional=true)
    protected native MIDIError connectSource(MIDIEndpoint source, @Pointer long connRefCon);
    /**
     * @since Available in iOS 4.2 and later.
     */
    @Bridge(symbol="MIDIPortDisconnectSource", optional=true)
    public native MIDIError disconnectSource(MIDIEndpoint source);
    /**/
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy