| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386 |
- using System;
- using System.Collections.Generic;
- using System.Runtime.InteropServices;
- namespace SoundIOSharp
- {
- public class SoundIO : IDisposable
- {
- Pointer<SoundIo> handle;
- public SoundIO()
- {
- handle = Natives.soundio_create();
- }
- internal SoundIO(Pointer<SoundIo> handle)
- {
- this.handle = handle;
- }
- public void Dispose ()
- {
- foreach (var h in allocated_hglobals)
- {
- Marshal.FreeHGlobal(h);
- }
- Natives.soundio_destroy(handle);
- }
- // Equality (based on handle)
- public override bool Equals(object other)
- {
- var d = other as SoundIO;
- return d != null && this.handle == d.handle;
- }
- public override int GetHashCode()
- {
- return (int)(IntPtr)handle;
- }
- public static bool operator == (SoundIO obj1, SoundIO obj2)
- {
- return obj1 is null ? obj2 is null : obj1.Equals(obj2);
- }
- public static bool operator != (SoundIO obj1, SoundIO obj2)
- {
- return obj1 is null ? obj2 is object : !obj1.Equals(obj2);
- }
- // fields
- // FIXME: this should be taken care in more centralized/decent manner... we don't want to write
- // this kind of code anywhere we need string marshaling.
- List<IntPtr> allocated_hglobals = new List<IntPtr>();
- public string ApplicationName {
- get { return Marshal.PtrToStringAnsi(Marshal.ReadIntPtr(handle, app_name_offset)); }
- set
- {
- unsafe
- {
- var existing = Marshal.ReadIntPtr(handle, app_name_offset);
- if (allocated_hglobals.Contains (existing))
- {
- allocated_hglobals.Remove(existing);
- Marshal.FreeHGlobal(existing);
- }
- var ptr = Marshal.StringToHGlobalAnsi(value);
- Marshal.WriteIntPtr(handle, app_name_offset, ptr);
- allocated_hglobals.Add(ptr);
- }
- }
- }
- static readonly int app_name_offset = (int)Marshal.OffsetOf<SoundIo>("app_name");
- public SoundIOBackend CurrentBackend
- {
- get { return (SoundIOBackend)Marshal.ReadInt32(handle, current_backend_offset); }
- }
- static readonly int current_backend_offset = (int)Marshal.OffsetOf<SoundIo>("current_backend");
- // emit_rtprio_warning
- public Action EmitRealtimePriorityWarning
- {
- get { return emit_rtprio_warning; }
- set
- {
- emit_rtprio_warning = value;
- var ptr = Marshal.GetFunctionPointerForDelegate(on_devices_change);
- Marshal.WriteIntPtr(handle, emit_rtprio_warning_offset, ptr);
- }
- }
- static readonly int emit_rtprio_warning_offset = (int)Marshal.OffsetOf<SoundIo>("emit_rtprio_warning");
- Action emit_rtprio_warning;
- // jack_error_callback
- public Action<string> JackErrorCallback
- {
- get { return jack_error_callback; }
- set
- {
- jack_error_callback = value;
- if (value == null)
- {
- jack_error_callback = null;
- }
- else
- {
- jack_error_callback_native = msg => jack_error_callback(msg);
- }
- var ptr = Marshal.GetFunctionPointerForDelegate(jack_error_callback_native);
- Marshal.WriteIntPtr(handle, jack_error_callback_offset, ptr);
- }
- }
- static readonly int jack_error_callback_offset = (int)Marshal.OffsetOf<SoundIo>("jack_error_callback");
- Action<string> jack_error_callback;
- delegate void jack_error_delegate(string message);
- jack_error_delegate jack_error_callback_native;
- // jack_info_callback
- public Action<string> JackInfoCallback
- {
- get { return jack_info_callback; }
- set
- {
- jack_info_callback = value;
- if (value == null)
- {
- jack_info_callback = null;
- }
- else
- {
- jack_info_callback_native = msg => jack_info_callback(msg);
- }
- var ptr = Marshal.GetFunctionPointerForDelegate(jack_info_callback_native);
- Marshal.WriteIntPtr(handle, jack_info_callback_offset, ptr);
- }
- }
- static readonly int jack_info_callback_offset = (int)Marshal.OffsetOf<SoundIo>("jack_info_callback");
- Action<string> jack_info_callback;
- delegate void jack_info_delegate(string message);
- jack_info_delegate jack_info_callback_native;
- // on_backend_disconnect
- public Action<int> OnBackendDisconnect
- {
- get { return on_backend_disconnect; }
- set
- {
- on_backend_disconnect = value;
- if (value == null)
- {
- on_backend_disconnect_native = null;
- }
- else
- {
- on_backend_disconnect_native = (sio, err) => on_backend_disconnect(err);
- }
- var ptr = Marshal.GetFunctionPointerForDelegate(on_backend_disconnect_native);
- Marshal.WriteIntPtr(handle, on_backend_disconnect_offset, ptr);
- }
- }
- static readonly int on_backend_disconnect_offset = (int)Marshal.OffsetOf<SoundIo>("on_backend_disconnect");
- Action<int> on_backend_disconnect;
- delegate void on_backend_disconnect_delegate(IntPtr handle, int errorCode);
- on_backend_disconnect_delegate on_backend_disconnect_native;
- // on_devices_change
- public Action OnDevicesChange
- {
- get { return on_devices_change; }
- set
- {
- on_devices_change = value;
- if (value == null)
- {
- on_devices_change_native = null;
- }
- else
- {
- on_devices_change_native = sio => on_devices_change();
- }
- var ptr = Marshal.GetFunctionPointerForDelegate(on_devices_change_native);
- Marshal.WriteIntPtr(handle, on_devices_change_offset, ptr);
- }
- }
- static readonly int on_devices_change_offset = (int)Marshal.OffsetOf<SoundIo>("on_devices_change");
- Action on_devices_change;
- delegate void on_devices_change_delegate(IntPtr handle);
- on_devices_change_delegate on_devices_change_native;
- // on_events_signal
- public Action OnEventsSignal
- {
- get { return on_events_signal; }
- set
- {
- on_events_signal = value;
- if (value == null)
- {
- on_events_signal_native = null;
- }
- else
- {
- on_events_signal_native = sio => on_events_signal();
- }
- var ptr = Marshal.GetFunctionPointerForDelegate(on_events_signal_native);
- Marshal.WriteIntPtr(handle, on_events_signal_offset, ptr);
- }
- }
- static readonly int on_events_signal_offset = (int)Marshal.OffsetOf<SoundIo>("on_events_signal");
- Action on_events_signal;
- delegate void on_events_signal_delegate(IntPtr handle);
- on_events_signal_delegate on_events_signal_native;
- // functions
- public int BackendCount
- {
- get { return Natives.soundio_backend_count(handle); }
- }
- public int InputDeviceCount
- {
- get { return Natives.soundio_input_device_count(handle); }
- }
- public int OutputDeviceCount
- {
- get { return Natives.soundio_output_device_count(handle); }
- }
- public int DefaultInputDeviceIndex
- {
- get { return Natives.soundio_default_input_device_index(handle); }
- }
- public int DefaultOutputDeviceIndex
- {
- get { return Natives.soundio_default_output_device_index(handle); }
- }
- public SoundIOBackend GetBackend(int index)
- {
- return (SoundIOBackend)Natives.soundio_get_backend(handle, index);
- }
- public SoundIODevice GetInputDevice(int index)
- {
- return new SoundIODevice(Natives.soundio_get_input_device(handle, index));
- }
- public SoundIODevice GetOutputDevice(int index)
- {
- return new SoundIODevice(Natives.soundio_get_output_device(handle, index));
- }
- public void Connect()
- {
- var ret = (SoundIoError)Natives.soundio_connect(handle);
- if (ret != SoundIoError.SoundIoErrorNone)
- {
- throw new SoundIOException(ret);
- }
- }
- public void ConnectBackend(SoundIOBackend backend)
- {
- var ret = (SoundIoError)Natives.soundio_connect_backend(handle, (SoundIoBackend)backend);
- if (ret != SoundIoError.SoundIoErrorNone)
- {
- throw new SoundIOException(ret);
- }
- }
- public void Disconnect()
- {
- Natives.soundio_disconnect(handle);
- }
- public void FlushEvents()
- {
- Natives.soundio_flush_events(handle);
- }
- public void WaitEvents()
- {
- Natives.soundio_wait_events(handle);
- }
- public void Wakeup()
- {
- Natives.soundio_wakeup(handle);
- }
- public void ForceDeviceScan()
- {
- Natives.soundio_force_device_scan(handle);
- }
- public SoundIORingBuffer CreateRingBuffer(int capacity)
- {
- return new SoundIORingBuffer(Natives.soundio_ring_buffer_create(handle, capacity));
- }
- // static methods
- public static string VersionString
- {
- get { return Marshal.PtrToStringAnsi(Natives.soundio_version_string()); }
- }
- public static int VersionMajor
- {
- get { return Natives.soundio_version_major(); }
- }
- public static int VersionMinor
- {
- get { return Natives.soundio_version_minor(); }
- }
- public static int VersionPatch
- {
- get { return Natives.soundio_version_patch(); }
- }
- public static string GetBackendName(SoundIOBackend backend)
- {
- return Marshal.PtrToStringAnsi(Natives.soundio_backend_name((SoundIoBackend)backend));
- }
- public static bool HaveBackend(SoundIOBackend backend)
- {
- return Natives.soundio_have_backend((SoundIoBackend)backend);
- }
- public static int GetBytesPerSample(SoundIOFormat format)
- {
- return Natives.soundio_get_bytes_per_sample((SoundIoFormat)format);
- }
- public static int GetBytesPerFrame(SoundIOFormat format, int channelCount)
- {
- return Natives.soundio_get_bytes_per_frame((SoundIoFormat)format, channelCount);
- }
- public static int GetBytesPerSecond(SoundIOFormat format, int channelCount, int sampleRate)
- {
- return Natives.soundio_get_bytes_per_second((SoundIoFormat)format, channelCount, sampleRate);
- }
- public static string GetSoundFormatName(SoundIOFormat format)
- {
- return Marshal.PtrToStringAnsi(Natives.soundio_format_string((SoundIoFormat)format));
- }
- }
- }
|