pygi_source_symbol_new (GISourceSymbol *symbol)
{
PyGISourceSymbol *self;
-
+
if (symbol == NULL)
{
Py_INCREF (Py_None);
return Py_None;
}
-
+
self = (PyGISourceSymbol *)PyObject_New (PyGISourceSymbol,
&PyGISourceSymbol_Type);
self->symbol = symbol;
symbol_get_ident (PyGISourceSymbol *self,
void *context)
{
-
+
if (!self->symbol->ident)
{
Py_INCREF(Py_None);
return Py_None;
}
-
+
return PyString_FromString (self->symbol->ident);
}
Py_INCREF(Py_None);
return Py_None;
}
-
+
return PyString_FromString (self->symbol->const_string);
}
pygi_source_type_new (GISourceType *type)
{
PyGISourceType *self;
-
+
if (type == NULL)
{
Py_INCREF (Py_None);
return Py_None;
}
-
+
self = (PyGISourceType *)PyObject_New (PyGISourceType,
&PyGISourceType_Type);
self->type = type;
Py_INCREF (Py_None);
return Py_None;
}
-
+
return PyString_FromString (self->type->name);
}
if (!self->type)
return Py_BuildValue("[]");
-
+
list = PyList_New (g_list_length (self->type->child_list));
-
+
for (l = self->type->child_list; l; l = l->next)
{
PyObject *item = pygi_source_symbol_new (l->data);
self->scanner->filenames = g_list_append (self->scanner->filenames,
g_realpath (filename));
-
+
Py_INCREF (Py_None);
return Py_None;
}
{
int fd;
FILE *fp;
-
+
if (!PyArg_ParseTuple (args, "i:SourceScanner.parse_file", &fd))
return NULL;
g_print ("Could not get OS handle from msvcr71 fd.\n");
return NULL;
}
-
+
fd = _open_osfhandle (handle, _O_RDONLY);
if (fd == -1)
{
PyObject *args)
{
char *filename;
-
+
if (!PyArg_ParseTuple (args, "s:SourceScanner.lex_filename", &filename))
return NULL;
PyObject *args)
{
int macro_scan;
-
+
if (!PyArg_ParseTuple (args, "b:SourceScanner.set_macro_scan", ¯o_scan))
return NULL;
GSList *l, *symbols;
PyObject *list;
int i = 0;
-
+
symbols = gi_source_scanner_get_symbols (self->scanner);
list = PyList_New (g_slist_length (symbols));
-
+
for (l = symbols; l; l = l->next)
{
PyObject *item = pygi_source_symbol_new (l->data);
{
int attr_length = 0;
int i;
-
+
if (indent == -1)
return -1;
PyObject *tuple;
char *attr, *value;
char *escaped;
-
+
tuple = PyList_GetItem (attributes, i);
if (PyTuple_GetItem(tuple, 1) == Py_None)
continue;
if (!PyArg_ParseTuple(tuple, "ss", &attr, &value))
return -1;
-
+
escaped = g_markup_escape_text (value, -1);
attr_length += 2 + strlen(attr) + strlen(escaped) + 2;
g_free(escaped);
gboolean first;
GString *attr_value;
int len;
-
+
if (!PyArg_ParseTuple(args, "sO!isi",
&tag_name, &PyList_Type, &attributes,
&self_indent, &indent_char,
first = TRUE;
attr_value = g_string_new ("");
-
+
for (i = 0; i < PyList_Size (attributes); ++i)
{
PyObject *tuple;
char *attr, *value, *escaped;
-
+
tuple = PyList_GetItem (attributes, i);
-
- if (!PyTuple_Check (tuple))
+
+ if (!PyTuple_Check (tuple))
{
PyErr_SetString(PyExc_TypeError,
"attribute item must be a tuple");
return NULL;
}
-
+
if (!PyTuple_Size (tuple) == 2)
{
PyErr_SetString(PyExc_IndexError,
"attribute item must be a tuple of length 2");
return NULL;
}
-
+
if (PyTuple_GetItem(tuple, 1) == Py_None)
continue;
extern int yylex (GISourceScanner *scanner);
static void yyerror (GISourceScanner *scanner, const char *str);
-
+
extern void ctype_free (GISourceType * type);
static int last_enum_value = -1;
{
#if 0
g_warning ("Ignoring non-UTF-8 constant string \"%s\"", yytext + 1);
-#endif
+#endif
g_free($$->const_string);
$$->const_string = NULL;
}
gi_source_scanner_parse_file (GISourceScanner *scanner, FILE *file)
{
g_return_val_if_fail (file != NULL, FALSE);
-
+
const_table = g_hash_table_new_full (g_str_hash, g_str_equal,
g_free, (GDestroyNotify)gi_source_symbol_unref);
-
+
lineno = 1;
yyin = file;
yyparse (scanner);
-
+
g_hash_table_destroy (const_table);
const_table = NULL;
-
+
yyin = NULL;
return TRUE;
;
fclose (yyin);
-
+
return TRUE;
}