Save the line number of a source comment
authorJohan Dahlin <johan@gnome.org>
Sun, 19 Sep 2010 14:33:38 +0000 (11:33 -0300)
committerJohan Dahlin <johan@gnome.org>
Sun, 19 Sep 2010 15:04:20 +0000 (12:04 -0300)
giscanner/annotationparser.py
giscanner/giscannermodule.c
giscanner/scannerlexer.l
giscanner/sourcescanner.c
giscanner/sourcescanner.h

index 2aa198e224e7f7b319ed27ad665ae3150de3849c..ea1757879bbb466c525a1d0cc10b88533fe3d485 100644 (file)
@@ -139,7 +139,7 @@ class AnnotationParser(object):
             self._parse_comment(comment)
         return self._blocks
 
-    def _parse_comment(self, comment):
+    def _parse_comment(self, cmt):
         # We're looking for gtk-doc comments here, they look like this:
         # /**
         #   * symbol:
@@ -153,6 +153,7 @@ class AnnotationParser(object):
         #  - signal:   GtkWidget::destroy
         #  - property: GtkWidget:visible
         #
+        comment, lineno = cmt
         comment = comment.lstrip()
         if not comment.startswith(_COMMENT_HEADER):
             return
index 2d2e073e0d2611b7a62fb37f8b021c4aa239c620..b4aae792a5d06b6907bd69c688cae3ee32799070 100644 (file)
@@ -517,14 +517,17 @@ pygi_source_scanner_get_comments (PyGISourceScanner *self)
   GSList *l, *comments;
   PyObject *list;
   int i = 0;
-  
+
   comments = gi_source_scanner_get_comments (self->scanner);
   list = PyList_New (g_slist_length (comments));
-  
+
   for (l = comments; l; l = l->next)
     {
-      PyObject *item = PyString_FromString (l->data);
-      PyList_SetItem (list, i++, item);
+      GISourceComment *comment = l->data;
+      PyObject *item = Py_BuildValue ("(ssi)", comment->comment,
+                                      comment->filename,
+                                      comment->line);
+      PyList_SET_ITEM (list, i++, item);
       Py_INCREF (item);
     }
 
index ff1ee0ff8b549887dcca4f259e7cca6e5bd9825d..4fa40f635bd4a134883e2c0a2a18982fb86fb0df 100644 (file)
@@ -210,17 +210,21 @@ yywrap (void)
 static void
 parse_comment (GISourceScanner *scanner)
 {
-  GString *comment;
+  GString *string;
   int c1, c2;
+  GISourceComment *comment;
+  int comment_lineno;
 
   c1 = input();
   c2 = input();
 
-  comment = g_string_new ("");
+  string = g_string_new ("");
+
+  comment_lineno = lineno;
 
   while (c2 != EOF && !(c1 == '*' && c2 == '/'))
     {
-      g_string_append_c (comment, c1);
+      g_string_append_c (string, c1);
 
       if (c1 == '\n')
         lineno++;
@@ -230,8 +234,13 @@ parse_comment (GISourceScanner *scanner)
 
     }
 
+  comment = g_slice_new (GISourceComment);
+  comment->comment = g_string_free (string, FALSE);
+  comment->line = comment_lineno;
+  comment->filename = g_strdup(scanner->current_filename);
+
   scanner->comments = g_slist_prepend (scanner->comments,
-                                       g_string_free (comment, FALSE));
+                                       comment);
 }
 
 static int
index 14e3a3bd1d9824bd5fa60707d4da1a4515660239..e519a942d639a2103dea6db1349dbcbd54b2006c 100644 (file)
@@ -194,6 +194,14 @@ gi_source_scanner_new (void)
   return scanner;
 }
 
+static void
+gi_source_comment_free (GISourceComment *comment)
+{
+  g_free (comment->comment);
+  g_free (comment->filename);
+  g_slice_free (GISourceComment, comment);
+}
+
 void
 gi_source_scanner_free (GISourceScanner *scanner)
 {
@@ -202,7 +210,7 @@ gi_source_scanner_free (GISourceScanner *scanner)
   g_hash_table_destroy (scanner->typedef_table);
   g_hash_table_destroy (scanner->struct_or_union_or_enum_table);
 
-  g_slist_foreach (scanner->comments, (GFunc)g_free, NULL);
+  g_slist_foreach (scanner->comments, (GFunc)gi_source_comment_free, NULL);
   g_slist_free (scanner->comments);
   g_slist_foreach (scanner->symbols, (GFunc)gi_source_symbol_unref, NULL);
   g_slist_free (scanner->symbols);
index 581b6b1772664863a580fb3f4b083174865f1cff..a7bc176c342170b61904d0f33f3f68a9e5a1379e 100644 (file)
@@ -28,6 +28,7 @@
 
 G_BEGIN_DECLS
 
+typedef struct _GISourceComment GISourceComment;
 typedef struct _GISourceScanner GISourceScanner;
 typedef struct _GISourceSymbol GISourceSymbol;
 typedef struct _GISourceType GISourceType;
@@ -95,13 +96,20 @@ typedef enum
   UNARY_LOGICAL_NEGATION
 } UnaryOperator;
 
+struct _GISourceComment
+{
+  char *comment;
+  char *filename;
+  int line;
+};
+
 struct _GISourceScanner
 {
   char *current_filename;
   gboolean macro_scan;
   GSList *symbols;
   GList *filenames;
-  GSList *comments;
+  GSList *comments; /* _GIComment */
   GHashTable *typedef_table;
   GHashTable *struct_or_union_or_enum_table;
 };