using System;
using System.Runtime.InteropServices;
+using System.ComponentModel;
using static eldbus.EldbusConnectionNativeFunctions;
namespace eldbus
{
+[EditorBrowsable(EditorBrowsableState.Never)]
public static class EldbusConnectionNativeFunctions
{
[DllImport(efl.Libs.Eldbus)] public static extern IntPtr
}
/// <summary>Represents a DBus connection.
-///
-/// Since EFL 1.23.
+/// <para>Since EFL 1.23.</para>
/// </summary>
public class Connection : IDisposable
{
+ /// <summary>
+ /// The type of the Connection.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
public enum Type
{
+ /// <summary>
+ /// Unknown type.
+ /// <para>It's a sentinel.</para>
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
Unknown = 0, // sentinel, not a real type
+ /// <summary>
+ /// Session type.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
Session,
+ /// <summary>
+ /// System type.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
System,
+ /// <summary>
+ /// Starter type.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
Starter,
+ /// <summary>
+ /// Address type.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
Address,
+ /// <summary>
+ /// Last type.
+ /// <para>It's a sentinel.</para>
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
Last // sentinel, not a real type
};
+ [EditorBrowsable(EditorBrowsableState.Never)]
public IntPtr Handle {get;set;} = IntPtr.Zero;
+ /// <summary>Whether this wrapper owns the native handle.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
public bool Own {get;set;} = true;
private void InitNew(IntPtr handle, bool own)
}
}
+ [EditorBrowsable(EditorBrowsableState.Never)]
public Connection(IntPtr handle, bool own)
{
InitNew(handle, own);
}
-
+ /// <summary>
+ /// Constructor.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="type">The type of the connection.</param>
public Connection(eldbus.Connection.Type type)
{
InitNew(eldbus_connection_get(type), true);
}
+ /// <summary>
+ /// Constructor.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="address">The address of the connection.</param>
public Connection(string address)
{
InitNew(eldbus_address_connection_get(address), true);
}
+ /// <summary>
+ /// Gets a Connection with a type.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="type"></param>
+ /// <returns>A Connection with the type.</returns>
public static eldbus.Connection GetPrivate(eldbus.Connection.Type type)
{
return new eldbus.Connection(eldbus_private_connection_get(type), true);
}
+ /// <summary>
+ /// Gets a Connection with a address.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="address">The address of the connection.</param>
public static eldbus.Connection GetPrivate(string address)
{
return new eldbus.Connection(eldbus_private_address_connection_get(address), true);
}
-
+ /// <summary>
+ /// Finalizer to be called from the Garbage Collector.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
~Connection()
{
Dispose(false);
}
+ /// <summary>Disposes of this wrapper, releasing the native array if owned.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="disposing">True if this was called from <see cref="Dispose()"/> public method. False if
+ /// called from the C# finalizer.</param>
protected virtual void Dispose(bool disposing)
{
IntPtr h = Handle;
}
}
+ /// <summary>Releases the native resources held by this instance.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
+ /// <summary>Releases the native resources held by this instance.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
public void Free()
{
Dispose();
}
+ /// <summary>
+ /// Releases the native handler.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <returns>The native handler.</returns>
public IntPtr Release()
{
IntPtr h = Handle;
return h;
}
+ /// <summary>
+ /// Send a message.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="msg">The message that will be sent.</param>
+ /// <param name="dlgt">The function that is executed when a response arrives..</param>
+ /// <param name="timeout">The timeout of the message.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending Send(eldbus.Message msg, eldbus.MessageDelegate dlgt = null, double timeout = -1)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Gets a unique name assigned by the message bus.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <returns>The unique name string.</returns>
public string GetUniqueName()
{
CheckHandle();
return Eina.StringConversion.NativeUtf8ToManagedString(ptr);
}
+ /// <summary>
+ /// Send a RequestName method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="bus">The name of the bus.</param>
+ /// <param name="flags">Parameter of the RequestName method.</param>
+ /// <param name="dlgt">The function to call when receiving answer.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending NameRequest(string bus, uint flags, eldbus.MessageDelegate dlgt = null)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Send a ReleaseName method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="bus">The name of the bus.</param>
+ /// <param name="dlgt">The function to call when receiving answer.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending NameRelease(string bus, eldbus.MessageDelegate dlgt = null)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Send a GetNameOwner method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="bus">The name of the bus.</param>
+ /// <param name="dlgt">The function to call when receiving answer.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending GetNameOwner(string bus, eldbus.MessageDelegate dlgt = null)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Send NameHasOwner method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="bus">The name of the bus.</param>
+ /// <param name="dlgt">The function to call when receiving the answer.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending HasNameOwner(string bus, eldbus.MessageDelegate dlgt = null)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Send ListNames method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="dlgt">The function to call when receiving answer.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending NameList(eldbus.MessageDelegate dlgt = null)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Send ListActivatableNames method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="dlgt">The function to call when receiving a method.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending ActivatableList(eldbus.MessageDelegate dlgt = null)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Send Hello method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="dlgt">The function to call when receiving answer.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending Hello(eldbus.MessageDelegate dlgt = null)
{
CheckHandle();
return new eldbus.Pending(pending_hdl, false);
}
+ /// <summary>
+ /// Send StartServiceByName method.
+ /// <para>Since EFL 1.23.</para>
+ /// </summary>
+ /// <param name="bus">The name of the bus.</param>
+ /// <param name="flags">Parameter of the StartServiceByName.</param>
+ /// <param name="dlgt">The function to call when receiving answer.</param>
+ /// <returns>A <see cref="eldbus.Pending" /></returns>
public eldbus.Pending NameStart(string bus, uint flags, eldbus.MessageDelegate dlgt = null)
{
CheckHandle();