- ir_visibility vis;
- ir_type *var_type;
- switch ((storage_class_tag_t) entity->declaration.storage_class) {
- case STORAGE_CLASS_STATIC:
- vis = visibility_local;
- goto global_var;
-
- case STORAGE_CLASS_EXTERN:
- vis = visibility_external_allocated;
- goto global_var;
-
- case STORAGE_CLASS_NONE:
- vis = visibility_external_visible;
- goto global_var;
-
- case STORAGE_CLASS_THREAD:
- vis = visibility_external_visible;
- goto tls_var;
-
- case STORAGE_CLASS_THREAD_EXTERN:
- vis = visibility_external_allocated;
- goto tls_var;
-
- case STORAGE_CLASS_THREAD_STATIC:
- vis = visibility_local;
- goto tls_var;
-
-tls_var:
- var_type = get_tls_type();
- goto create_var;
-
-global_var:
- var_type = get_glob_type();
- goto create_var;
-
-create_var:
- create_variable_entity(entity,
- DECLARATION_KIND_GLOBAL_VARIABLE,
- var_type);
- /* Matze: I'm confused, shouldn't we only be here when creating
- * variables? */
-#if 0
- if (!is_type_function(skip_typeref(entity->declaration.type))) {
- set_entity_visibility(declaration->v.entity, vis);
- }
-#else
- set_entity_visibility(entity->variable.v.entity, vis);
-#endif
-
- return;
+ ir_visibility vis;
+ switch ((storage_class_tag_t)entity->declaration.storage_class) {
+ case STORAGE_CLASS_STATIC: vis = visibility_local; break;
+ case STORAGE_CLASS_EXTERN: vis = visibility_external_allocated; break;
+ case STORAGE_CLASS_NONE: vis = visibility_external_visible; break;