Merge pull request #270 from lytico/lytico/issues/269_GLibrary_issupported

GLibrary.cs: introduce IsSupported
This commit is contained in:
lytico 2021-07-20 01:56:05 +02:00 committed by GitHub
commit 1fb5527458
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
11 changed files with 142 additions and 65 deletions

View file

@ -40,6 +40,9 @@ namespace Atk {
GLib.Marshaller.Free (native_event_type); GLib.Marshaller.Free (native_event_type);
return id; return id;
} }
public static bool IsSupported => GLibrary.IsSupported(Library.Atk);
} }
} }

View file

@ -0,0 +1,11 @@
namespace Cairo
{
public partial class Global
{
public static bool IsSupported => GLibrary.IsSupported(Library.Cairo);
}
}

View file

@ -85,6 +85,9 @@ namespace GLib {
{ {
return Marshaller.PtrToStringGFree (g_format_size_for_display (size)); return Marshaller.PtrToStringGFree (g_format_size_for_display (size));
} }
public static bool IsSupported => GLibrary.IsSupported(Library.GLib);
} }
} }

View file

@ -160,6 +160,9 @@ namespace Gdk {
result [i] = (VisualType) tmp [i]; result [i] = (VisualType) tmp [i];
return result; return result;
} }
public static bool IsSupported => GLibrary.IsSupported(Library.Gdk);
} }
} }

View file

@ -0,0 +1,11 @@
namespace Gio
{
public partial class Global
{
public static bool IsSupported => GLibrary.IsSupported(Library.Gio);
}
}

View file

@ -20,8 +20,6 @@ namespace Gtk {
public partial class Global { public partial class Global {
internal const string GtkNativeDll = "libgtk-3-0.dll";
public static bool ShowUri (string uri) public static bool ShowUri (string uri)
{ {
return ShowUri (null, uri); return ShowUri (null, uri);
@ -31,6 +29,9 @@ namespace Gtk {
{ {
return ShowUri (screen, uri, Gtk.Global.CurrentEventTime); return ShowUri (screen, uri, Gtk.Global.CurrentEventTime);
} }
public static bool IsSupported => GLibrary.IsSupported(Library.Gtk);
} }
} }

View file

@ -0,0 +1,11 @@
namespace GtkSource
{
public partial class Global
{
public static bool IsSupported => GLibrary.IsSupported(Library.GtkSource);
}
}

View file

@ -50,6 +50,9 @@ namespace Pango {
attrs = new Pango.AttrList (attrs_handle); attrs = new Pango.AttrList (attrs_handle);
return result; return result;
} }
public static bool IsSupported => GLibrary.IsSupported(Library.Pango);
} }
} }

View file

@ -5,16 +5,19 @@ using System.Runtime.InteropServices;
class GLibrary class GLibrary
{ {
[DllImport("kernel32.dll", SetLastError = true)] [DllImport("kernel32.dll", SetLastError = true)]
private static extern bool SetDllDirectory(string lpPathName); private static extern bool SetDllDirectory(string lpPathName);
private static Dictionary<Library, IntPtr> _libraries; private static Dictionary<Library, IntPtr> _libraries;
private static HashSet<Library> _librariesNotFound;
private static Dictionary<string, IntPtr> _customlibraries; private static Dictionary<string, IntPtr> _customlibraries;
private static Dictionary<Library, string[]> _libraryDefinitions; private static Dictionary<Library, string[]> _libraryDefinitions;
static GLibrary() static GLibrary()
{ {
_customlibraries = new Dictionary<string, IntPtr>(); _customlibraries = new Dictionary<string, IntPtr>();
_librariesNotFound = new HashSet<Library>();
_libraries = new Dictionary<Library, IntPtr>(); _libraries = new Dictionary<Library, IntPtr>();
_libraryDefinitions = new Dictionary<Library, string[]>(); _libraryDefinitions = new Dictionary<Library, string[]>();
_libraryDefinitions[Library.GLib] = new[] {"libglib-2.0-0.dll", "libglib-2.0.so.0", "libglib-2.0.0.dylib", "glib-2.dll"}; _libraryDefinitions[Library.GLib] = new[] {"libglib-2.0-0.dll", "libglib-2.0.so.0", "libglib-2.0.0.dylib", "glib-2.dll"};
@ -29,41 +32,53 @@ class GLibrary
_libraryDefinitions[Library.PangoCairo] = new[] {"libpangocairo-1.0-0.dll", "libpangocairo-1.0.so.0", "libpangocairo-1.0.0.dylib", "pangocairo-1.dll"}; _libraryDefinitions[Library.PangoCairo] = new[] {"libpangocairo-1.0-0.dll", "libpangocairo-1.0.so.0", "libpangocairo-1.0.0.dylib", "pangocairo-1.dll"};
_libraryDefinitions[Library.GtkSource] = new[] {"libgtksourceview-4-0.dll", "libgtksourceview-4.so.0", "libgtksourceview-4.0.dylib", "gtksourceview-4.dll"}; _libraryDefinitions[Library.GtkSource] = new[] {"libgtksourceview-4-0.dll", "libgtksourceview-4.so.0", "libgtksourceview-4.0.dylib", "gtksourceview-4.dll"};
_libraryDefinitions[Library.Webkit] = new[] { "libwebkit2gtk-4.0.dll", "libwebkit2gtk-4.0.so.37", "libwebkit2gtk-4.0.dylib", "libwebkit2gtk-4.0.0.dll" }; _libraryDefinitions[Library.Webkit] = new[] { "libwebkit2gtk-4.0.dll", "libwebkit2gtk-4.0.so.37", "libwebkit2gtk-4.0.dylib", "libwebkit2gtk-4.0.0.dll" };
} }
public static IntPtr Load(Library library) public static IntPtr Load(Library library)
{ {
var ret = IntPtr.Zero; if (_libraries.TryGetValue(library, out var ret))
if (_libraries.TryGetValue(library, out ret))
return ret; return ret;
if (FuncLoader.IsWindows) if (TryGet(library, out ret)) return ret;
var err = library + ": " + string.Join(", ", _libraryDefinitions[library]);
throw new DllNotFoundException(err);
}
public static bool IsSupported(Library library) => TryGet(library, out var __);
static bool TryGet(Library library, out IntPtr ret)
{ {
ret = IntPtr.Zero;
if (_libraries.TryGetValue(library, out ret)) {
return true;
}
if (_librariesNotFound.Contains(library)) {
return false;
}
if (FuncLoader.IsWindows) {
ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][0]); ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][0]);
if (ret == IntPtr.Zero) if (ret == IntPtr.Zero) {
{
SetDllDirectory(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "Gtk", "3.24.24")); SetDllDirectory(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "Gtk", "3.24.24"));
ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][0]); ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][0]);
} }
} } else if (FuncLoader.IsOSX) {
else if (FuncLoader.IsOSX)
{
ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][2]); ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][2]);
if (ret == IntPtr.Zero) if (ret == IntPtr.Zero) {
{
ret = FuncLoader.LoadLibrary("/usr/local/lib/" + _libraryDefinitions[library][2]); ret = FuncLoader.LoadLibrary("/usr/local/lib/" + _libraryDefinitions[library][2]);
} }
} } else
else
ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][1]); ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][1]);
if (ret == IntPtr.Zero) if (ret == IntPtr.Zero) {
{ for (var i = 0; i < _libraryDefinitions[library].Length; i++) {
for (int i = 0; i < _libraryDefinitions[library].Length; i++)
{
ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][i]); ret = FuncLoader.LoadLibrary(_libraryDefinitions[library][i]);
if (ret != IntPtr.Zero) if (ret != IntPtr.Zero)
@ -71,13 +86,13 @@ class GLibrary
} }
} }
if (ret == IntPtr.Zero) if (ret != IntPtr.Zero) {
{ _libraries[library] = ret;
var err = library + ": " + string.Join(", ", _libraryDefinitions[library]); } else {
throw new DllNotFoundException(err); _librariesNotFound.Add(library);
} }
_libraries[library] = ret; return ret != IntPtr.Zero;
return ret;
} }
} }

View file

@ -0,0 +1,11 @@
namespace WebKit
{
public partial class Global
{
public static bool IsSupported => GLibrary.IsSupported(Library.Webkit);
}
}

View file

@ -19,6 +19,11 @@ namespace Samples
public WebviewSection() public WebviewSection()
{ {
if (!WebKit.Global.IsSupported) {
AddItem(($"{nameof(WebKit.WebView)}",new Label($"{typeof(WebView).Namespace} is not suported on your OS")));
return;
}
AddItem(ShowHtml()); AddItem(ShowHtml());
AddItem(ShowUri()); AddItem(ShowUri());