mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-11 23:16:14 +01:00
compiler: Remove --code argument
It can't really work right now because we rely on dumping data at runtime, which requires the library. If in the future we support static scanning, we can reinvestigate embedded typelibs.
This commit is contained in:
parent
75cdddb576
commit
b2df59c315
@ -35,7 +35,6 @@
|
|||||||
#include "girparser.h"
|
#include "girparser.h"
|
||||||
#include "gitypelib-internal.h"
|
#include "gitypelib-internal.h"
|
||||||
|
|
||||||
gboolean code = FALSE;
|
|
||||||
gboolean no_init = FALSE;
|
gboolean no_init = FALSE;
|
||||||
gchar **includedirs = NULL;
|
gchar **includedirs = NULL;
|
||||||
gchar **input = NULL;
|
gchar **input = NULL;
|
||||||
@ -46,54 +45,6 @@ gboolean include_cwd = FALSE;
|
|||||||
gboolean debug = FALSE;
|
gboolean debug = FALSE;
|
||||||
gboolean verbose = FALSE;
|
gboolean verbose = FALSE;
|
||||||
|
|
||||||
static gchar *
|
|
||||||
format_output (GTypelib *typelib)
|
|
||||||
{
|
|
||||||
GString *result;
|
|
||||||
guint i;
|
|
||||||
|
|
||||||
result = g_string_sized_new (6 * typelib->len);
|
|
||||||
|
|
||||||
g_string_append_printf (result, "/* GENERATED CODE - DO NOT EDIT */\n");
|
|
||||||
g_string_append_printf (result, "#include <stdlib.h>\n");
|
|
||||||
g_string_append_printf (result, "#include <girepository.h>\n\n");
|
|
||||||
|
|
||||||
g_string_append_printf (result, "const unsigned char _G_TYPELIB[] = \n{");
|
|
||||||
|
|
||||||
for (i = 0; i < typelib->len; i++)
|
|
||||||
{
|
|
||||||
if (i > 0)
|
|
||||||
g_string_append (result, ", ");
|
|
||||||
|
|
||||||
if (i % 10 == 0)
|
|
||||||
g_string_append (result, "\n\t");
|
|
||||||
|
|
||||||
g_string_append_printf (result, "0x%.2x", typelib->data[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
g_string_append_printf (result, "\n};\n\n");
|
|
||||||
g_string_append_printf (result, "const gsize _G_TYPELIB_SIZE = %u;\n\n",
|
|
||||||
(guint)typelib->len);
|
|
||||||
|
|
||||||
if (!no_init)
|
|
||||||
{
|
|
||||||
g_string_append_printf (result,
|
|
||||||
"__attribute__((constructor)) void "
|
|
||||||
"register_typelib (void);\n\n");
|
|
||||||
g_string_append_printf (result,
|
|
||||||
"__attribute__((constructor)) void\n"
|
|
||||||
"register_typelib (void)\n"
|
|
||||||
"{\n"
|
|
||||||
"\tGTypelib *typelib;\n"
|
|
||||||
"\ttypelib = g_typelib_new_from_const_memory (_G_TYPELIB, _G_TYPELIB_SIZE, NULL);\n"
|
|
||||||
"\tg_assert (typelib != NULL);\n"
|
|
||||||
"\tg_irepository_load_typelib (NULL, typelib, G_IREPOSITORY_LOAD_FLAG_LAZY, NULL);\n"
|
|
||||||
"}\n\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
return g_string_free (result, FALSE);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
write_out_typelib (gchar *prefix,
|
write_out_typelib (gchar *prefix,
|
||||||
GTypelib *typelib)
|
GTypelib *typelib)
|
||||||
@ -136,23 +87,12 @@ write_out_typelib (gchar *prefix,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!code)
|
written = fwrite (typelib->data, 1, typelib->len, file);
|
||||||
{
|
if (written < typelib->len) {
|
||||||
written = fwrite (typelib->data, 1, typelib->len, file);
|
g_error ("ERROR: Could not write the whole output: %s",
|
||||||
if (written < typelib->len) {
|
strerror(errno));
|
||||||
g_error ("ERROR: Could not write the whole output: %s",
|
goto out;
|
||||||
strerror(errno));
|
}
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
gchar *code;
|
|
||||||
|
|
||||||
code = format_output (typelib);
|
|
||||||
fputs (code, file);
|
|
||||||
g_free (code);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (output != NULL)
|
if (output != NULL)
|
||||||
fclose (file);
|
fclose (file);
|
||||||
@ -183,7 +123,6 @@ static void log_handler (const gchar *log_domain,
|
|||||||
|
|
||||||
static GOptionEntry options[] =
|
static GOptionEntry options[] =
|
||||||
{
|
{
|
||||||
{ "code", 0, 0, G_OPTION_ARG_NONE, &code, "emit C code", NULL },
|
|
||||||
{ "no-init", 0, 0, G_OPTION_ARG_NONE, &no_init, "do not create _init() function", NULL },
|
{ "no-init", 0, 0, G_OPTION_ARG_NONE, &no_init, "do not create _init() function", NULL },
|
||||||
{ "includedir", 0, 0, G_OPTION_ARG_FILENAME_ARRAY, &includedirs, "include directories in GIR search path", NULL },
|
{ "includedir", 0, 0, G_OPTION_ARG_FILENAME_ARRAY, &includedirs, "include directories in GIR search path", NULL },
|
||||||
{ "output", 'o', 0, G_OPTION_ARG_FILENAME, &output, "output file", "FILE" },
|
{ "output", 'o', 0, G_OPTION_ARG_FILENAME, &output, "output file", "FILE" },
|
||||||
|
Loading…
Reference in New Issue
Block a user