index d419abea2de5e88267b44667ccf95d370d08f698..2b9b5483efa3b7b76050a4c105d3cb4b20dc655c 100644 (file)
return '!';
}
+char
+jvm_get_postfix(oberon_type_t * type)
+{
+ int size = type -> size;
+ switch(type -> class)
+ {
+ case OBERON_TYPE_BOOLEAN:
+ return 'b';
+ break;
+ case OBERON_TYPE_INTEGER:
+ switch(size)
+ {
+ case 1:
+ return 'b';
+ break;
+ case 2:
+ return 's';
+ break;
+ case 4:
+ return 'i';
+ break;
+ case 8:
+ return 'l';
+ break;
+ default:
+ gen_error("jvm_get_postfix: int wat");
+ break;
+ }
+ break;
+ case OBERON_TYPE_PROCEDURE:
+ case OBERON_TYPE_ARRAY:
+ case OBERON_TYPE_RECORD:
+ case OBERON_TYPE_POINTER:
+ return 'a';
+ break;
+ case OBERON_TYPE_REAL:
+ return (size <= 4) ? ('f') : ('d');
+ break;
+ default:
+ gen_error("jvm_get_postfix: wat");
+ break;
+ }
+
+ return '!';
+}
+
char *
jvm_get_field_full_name(oberon_object_t * x)
{
switch(x -> class)
{
case OBERON_CLASS_VAR:
+ case OBERON_CLASS_PROC:
return new_string("%s/%s", x -> module -> name, x -> name);
case OBERON_CLASS_FIELD:;
char * rec_name = jvm_get_class_full_name(x -> parent_type);
return NULL;
}
+char *
+jvm_get_field_full_name_safe(oberon_object_t * x)
+{
+ switch(x -> class)
+ {
+ case OBERON_CLASS_VAR:
+ case OBERON_CLASS_PROC:
+ return new_string("%s$%s", x -> module -> name, x -> name);
+ case OBERON_CLASS_FIELD:;
+ char * rec_name = jvm_get_class_full_name(x -> parent_type);
+ return new_string("%s$%s", rec_name, x -> name);
+ case OBERON_CLASS_MODULE:
+ return new_string(x -> module -> name);
+ default:
+ gen_error("jvm_get_field_full_name: wat");
+ break;
+ }
+
+ return NULL;
+}
+
char *
jvm_get_class_full_name(oberon_type_t * type)
{
switch(type -> class)
{
+ case OBERON_TYPE_POINTER:
+ name = jvm_get_class_full_name(type -> base);
+ break;
case OBERON_TYPE_PROCEDURE:
name = new_string("SYSTEM$PROCEDURE");
}
int
-jvm_cell_size_for_prefix(char prefix)
+jvm_cell_size_for_postfix(char postfix)
{
- switch(prefix)
+ switch(postfix)
{
case 'a':
case 'b':
case 's':
case 'i':
- case 'z':
case 'f':
return 1;
case 'l':
case 'd':
return 2;
default:
- gen_error("jvm_cell_size_for_prefix: unk prefix %c", prefix);
+ gen_error("jvm_cell_size_for_postfix: unk postfix %c", postfix);
}
return -666;