mirror of
https://github.com/Ryujinx/GtkSharp.git
synced 2025-01-11 23:15:31 +00:00
faaccd7e0b
new methods to allow arbitrary setup and teardown code around the managed call. When passing a type with "complicated" marshalling requirements as a ref or out param, first assign the value to a temporary variable (in Setup), then pass the temp as the ref or out param (in ToString), and then assign the new value back to the original argument (in Finish). * generator/Signal.cs: * generator/SignalHandler.cs: Update to generate correct glue for signals with "ref" or "out" params. (#70566) * generator/VirtualMethod.cs: Update for ManagedCallString change * generator/IGeneratable.cs: add comments explaining what each member does * gtk/Gtk.metadata: mark Editable.InsertText's "position" arg * pass-by-ref * sample/Size.cs: connect to the SizeRequested event and override it, to test/demo the changes svn path=/trunk/gtk-sharp/; revision=37854
64 lines
2.1 KiB
C#
64 lines
2.1 KiB
C#
// GtkSharp.Generation.IGeneratable.cs - Interface to generate code for a type.
|
|
//
|
|
// Author: Mike Kestner <mkestner@speakeasy.net>
|
|
//
|
|
// Copyright (c) 2001 Mike Kestner
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of version 2 of the GNU General Public
|
|
// License as published by the Free Software Foundation.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public
|
|
// License along with this program; if not, write to the
|
|
// Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
// Boston, MA 02111-1307, USA.
|
|
|
|
|
|
namespace GtkSharp.Generation {
|
|
|
|
public interface IGeneratable {
|
|
|
|
// The C name of the generatable
|
|
string CName {get;}
|
|
|
|
// The (short) C# name of the generatable
|
|
string Name {get;}
|
|
|
|
// The fully-qualified C# name of the generatable
|
|
string QualifiedName {get;}
|
|
|
|
// The type (possibly including "ref" or "out") to use in the import
|
|
// signature when passing this generatable to unmanaged code
|
|
string MarshalType {get;}
|
|
|
|
// The type to use as the return type in an import signature when
|
|
// receiving this generatable back from unmanaged code
|
|
string MarshalReturnType {get;}
|
|
|
|
// The type to use in a managed callback signature when returning this
|
|
// generatable to unmanaged code
|
|
string ToNativeReturnType {get;}
|
|
|
|
// Generates an expression to convert var_name to MarshalType
|
|
string CallByName (string var_name);
|
|
|
|
// Generates an expression to convert var from MarshalType
|
|
string FromNative (string var);
|
|
|
|
// Generates an expression to convert var from MarshalReturnType
|
|
string FromNativeReturn (string var);
|
|
|
|
// Generates an expression to convert var to ToNativeReturnType
|
|
string ToNativeReturn (string var);
|
|
|
|
void Generate ();
|
|
|
|
void Generate (GenerationInfo gen_info);
|
|
}
|
|
}
|