case sig::typename_P: return $ CYTypedIdentifier($V("Class"));
case sig::union_P: _assert(false); break;
- case sig::string_P: return $ CYTypedIdentifier($V("char"), $ CYTypeConstant($ CYTypePointerTo()));
+ case sig::string_P: return $ CYTypedIdentifier($V("char"), $ CYTypePointerTo());
case sig::selector_P: return $ CYTypedIdentifier($V("SEL"));
case sig::block_P: _assert(false); break;
CYTypedIdentifier *Decode(CYPool &pool, struct sig::Type *type) {
CYTypedIdentifier *typed(Decode_(pool, type));
- if ((type->flags & JOC_TYPE_CONST) != 0)
- typed = typed->Modify($ CYTypeConstant());
+ if ((type->flags & JOC_TYPE_CONST) != 0) {
+ if (type->primitive == sig::string_P)
+ typed->modifier_ = $ CYTypeConstant(typed->modifier_);
+ else
+ typed = typed->Modify($ CYTypeConstant());
+ }
return typed;
}
sig::Type type;
type.name = NULL;
- type.flags = 0;
- type.primitive = sig::pointer_P;
- type.data.data.type = internal->type_;
- type.data.data.size = 0;
+ if (internal->type_->primitive == sig::char_P) {
+ type.flags = internal->type_->flags;
+ type.primitive = sig::string_P;
+ type.data.data.type = NULL;
+ type.data.data.size = 0;
+ } else {
+ type.flags = 0;
+ type.primitive = sig::pointer_P;
+ type.data.data.type = internal->type_;
+ type.data.data.size = 0;
+ }
return CYMakeType(context, &type);
} CYCatch(NULL) }