Jump to content

MIDIAddLink: Difference between revisions

From EDM2
 
(6 intermediate revisions by 2 users not shown)
Line 1: Line 1:
==MIDIAddLink==
MIDIAddLink creates a link from the source instance (''minstanceSource'') to the target instance (''minstanceTarget'') on the specified slot (''ulSlotNumber'').
 
; MIDIAddLink( ''minstanceSource'', ''minstanceTarget'', ''ulSlotNumber'', ''ulFlag'' );
: MIDIAddLink creates a link from the source instance (''minstanceSource'') to the target instance (''minstanceTarget'') on the specified slot (''ulSlotNumber'').


==Syntax==
MIDIAddLink( ''minstanceSource'', ''minstanceTarget'', ''ulSlotNumber'', ''ulFlag'' )


===Parameters===
===Parameters===
 
; minstanceSource (MINSTANCE) - input: The source instance number.
; MINSTANCE ''minstanceSource'' (input)
; minstanceTarget (MINSTANCE) - input: The target instance number.
: The source instance number.
; ulSlotNumber ([[ULONG]])  - input: The slot number of the source instance.
; MINSTANCE ''minstanceTarget'' (input)
; ulFlag ([[ULONG]]) - input: This parameter is not currently used and must be set to 0.
: The target instance number.
; ULONG ''ulSlotNumber'' (input)
: The slot number of the source instance.
; ULONG ''ulFlag'' (input)
: This parameter is not currently used and must be set to 0.


===Returns===
===Returns===
;ULONG rc:The following values can be returned


; ULONG rc
{|class="wikitable"
: The following values can be returned
|align="RIGHT" |0
:
|NO_ERROR
{| border="1"
|Operation was successful.
| align="RIGHT" | 0
| align="LEFT" | NO_ERROR
| align="LEFT" | Operation was successful.
|-
|-
| align="RIGHT" | 7003
|align="RIGHT" | 7003
| align="LEFT" | MIDIERR_INTERNAL_SYSTEM
|MIDIERR_INTERNAL_SYSTEM
| align="LEFT" | Error, The RTMIDI subsystem has become corrupt, and the application should terminate immediately, cleaning up as much as possible. Rebooting will most likely be necessary to restore RTMIDI to a functional state.
|Error, The RTMIDI subsystem has become corrupt, and the application should terminate immediately, cleaning up as much as possible. Rebooting will most likely be necessary to restore RTMIDI to a functional state.
|-
|-
| align="RIGHT" | 7007
| align="RIGHT" | 7007
| align="LEFT" | MIDIERR_INVALID_FLAG
|MIDIERR_INVALID_FLAG
| align="LEFT" | Error, The ''ulFlag'' value is not set to 0.
|Error, The ''ulFlag'' value is not set to 0.
|-
|-
| align="RIGHT" | 7009
| align="RIGHT" | 7009
| align="LEFT" | MIDIERR_INVALID_INSTANCE_NUMBER
|MIDIERR_INVALID_INSTANCE_NUMBER
| align="LEFT" | Error, Either the source or target instance number is invalid.
|Error, Either the source or target instance number is invalid.
|-
|-
| align="RIGHT" | 7010
| align="RIGHT" | 7010
| align="LEFT" | MIDIERR_INVALID_PARAMETER
|MIDIERR_INVALID_PARAMETER
| align="LEFT" | Error, The ''ulSlotNumber'' parameter contains an invalid value.
|Error, The ''ulSlotNumber'' parameter contains an invalid value.
|-
|-
| align="RIGHT" | 7014
| align="RIGHT" | 7014
| align="LEFT" | MIDIERR_NOT_ALLOWED
|MIDIERR_NOT_ALLOWED
| align="LEFT" | Error, An attempt was made to create a link either between two instances not owned by this process or between a hardware node and an instance owned by another process.
|Error, An attempt was made to create a link either between two instances not owned by this process or between a hardware node and an instance owned by another process.
|-
|-
| align="RIGHT" | 7016
| align="RIGHT" | 7016
| align="LEFT" | MIDIERR_RESOURCE_NOT_AVAILABLE
|MIDIERR_RESOURCE_NOT_AVAILABLE
| align="LEFT" | Error, There are not enough resources to create any new links.
|Error, There are not enough resources to create any new links.
|}
|}


===Include Info===
==Gotchas==
 
#include <mididll.h>
 
===Gotchas===
 
A link is only allowed between two hardware nodes, a hardware node and an instance owned by this process, or between two instances which are owned by this process.
A link is only allowed between two hardware nodes, a hardware node and an instance owned by this process, or between two instances which are owned by this process.


The value of the slot number (''ulSlotNumber'') depends on the class of the source instance. The class defines the number and meaning of the slots of its instances. Most classes only provide one slot, so ''ulSlotNumber'' will be 0 for these classes.
The value of the slot number (''ulSlotNumber'') depends on the class of the source instance. The class defines the number and meaning of the slots of its instances. Most classes only provide one slot, so ''ulSlotNumber'' will be 0 for these classes.


===Sample Code===
==Sample Code==
 
<pre>
  #include <mididll.h>
  #include <mididll.h>
   
   
Line 79: Line 66:
    /* We got an error to take care of. */
    /* We got an error to take care of. */
  }
  }
</pre>


===See Also===
===See Also===
*MIDIRemoveLink
*MIDIQueryInstanceInfo


MIDIRemoveLink, MIDIQueryInstanceInfo
[[Category:MIDI]]
 
=== OS Version Introduced ===
 
 
[[Category:The OS/2 API Project]]

Latest revision as of 02:53, 25 April 2025

MIDIAddLink creates a link from the source instance (minstanceSource) to the target instance (minstanceTarget) on the specified slot (ulSlotNumber).

Syntax

MIDIAddLink( minstanceSource, minstanceTarget, ulSlotNumber, ulFlag )

Parameters

minstanceSource (MINSTANCE) - input
The source instance number.
minstanceTarget (MINSTANCE) - input
The target instance number.
ulSlotNumber (ULONG) - input
The slot number of the source instance.
ulFlag (ULONG) - input
This parameter is not currently used and must be set to 0.

Returns

ULONG rc
The following values can be returned
0 NO_ERROR Operation was successful.
7003 MIDIERR_INTERNAL_SYSTEM Error, The RTMIDI subsystem has become corrupt, and the application should terminate immediately, cleaning up as much as possible. Rebooting will most likely be necessary to restore RTMIDI to a functional state.
7007 MIDIERR_INVALID_FLAG Error, The ulFlag value is not set to 0.
7009 MIDIERR_INVALID_INSTANCE_NUMBER Error, Either the source or target instance number is invalid.
7010 MIDIERR_INVALID_PARAMETER Error, The ulSlotNumber parameter contains an invalid value.
7014 MIDIERR_NOT_ALLOWED Error, An attempt was made to create a link either between two instances not owned by this process or between a hardware node and an instance owned by another process.
7016 MIDIERR_RESOURCE_NOT_AVAILABLE Error, There are not enough resources to create any new links.

Gotchas

A link is only allowed between two hardware nodes, a hardware node and an instance owned by this process, or between two instances which are owned by this process.

The value of the slot number (ulSlotNumber) depends on the class of the source instance. The class defines the number and meaning of the slots of its instances. Most classes only provide one slot, so ulSlotNumber will be 0 for these classes.

Sample Code

 #include <mididll.h>
 
 MINSTANCE miSource;
 MINSTANCE miTarget;
 ULONG ulSlot;
 
    /* Create a link from the instance identified with miSource       */
    /* to the instance identified with miTarget, on the slot          */
    /* of the source instance
 
 	rc = MIDIAddLink(miSource, miTarget, ulSlot, 0);
 
 	if (rc != 0)
 	{
 	  /* We got an error to take care of. */
 	}

See Also

  • MIDIRemoveLink
  • MIDIQueryInstanceInfo