/// <summary> /// Creates a new <see cref="DomainParticipant" /> with the desired QoS policies and attaches to it the specified <see cref="DomainParticipantListener" />. /// </summary> /// <remarks> /// If the specified QoS policies are not consistent, the operation will fail and no <see cref="DomainParticipant" /> will be created. /// </remarks> /// <param name="domainId">Domain ID that the application intends to join.</param> /// <param name="qos">The <see cref="DomainParticipantQos" /> policies to be used for creating the new <see cref="DomainParticipant" />.</param> /// <param name="listener">The <see cref="DomainParticipantListener" /> to be attached to the newly created <see cref="DomainParticipant" />.</param> /// <param name="statusMask">The <see cref="StatusMask" /> of which status changes the listener should be notified.</param> /// <returns> The newly created <see cref="DomainParticipant" /> on success, otherwise <see langword="null"/>.</returns> public DomainParticipant CreateParticipant(int domainId, DomainParticipantQos qos, DomainParticipantListener listener, StatusMask statusMask) { DomainParticipantQosWrapper qosWrapper = default; if (qos is null) { qos = new DomainParticipantQos(); var ret = GetDefaultDomainParticipantQos(qos); if (ret == ReturnCode.Ok) { qosWrapper = qos.ToNative(); } } else { qosWrapper = qos.ToNative(); } IntPtr nativeListener = IntPtr.Zero; if (listener != null) { nativeListener = listener.ToNative(); } IntPtr native = UnsafeNativeMethods.CreateParticipant(_native, domainId, qosWrapper, nativeListener, statusMask); qos.Release(); if (native.Equals(IntPtr.Zero)) { return(null); } var p = new DomainParticipant(native) { Listener = listener, }; EntityManager.Instance.Add((p as Entity).ToNative(), p); return(p); }
/// <summary> /// Creates a new <see cref="DomainParticipant" /> with the desired QoS policies and attaches to it the specified <see cref="DomainParticipantListener" />. /// The specified <see cref="DomainParticipantListener" /> will be attached with the default <see cref="StatusMask" />. /// </summary> /// <remarks> /// If the specified QoS policies are not consistent, the operation will fail and no <see cref="DomainParticipant" /> will be created. /// </remarks> /// <param name="domainId">Domain ID that the application intends to join.</param> /// <param name="qos">The <see cref="DomainParticipantQos" /> policies to be used for creating the new <see cref="DomainParticipant" />.</param> /// <param name="listener">The <see cref="DomainParticipantListener" /> to be attached to the newly created <see cref="DomainParticipant" />.</param> /// <returns> The newly created <see cref="DomainParticipant" /> on success, otherwise <see langword="null"/>.</returns> public DomainParticipant CreateParticipant(int domainId, DomainParticipantQos qos, DomainParticipantListener listener) { return(CreateParticipant(domainId, qos, listener, StatusMask.DefaultStatusMask)); }