2004-03-18 Mike Kestner <mkestner@ximian.com>
* configure.in : expand atk/glue/Makefile * atk/Makefile.am : generate glue and build glue dir * atk/makefile.win32 : ditto * atk/glue/Makefile.am : build new glue * atk/glue/makefile.win32 : build new glue * atk/glue/vmglueheaders.h : new includes for vm glue * atk/glue/win32dll.c : win dll building code * generator/CodeGenerator.cs : add --gluelib-name and --glue-filename argument parsing. * generator/GenerationInfo.cs : add GluelibName, GlueFilename, GlueEnabled, GlueWriter, and CloseGlueWriter. * generator/ObjectGen.cs : Add VirtualMethod glue generation * generator/Statistics.cs : Add warning message for virtual method throttling. svn path=/trunk/gtk-sharp/; revision=24292
This commit is contained in:
parent
37a37adf53
commit
9861569931
13 changed files with 232 additions and 11 deletions
17
ChangeLog
17
ChangeLog
|
@ -1,3 +1,20 @@
|
||||||
|
2004-03-18 Mike Kestner <mkestner@ximian.com>
|
||||||
|
|
||||||
|
* configure.in : expand atk/glue/Makefile
|
||||||
|
* atk/Makefile.am : generate glue and build glue dir
|
||||||
|
* atk/makefile.win32 : ditto
|
||||||
|
* atk/glue/Makefile.am : build new glue
|
||||||
|
* atk/glue/makefile.win32 : build new glue
|
||||||
|
* atk/glue/vmglueheaders.h : new includes for vm glue
|
||||||
|
* atk/glue/win32dll.c : win dll building code
|
||||||
|
* generator/CodeGenerator.cs : add --gluelib-name and
|
||||||
|
--glue-filename argument parsing.
|
||||||
|
* generator/GenerationInfo.cs : add GluelibName, GlueFilename,
|
||||||
|
GlueEnabled, GlueWriter, and CloseGlueWriter.
|
||||||
|
* generator/ObjectGen.cs : Add VirtualMethod glue generation
|
||||||
|
* generator/Statistics.cs : Add warning message for virtual
|
||||||
|
method throttling.
|
||||||
|
|
||||||
2004-03-18 Mike Kestner <mkestner@ximian.com>
|
2004-03-18 Mike Kestner <mkestner@ximian.com>
|
||||||
|
|
||||||
* parser/gapi2xml.pl : fix passbyvalue bug in vm parsing.
|
* parser/gapi2xml.pl : fix passbyvalue bug in vm parsing.
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
SUBDIRS = . glue
|
||||||
|
|
||||||
API = atk-api.xml
|
API = atk-api.xml
|
||||||
RAW_API = atk-api.raw
|
RAW_API = atk-api.raw
|
||||||
METADATA = Atk.metadata
|
METADATA = Atk.metadata
|
||||||
|
@ -9,7 +11,7 @@ assemblydir = $(libdir)
|
||||||
gapidir = $(datadir)/gapi
|
gapidir = $(datadir)/gapi
|
||||||
assembly_DATA = $(ASSEMBLY)
|
assembly_DATA = $(ASSEMBLY)
|
||||||
gapi_DATA = $(API)
|
gapi_DATA = $(API)
|
||||||
CLEANFILES = $(ASSEMBLY) generated-stamp generated/*.cs $(API)
|
CLEANFILES = $(ASSEMBLY) generated-stamp generated/*.cs $(API) glue/generated.c
|
||||||
|
|
||||||
sources =
|
sources =
|
||||||
|
|
||||||
|
@ -34,6 +36,7 @@ $(API): $(srcdir)/$(RAW_API) $(srcdir)/$(METADATA)
|
||||||
generated-stamp: $(API) ../generator/gapi_codegen.exe $(build_customs)
|
generated-stamp: $(API) ../generator/gapi_codegen.exe $(build_customs)
|
||||||
$(RUNTIME) ../generator/gapi_codegen.exe --generate $(API) \
|
$(RUNTIME) ../generator/gapi_codegen.exe --generate $(API) \
|
||||||
--outdir=generated --customdir=$(srcdir) --assembly-name=$(ASSEMBLY_NAME) \
|
--outdir=generated --customdir=$(srcdir) --assembly-name=$(ASSEMBLY_NAME) \
|
||||||
|
--gluelib-name=atksharpglue --glue-filename=glue/generated.c \
|
||||||
&& touch generated-stamp
|
&& touch generated-stamp
|
||||||
|
|
||||||
$(ASSEMBLY): $(build_sources) generated-stamp
|
$(ASSEMBLY): $(build_sources) generated-stamp
|
||||||
|
|
8
atk/glue/.cvsignore
Normal file
8
atk/glue/.cvsignore
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
generated.c
|
||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
|
*.la
|
||||||
|
*.lo
|
||||||
|
*.o
|
||||||
|
.deps
|
||||||
|
.libs
|
21
atk/glue/Makefile.am
Normal file
21
atk/glue/Makefile.am
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
lib_LTLIBRARIES = libatksharpglue.la
|
||||||
|
|
||||||
|
libatksharpglue_la_LDFLAGS = -module -avoid-version
|
||||||
|
|
||||||
|
libatksharpglue_la_SOURCES = \
|
||||||
|
generated.c \
|
||||||
|
vmglueheaders.h
|
||||||
|
|
||||||
|
# Adding a new glue file?
|
||||||
|
# Please remember to update makefile.win32
|
||||||
|
|
||||||
|
libatksharpglue_la_LIBADD = $(BASE_DEPENDENCIES_LIBS)
|
||||||
|
|
||||||
|
INCLUDES = $(BASE_DEPENDENCIES_CFLAGS) -I$(top_srcdir)
|
||||||
|
|
||||||
|
libatksharpglue.dll: $(libatksharpglue_la_OBJECTS) libatksharpglue.rc libatksharpglue.def
|
||||||
|
./build-dll libatksharpglue $(VERSION)
|
||||||
|
|
||||||
|
CLEANFILES = lib*.a lib*.dll
|
||||||
|
|
||||||
|
EXTRA_DIST = makefile.win32 win32dll.c
|
22
atk/glue/makefile.win32
Executable file
22
atk/glue/makefile.win32
Executable file
|
@ -0,0 +1,22 @@
|
||||||
|
GTK_CFLAGS=`pkg-config --cflags gtk+-win32-2.0 libglade-2.0`
|
||||||
|
GTK_LIBS=`pkg-config --libs gtk+-win32-2.0 libglade-2.0`
|
||||||
|
CC=gcc -mno-cygwin -mms-bitfields
|
||||||
|
DLLWRAP=dllwrap -mno-cygwin -mms-bitfields --target i386-mingw32 --export-all-symbols
|
||||||
|
|
||||||
|
GLUE_OBJS = \
|
||||||
|
generated.o \
|
||||||
|
win32dll.o
|
||||||
|
|
||||||
|
all: atksharpglue.dll
|
||||||
|
|
||||||
|
|
||||||
|
%.o: %.c
|
||||||
|
$(CC) -c $(CFLAGS) $(GTK_CFLAGS) -o $@ $^
|
||||||
|
|
||||||
|
|
||||||
|
atksharpglue.dll: $(GLUE_OBJS)
|
||||||
|
$(DLLWRAP) --output-lib=libatksharpglue.a --dllname=atksharpglue.dll --driver-name=gcc --output-def=atksharpglue.def $(GLUE_OBJS) $(GTK_LIBS)
|
||||||
|
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f atksharpglue.dll *.o libatksharpglue.a
|
4
atk/glue/vmglueheaders.h
Normal file
4
atk/glue/vmglueheaders.h
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
/* Headers for virtual method glue compilation */
|
||||||
|
|
||||||
|
#include <atk/atk.h>
|
||||||
|
|
16
atk/glue/win32dll.c
Executable file
16
atk/glue/win32dll.c
Executable file
|
@ -0,0 +1,16 @@
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include <windows.h>
|
||||||
|
#undef WIN32_LEAN_AND_MEAN
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
BOOL APIENTRY DllMain (HINSTANCE hInst, DWORD reason, LPVOID reserved)
|
||||||
|
{
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
BOOL APIENTRY DllMainCRTStartup (HINSTANCE hInst, DWORD reason, LPVOID reserved)
|
||||||
|
{
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
*/
|
|
@ -6,9 +6,10 @@ all: windows
|
||||||
|
|
||||||
windows: generated-stamp
|
windows: generated-stamp
|
||||||
$(CSC) /unsafe /nowarn:0660,0661 /target:library /r:../glib/glib-sharp.dll /r:../pango/pango-sharp.dll /out:$(ASSEMBLY) /recurse:*.cs
|
$(CSC) /unsafe /nowarn:0660,0661 /target:library /r:../glib/glib-sharp.dll /r:../pango/pango-sharp.dll /out:$(ASSEMBLY) /recurse:*.cs
|
||||||
|
cd glue && make -f makefile.win32
|
||||||
|
|
||||||
generated-stamp: ../generator/codegen.exe atk-api.xml
|
generated-stamp: ../generator/codegen.exe atk-api.xml
|
||||||
../generator/codegen --generate $(APIS) --outdir=generated --customdir=. --assembly-name=atk-sharp && touch generated-stamp
|
../generator/codegen --generate $(APIS) --outdir=generated --customdir=. --assembly-name=atk-sharp --gluelib-name=atksharpglue --glue-filename=glue/generated.c && touch generated-stamp
|
||||||
|
|
||||||
atk-api.xml: atk-api.raw Atk.metadata
|
atk-api.xml: atk-api.raw Atk.metadata
|
||||||
cp atk-api.raw atk-api.xml
|
cp atk-api.raw atk-api.xml
|
||||||
|
@ -19,5 +20,7 @@ clean:
|
||||||
rm -f generated-stamp
|
rm -f generated-stamp
|
||||||
rm -f $(ASSEMBLY)
|
rm -f $(ASSEMBLY)
|
||||||
rm -rf generated
|
rm -rf generated
|
||||||
|
rm -f glue/generated.c
|
||||||
rm -f atk-api.xml
|
rm -f atk-api.xml
|
||||||
|
cd glue && make -f makefile.win32
|
||||||
|
|
||||||
|
|
|
@ -166,6 +166,7 @@ glib/Makefile
|
||||||
glib/glue/Makefile
|
glib/glue/Makefile
|
||||||
pango/Makefile
|
pango/Makefile
|
||||||
atk/Makefile
|
atk/Makefile
|
||||||
|
atk/glue/Makefile
|
||||||
art/Makefile
|
art/Makefile
|
||||||
gdk/Makefile
|
gdk/Makefile
|
||||||
gdk/glue/Makefile
|
gdk/glue/Makefile
|
||||||
|
|
|
@ -24,6 +24,8 @@ namespace GtkSharp.Generation {
|
||||||
string dir = "";
|
string dir = "";
|
||||||
string custom_dir = "";
|
string custom_dir = "";
|
||||||
string assembly_name = "";
|
string assembly_name = "";
|
||||||
|
string glue_filename = "";
|
||||||
|
string gluelib_name = "";
|
||||||
|
|
||||||
SymbolTable table = SymbolTable.Table;
|
SymbolTable table = SymbolTable.Table;
|
||||||
ArrayList gens = new ArrayList ();
|
ArrayList gens = new ArrayList ();
|
||||||
|
@ -48,6 +50,14 @@ namespace GtkSharp.Generation {
|
||||||
include = generate = false;
|
include = generate = false;
|
||||||
assembly_name = arg.Substring (16);
|
assembly_name = arg.Substring (16);
|
||||||
continue;
|
continue;
|
||||||
|
} else if (arg.StartsWith ("--glue-filename=")) {
|
||||||
|
include = generate = false;
|
||||||
|
glue_filename = arg.Substring (16);
|
||||||
|
continue;
|
||||||
|
} else if (arg.StartsWith ("--gluelib-name=")) {
|
||||||
|
include = generate = false;
|
||||||
|
gluelib_name = arg.Substring (15);
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
Parser p = new Parser ();
|
Parser p = new Parser ();
|
||||||
|
@ -58,8 +68,8 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
|
|
||||||
GenerationInfo gen_info = null;
|
GenerationInfo gen_info = null;
|
||||||
if (dir != "" || assembly_name != "")
|
if (dir != "" || assembly_name != "" || glue_filename != "" || gluelib_name != "")
|
||||||
gen_info = new GenerationInfo (dir, custom_dir, assembly_name);
|
gen_info = new GenerationInfo (dir, custom_dir, assembly_name, glue_filename, gluelib_name);
|
||||||
|
|
||||||
foreach (IGeneratable gen in gens) {
|
foreach (IGeneratable gen in gens) {
|
||||||
if (gen_info == null)
|
if (gen_info == null)
|
||||||
|
@ -70,6 +80,9 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
ObjectGen.GenerateMappers ();
|
ObjectGen.GenerateMappers ();
|
||||||
|
|
||||||
|
if (gen_info != null)
|
||||||
|
gen_info.CloseGlueWriter ();
|
||||||
|
|
||||||
Statistics.Report();
|
Statistics.Report();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,8 @@ namespace GtkSharp.Generation {
|
||||||
string dir;
|
string dir;
|
||||||
string custom_dir;
|
string custom_dir;
|
||||||
string assembly_name;
|
string assembly_name;
|
||||||
|
string glue_filename;
|
||||||
|
string gluelib_name;
|
||||||
StreamWriter sw;
|
StreamWriter sw;
|
||||||
|
|
||||||
public GenerationInfo (XmlElement ns)
|
public GenerationInfo (XmlElement ns)
|
||||||
|
@ -25,15 +27,19 @@ namespace GtkSharp.Generation {
|
||||||
dir = ".." + sep + ns_name.ToLower () + sep + "generated";
|
dir = ".." + sep + ns_name.ToLower () + sep + "generated";
|
||||||
custom_dir = ".." + sep + ns_name.ToLower ();
|
custom_dir = ".." + sep + ns_name.ToLower ();
|
||||||
assembly_name = ns_name.ToLower () + "-sharp";
|
assembly_name = ns_name.ToLower () + "-sharp";
|
||||||
|
gluelib_name = "";
|
||||||
|
glue_filename = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
public GenerationInfo (string dir, string assembly_name) : this (dir, dir, assembly_name) {}
|
public GenerationInfo (string dir, string assembly_name) : this (dir, dir, assembly_name, "", "") {}
|
||||||
|
|
||||||
public GenerationInfo (string dir, string custom_dir, string assembly_name)
|
public GenerationInfo (string dir, string custom_dir, string assembly_name, string glue_filename, string gluelib_name)
|
||||||
{
|
{
|
||||||
this.dir = dir;
|
this.dir = dir;
|
||||||
this.custom_dir = custom_dir;
|
this.custom_dir = custom_dir;
|
||||||
this.assembly_name = assembly_name;
|
this.assembly_name = assembly_name;
|
||||||
|
this.glue_filename = glue_filename;
|
||||||
|
this.gluelib_name = gluelib_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public string AssemblyName {
|
public string AssemblyName {
|
||||||
|
@ -54,6 +60,43 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public string GluelibName {
|
||||||
|
get {
|
||||||
|
return gluelib_name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool GlueEnabled {
|
||||||
|
get {
|
||||||
|
return gluelib_name != String.Empty && glue_filename != String.Empty;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string GlueFilename {
|
||||||
|
get {
|
||||||
|
return glue_filename;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
StreamWriter glue_sw = null;
|
||||||
|
public StreamWriter GlueWriter {
|
||||||
|
get {
|
||||||
|
if (!GlueEnabled)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
if (glue_sw == null) {
|
||||||
|
FileStream stream = new FileStream (glue_filename, FileMode.Create, FileAccess.Write);
|
||||||
|
glue_sw = new StreamWriter (stream);
|
||||||
|
|
||||||
|
glue_sw.WriteLine ("// This file was generated by the Gtk# code generator.");
|
||||||
|
glue_sw.WriteLine ("// Any changes made will be lost if regenerated.");
|
||||||
|
glue_sw.WriteLine ();
|
||||||
|
}
|
||||||
|
|
||||||
|
return glue_sw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public StreamWriter Writer {
|
public StreamWriter Writer {
|
||||||
get {
|
get {
|
||||||
return sw;
|
return sw;
|
||||||
|
@ -63,6 +106,12 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void CloseGlueWriter ()
|
||||||
|
{
|
||||||
|
if (glue_sw != null)
|
||||||
|
glue_sw.Close ();
|
||||||
|
}
|
||||||
|
|
||||||
public StreamWriter OpenStream (string name)
|
public StreamWriter OpenStream (string name)
|
||||||
{
|
{
|
||||||
char sep = Path.DirectorySeparatorChar;
|
char sep = Path.DirectorySeparatorChar;
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
// GtkSharp.Generation.ObjectGen.cs - The Object Generatable.
|
// GtkSharp.Generation.ObjectGen.cs - The Object Generatable.
|
||||||
//
|
//
|
||||||
// Author: Mike Kestner <mkestner@speakeasy.net>
|
// Author: Mike Kestner <mkestner@ximian.com>
|
||||||
//
|
//
|
||||||
// (c) 2001-2003 Mike Kestner and Ximian Inc.
|
// (c) 2001-2003 Mike Kestner and Ximian Inc.
|
||||||
|
// (c) 2004 Novell, Inc.
|
||||||
|
|
||||||
namespace GtkSharp.Generation {
|
namespace GtkSharp.Generation {
|
||||||
|
|
||||||
|
@ -15,6 +16,7 @@ namespace GtkSharp.Generation {
|
||||||
public class ObjectGen : ClassBase, IGeneratable {
|
public class ObjectGen : ClassBase, IGeneratable {
|
||||||
|
|
||||||
private ArrayList strings = new ArrayList();
|
private ArrayList strings = new ArrayList();
|
||||||
|
private ArrayList vm_nodes = new ArrayList();
|
||||||
private static Hashtable dirs = new Hashtable ();
|
private static Hashtable dirs = new Hashtable ();
|
||||||
|
|
||||||
public ObjectGen (XmlElement ns, XmlElement elem) : base (ns, elem)
|
public ObjectGen (XmlElement ns, XmlElement elem) : base (ns, elem)
|
||||||
|
@ -27,10 +29,13 @@ namespace GtkSharp.Generation {
|
||||||
switch (node.Name) {
|
switch (node.Name) {
|
||||||
case "field":
|
case "field":
|
||||||
case "callback":
|
case "callback":
|
||||||
case "virtual_method":
|
|
||||||
Statistics.IgnoreCount++;
|
Statistics.IgnoreCount++;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case "virtual_method":
|
||||||
|
vm_nodes.Add (node);
|
||||||
|
break;
|
||||||
|
|
||||||
case "static-string":
|
case "static-string":
|
||||||
strings.Add (node);
|
strings.Add (node);
|
||||||
break;
|
break;
|
||||||
|
@ -128,6 +133,15 @@ namespace GtkSharp.Generation {
|
||||||
GenSignals (gen_info, null);
|
GenSignals (gen_info, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (vm_nodes.Count > 0) {
|
||||||
|
if (gen_info.GlueEnabled) {
|
||||||
|
GenVirtualMethods (gen_info);
|
||||||
|
} else {
|
||||||
|
Statistics.VMIgnored = true;
|
||||||
|
Statistics.ThrottledCount += vm_nodes.Count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
GenMethods (gen_info, null, null);
|
GenMethods (gen_info, null, null);
|
||||||
|
|
||||||
if (interfaces != null) {
|
if (interfaces != null) {
|
||||||
|
@ -185,6 +199,39 @@ namespace GtkSharp.Generation {
|
||||||
base.GenCtors (gen_info);
|
base.GenCtors (gen_info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void GenVMGlue (GenerationInfo gen_info, XmlElement elem)
|
||||||
|
{
|
||||||
|
StreamWriter sw = gen_info.GlueWriter;
|
||||||
|
|
||||||
|
string vm_name = elem.GetAttribute ("cname");
|
||||||
|
string method = gen_info.GluelibName + "_" + NS + Name + "_override_" + vm_name;
|
||||||
|
sw.WriteLine ();
|
||||||
|
sw.WriteLine ("void " + method + " (GType type, gpointer cb);");
|
||||||
|
sw.WriteLine ();
|
||||||
|
sw.WriteLine ("void");
|
||||||
|
sw.WriteLine (method + " (GType type, gpointer cb)");
|
||||||
|
sw.WriteLine ("{");
|
||||||
|
sw.WriteLine ("\t{0} *klass = ({0} *) g_type_class_peek (type);", NS + Name + "Class");
|
||||||
|
sw.WriteLine ("\tklass->" + vm_name + " = cb;");
|
||||||
|
sw.WriteLine ("}");
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool vmhdrs_needed = true;
|
||||||
|
|
||||||
|
private void GenVirtualMethods (GenerationInfo gen_info)
|
||||||
|
{
|
||||||
|
if (vmhdrs_needed) {
|
||||||
|
gen_info.GlueWriter.WriteLine ("#include <glib-object.h>");
|
||||||
|
gen_info.GlueWriter.WriteLine ("#include \"vmglueheaders.h\"");
|
||||||
|
gen_info.GlueWriter.WriteLine ();
|
||||||
|
vmhdrs_needed = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (XmlElement elem in vm_nodes) {
|
||||||
|
GenVMGlue (gen_info, elem);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Keep this in sync with the one in glib/ObjectManager.cs */
|
/* Keep this in sync with the one in glib/ObjectManager.cs */
|
||||||
private static string GetExpected (string cname)
|
private static string GetExpected (string cname)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
// Statistics.cs : Generation statistics class implementation
|
// Statistics.cs : Generation statistics class implementation
|
||||||
//
|
//
|
||||||
// Author: Mike Kestner <mkestner@speakeasy.net>
|
// Author: Mike Kestner <mkestner@ximian.com>
|
||||||
//
|
//
|
||||||
// <c> 2002 Mike Kestner
|
// <c> 2002 Mike Kestner
|
||||||
|
// <c> 2004 Novell, Inc.
|
||||||
|
|
||||||
namespace GtkSharp.Generation {
|
namespace GtkSharp.Generation {
|
||||||
|
|
||||||
|
@ -24,6 +25,7 @@ namespace GtkSharp.Generation {
|
||||||
static int sigs = 0;
|
static int sigs = 0;
|
||||||
static int throttled = 0;
|
static int throttled = 0;
|
||||||
static int ignored = 0;
|
static int ignored = 0;
|
||||||
|
static bool vm_ignored = false;
|
||||||
|
|
||||||
public static int CBCount {
|
public static int CBCount {
|
||||||
get {
|
get {
|
||||||
|
@ -142,8 +144,23 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static bool VMIgnored {
|
||||||
|
get {
|
||||||
|
return vm_ignored;
|
||||||
|
}
|
||||||
|
set {
|
||||||
|
if (value)
|
||||||
|
vm_ignored = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static void Report()
|
public static void Report()
|
||||||
{
|
{
|
||||||
|
if (VMIgnored) {
|
||||||
|
Console.WriteLine();
|
||||||
|
Console.WriteLine("Warning: Generation throttled for Virtual Methods.");
|
||||||
|
Console.WriteLine(" Consider regenerating with --gluelib-name and --glue-filename.");
|
||||||
|
}
|
||||||
Console.WriteLine();
|
Console.WriteLine();
|
||||||
Console.WriteLine("Generation Summary:");
|
Console.WriteLine("Generation Summary:");
|
||||||
Console.Write(" Enums: " + enums);
|
Console.Write(" Enums: " + enums);
|
||||||
|
|
Loading…
Add table
Reference in a new issue