mirror of
https://github.com/Ryujinx/GtkSharp.git
synced 2025-10-24 07:07:06 +00:00
115 lines
3.5 KiB
Plaintext
115 lines
3.5 KiB
Plaintext
The contents of this directory are (basically) the first step
|
|
in creating .NET bindings, to libraries based on GObject.
|
|
|
|
QUICK INSTRUCTIONS
|
|
------------------
|
|
|
|
Edit the .metadata file(s), then do a:
|
|
|
|
make get-source-code
|
|
make api
|
|
|
|
You only have to do a "make get-source-code" once! After
|
|
you have run "make get-source-code" once, do the following...
|
|
|
|
|
|
Edit the .metadata file(s), then do a:
|
|
|
|
make api
|
|
|
|
|
|
Note, these instructions only generate XML files in the "api"
|
|
directory. To turn those XML files (in the "api" directory)
|
|
into C# code; and then turn that C# code into a .DLL, you'll
|
|
need to perform extra steps, which are NOT described in this
|
|
document.
|
|
|
|
(If you are going to create a new .NET binding, then you will need
|
|
to do more than just this.)
|
|
|
|
|
|
WHO USES THE SOURCES DIRECTORY
|
|
------------------------------
|
|
|
|
This directory is essentially the "starting point" in the creation
|
|
of a .NET binding. Most people can safely ignore it. (If all
|
|
you want to do is build Gtk#, then you can ignore what's in this
|
|
directory.)
|
|
|
|
This directory is not part of the normal "build process" for Gtk#.
|
|
But is instead used by people wishing to update an existing .NET
|
|
binding; or to create a new .NET binding (for a GObject based library).
|
|
|
|
The result of running "make api" on this directory (once everything
|
|
is set up) are the XML files that you find in the "api" directory.
|
|
(Those XML files, that you find in the "api" directory, are then used
|
|
to generate the C# code. And then that C# code is used to create
|
|
the various .DLL files.)
|
|
|
|
|
|
WHAT'S REQUIRED
|
|
---------------
|
|
|
|
Before you can do anything here, you need to get the source
|
|
code to the various libraries (which you are generating .NET
|
|
bindings for). And then do a little configuring. The current
|
|
list of libraries that Gtk# supports is:
|
|
|
|
pango-1.4.0
|
|
atk-1.6.0
|
|
gtk+-2.4.1
|
|
libgnome-2.6.0
|
|
libgnomecanvas-2.6.0
|
|
libgnomeui-2.6.0
|
|
libgnomeprint-2.6.0
|
|
libgnomeprintui-2.6.0
|
|
gtkhtml-3.0.10 files: gtkhtml.[ch], gtkhtml-types.h,
|
|
gtkhtml-enums.h, gtkhtml-stream.[ch]
|
|
libglade-2.3.6
|
|
libart_lgpl-2.3.16
|
|
librsvg-2.6.4
|
|
gnome-vfs-2.6.0
|
|
gnome-panel-2.6.0
|
|
|
|
(If you create a new binding, that is part of Gtk#, be sure to add it
|
|
to this list. Also, you'll need to add an entry in "gtk-sharp.sources".
|
|
And you should add it to the "makefile" so that it is part of the
|
|
"get-source-code" rule.)
|
|
|
|
(There are two ways to get this source code. As you will see in the
|
|
next section.)
|
|
|
|
|
|
SETTING THINGS UP
|
|
-----------------
|
|
|
|
To set things up, you need to get the source code to the libraries listed
|
|
above. There are two (alternate) methods of doing this.
|
|
|
|
Method 1)
|
|
Download it. Unpack the source code (if necessary). Then do the extra
|
|
cofiguration stuff listed above.
|
|
|
|
Method 2)
|
|
Run:
|
|
make get-source-code
|
|
|
|
|
|
(Method 2 is probably the easiest way to do it for most people. It automatically
|
|
goes and downloads everything you need. And configures everything for you.)
|
|
|
|
|
|
EDITING .METADATA FILES
|
|
-----------------------
|
|
|
|
Part of updating a .NET binding involves editing a .metadata file.
|
|
(Assuming you already have the required source code, to the
|
|
libraries...) once you update a binding, you then run:
|
|
|
|
make api
|
|
|
|
...to create the new updated XML file(s) that will be placed in the "api"
|
|
directory.
|
|
|
|
|