+void
+check_func_attrs(Class *c)
+{
+ GList *li;
+ for (li = c->nodes; li != NULL; li = li->next) {
+ Node *n = li->data;
+ if (n->type == METHOD_NODE) {
+ Method *m = (Method *)n;
+ if ((m->method == INIT_METHOD ||
+ m->method == CLASS_INIT_METHOD)
+ && (m->funcattrs != NULL && strlen(m->funcattrs) != 0)) {
+ /* This is actually dead code at the moment, since the parser
+ doesn't accept attributes to the init or class_init
+ syntactic forms anyway. But it could easily be made to do
+ so, and also for virtual override and signal methods, and
+ then we could give kinder error messages here. */
+ error_print (GOB_ERROR, m->line_no,
+ "function attributes (G_GNUC_PRINTF, etc.) aren't "
+ "supported for the init or class_init methods");
+ }
+ }
+ }
+}
+
+void
+check_for_class_destructors (Class *c)
+{
+ GList *li;
+ for (li = c->nodes; li != NULL; li = li->next) {
+ Node *n = li->data;
+ if (n->type == VARIABLE_NODE) {
+ Variable *v = (Variable *)n;
+ if (v->destructor != NULL &&
+ v->scope == CLASS_SCOPE) {
+ error_print (GOB_WARN, v->line_no,
+ "classwide members cannot have "
+ "destructors since the classes "
+ "are static and never get "
+ "destroyed anyway");
+ }
+ }
+ }
+}
+