summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--codemaker/source/codemaker/codemaker.cxx33
-rw-r--r--codemaker/source/commonjava/commonjava.cxx45
-rw-r--r--codemaker/source/cppumaker/cpputype.cxx9
-rw-r--r--codemaker/source/javamaker/classfile.cxx53
-rw-r--r--codemaker/source/javamaker/javatype.cxx567
5 files changed, 150 insertions, 557 deletions
diff --git a/codemaker/source/codemaker/codemaker.cxx b/codemaker/source/codemaker/codemaker.cxx
index 6c203bf6dc4b..b6169b88664e 100644
--- a/codemaker/source/codemaker/codemaker.cxx
+++ b/codemaker/source/codemaker/codemaker.cxx
@@ -41,8 +41,7 @@ namespace {
void checkNoTypeArguments(std::vector< rtl::OString > const & arguments) {
if (!arguments.empty()) {
- throw CannotDumpException(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Bad type information")));
+ throw CannotDumpException("Bad type information");
//TODO
}
}
@@ -58,10 +57,7 @@ rtl::OString convertString(rtl::OUString const & string) {
(RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR
| RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR)))
{
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Failure converting string from UTF-16 to UTF-8")));
+ throw CannotDumpException("Failure converting string from UTF-16 to UTF-8");
}
return s;
}
@@ -82,10 +78,7 @@ codemaker::UnoType::Sort decomposeAndResolve(
sal_Int32 n = 0;
*name = codemaker::UnoType::decompose(t, &n, arguments);
if (n > SAL_MAX_INT32 - *rank) {
- throw CannotDumpException(
- errorMsg(rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
- type));
+ throw CannotDumpException(errorMsg("Bad type information: ", type));
//TODO
}
*rank += n;
@@ -97,10 +90,7 @@ codemaker::UnoType::Sort decomposeAndResolve(
switch (sort) {
case codemaker::UnoType::SORT_VOID:
if (!allowVoid) {
- throw CannotDumpException(
- errorMsg(rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
- type));
+ throw CannotDumpException( errorMsg("Bad type information: ", type));
//TODO
}
default:
@@ -123,10 +113,7 @@ codemaker::UnoType::Sort decomposeAndResolve(
|| (static_cast< sal_uInt16 >(arguments->size())
!= reader.getReferenceCount())))
{
- throw CannotDumpException(
- errorMsg(rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
- type));
+ throw CannotDumpException(errorMsg("Bad type information: ", type));
//TODO
}
return sort;
@@ -137,10 +124,7 @@ codemaker::UnoType::Sort decomposeAndResolve(
case RT_TYPE_SINGLETON:
case RT_TYPE_CONSTANTS:
if (!allowExtraEntities) {
- throw CannotDumpException(
- errorMsg(rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
- type));
+ throw CannotDumpException(errorMsg("Bad type information: ", type));
//TODO
}
checkNoTypeArguments(*arguments);
@@ -162,10 +146,7 @@ codemaker::UnoType::Sort decomposeAndResolve(
}
}
default:
- throw CannotDumpException(
- errorMsg(rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
- type));
+ throw CannotDumpException(errorMsg("Bad type information: ", type));
//TODO
}
}
diff --git a/codemaker/source/commonjava/commonjava.cxx b/codemaker/source/commonjava/commonjava.cxx
index e5f6eca8fc5d..8049c98295a0 100644
--- a/codemaker/source/commonjava/commonjava.cxx
+++ b/codemaker/source/commonjava/commonjava.cxx
@@ -55,36 +55,21 @@ OString translateUnoToJavaType(
}
} else {
rtl::OString const javaTypes[codemaker::UnoType::SORT_ANY + 1][2] = {
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("void")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Void")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("boolean")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Boolean")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("byte")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Byte")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("short")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Short")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("short")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Short")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("int")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Integer")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("int")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Integer")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("long")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Long")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("long")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Long")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("float")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Float")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("double")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Double")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("char")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Character")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/String")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/String")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")) },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Object")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("java/lang/Object")) } };
+ { "void", "java/lang/Void" },
+ { "boolean", "java/lang/Boolean" },
+ { "byte", "java/lang/Byte" },
+ { "short", "java/lang/Short" },
+ { "short", "java/lang/Short" },
+ { "int", "java/lang/Integer" },
+ { "int", "java/lang/Integer" },
+ { "long", "java/lang/Long" },
+ { "long", "java/lang/Long" },
+ { "float", "java/lang/Float" },
+ { "double", "java/lang/Double" },
+ { "char", "java/lang/Character" },
+ { "java/lang/String", "java/lang/String" },
+ { "com/sun/star/uno/Type", "com/sun/star/uno/Type" },
+ { "java/lang/Object", "java/lang/Object" } };
buf.append(javaTypes[sort][referenceType]);
}
return buf.makeStringAndClear();
diff --git a/codemaker/source/cppumaker/cpputype.cxx b/codemaker/source/cppumaker/cpputype.cxx
index 6ee5f9e45b0f..1ac9673dfb2d 100644
--- a/codemaker/source/cppumaker/cpputype.cxx
+++ b/codemaker/source/cppumaker/cpputype.cxx
@@ -170,8 +170,7 @@ CppuType::~CppuType()
void CppuType::addGetCppuTypeIncludes(codemaker::cppumaker::Includes & includes)
const
{
- if (m_typeName.equals("com/sun/star/uno/XInterface")
- || m_typeName.equals("com/sun/star/uno/Exception"))
+ if (m_typeName == "com/sun/star/uno/XInterface" || m_typeName == "com/sun/star/uno/Exception")
{
includes.addType();
includes.addCppuUnotypeHxx();
@@ -514,10 +513,8 @@ void CppuType::dumpHFileContent(
out << "\n";
}
dumpDeclaration(out);
- if (!(m_typeName.equalsL(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/XInterface")) ||
- m_typeName.equalsL(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Exception")) ||
+ if (!(m_typeName == "com/sun/star/uno/XInterface" ||
+ m_typeName == "com/sun/star/uno/Exception" ||
isPolymorphic()))
{
out << "\n" << indent()
diff --git a/codemaker/source/javamaker/classfile.cxx b/codemaker/source/javamaker/classfile.cxx
index 1a61e2fe2092..e9d1b91226b8 100644
--- a/codemaker/source/javamaker/classfile.cxx
+++ b/codemaker/source/javamaker/classfile.cxx
@@ -73,10 +73,8 @@ void appendStream(
}
void write(FileStream & file, void const * buffer, sal_uInt64 size) {
- if (!file.write(buffer, size)) {
- throw CannotDumpException(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Error writing file")));
- }
+ if (!file.write(buffer, size))
+ throw CannotDumpException("Error writing file");
}
void writeU2(FileStream & file, sal_uInt16 data) {
@@ -237,10 +235,7 @@ void ClassFile::Code::instrLookupswitch(
// <match--offset pairs...>:
std::list< std::pair< sal_Int32, Code * > >::size_type size = blocks.size();
if (size > SAL_MAX_INT32) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Lookup-switch too large for Java class file format")));
+ throw CannotDumpException("Lookup-switch too large for Java class file format");
}
Position pos1 = m_code.size();
appendU1(m_code, 0xAB);
@@ -420,10 +415,7 @@ void ClassFile::Code::addException(
{
OSL_ASSERT(start < end && end <= m_code.size() && handler <= m_code.size());
if (m_exceptionTableLength == SAL_MAX_UINT16) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Too many exception handlers for Java class file format")));
+ throw CannotDumpException("Too many exception handlers for Java class file format");
}
++m_exceptionTableLength;
appendU2(m_exceptionTable, static_cast< sal_uInt16 >(start));
@@ -567,10 +559,7 @@ sal_uInt16 ClassFile::addDoubleInfo(double value) {
void ClassFile::addInterface(rtl::OString const & interface) {
if (m_interfacesCount == SAL_MAX_UINT16) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Too many interfaces for Java class file format")));
+ throw CannotDumpException("Too many interfaces for Java class file format");
}
++m_interfacesCount;
appendU2(m_interfaces, addClassInfo(interface));
@@ -582,10 +571,7 @@ void ClassFile::addField(
rtl::OString const & signature)
{
if (m_fieldsCount == SAL_MAX_UINT16) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Too many fields for Java class file format")));
+ throw CannotDumpException("Too many fields for Java class file format");
}
++m_fieldsCount;
appendU2(m_fields, static_cast< sal_uInt16 >(accessFlags));
@@ -613,10 +599,7 @@ void ClassFile::addMethod(
rtl::OString const & signature)
{
if (m_methodsCount == SAL_MAX_UINT16) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Too many methods for Java class file format")));
+ throw CannotDumpException("Too many methods for Java class file format");
}
++m_methodsCount;
appendU2(m_methods, static_cast< sal_uInt16 >(accessFlags));
@@ -624,11 +607,7 @@ void ClassFile::addMethod(
appendU2(m_methods, addUtf8Info(descriptor));
std::vector< rtl::OString >::size_type excs = exceptions.size();
if (excs > SAL_MAX_UINT16) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Too many exception specifications for Java class file"
- " format")));
+ throw CannotDumpException("Too many exception specifications for Java class file format");
}
appendU2(
m_methods,
@@ -643,10 +622,7 @@ void ClassFile::addMethod(
> (SAL_MAX_UINT32 - (2 + 2 + 4 + 2 + 2)
- static_cast< sal_uInt32 >(codeSize))))
{
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Code block is too big for Java class file format")));
+ throw CannotDumpException("Code block is too big for Java class file format");
}
appendU2(
m_methods,
@@ -703,11 +679,7 @@ void ClassFile::write(FileStream & file) const {
sal_uInt16 ClassFile::nextConstantPoolIndex(sal_uInt16 width) {
OSL_ASSERT(width == 1 || width == 2);
if (m_constantPoolCount > SAL_MAX_UINT16 - width) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Too many constant pool items for Java class file"
- " format")));
+ throw CannotDumpException("Too many constant pool items for Java class file format");
}
sal_uInt16 index = m_constantPoolCount;
m_constantPoolCount = m_constantPoolCount + width;
@@ -720,10 +692,7 @@ sal_uInt16 ClassFile::addUtf8Info(rtl::OString const & value) {
return i->second;
}
if (value.getLength() > SAL_MAX_UINT16) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "UTF-8 string too long for Java class file format")));
+ throw CannotDumpException("UTF-8 string too long for Java class file format");
}
sal_uInt16 index = nextConstantPoolIndex(1);
appendU1(m_constantPool, 1);
diff --git a/codemaker/source/javamaker/javatype.cxx b/codemaker/source/javamaker/javatype.cxx
index 64d0e24ed497..9aa4a0aa1046 100644
--- a/codemaker/source/javamaker/javatype.cxx
+++ b/codemaker/source/javamaker/javatype.cxx
@@ -153,10 +153,7 @@ SpecialType translateUnoTypeToDescriptor(
{
OSL_ASSERT(rank >= 0 && (signature == 0) == (needsSignature == 0));
if (rank > 0xFF - (array ? 1 : 0)) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Too many array dimensions for Java class file format")));
+ throw CannotDumpException("Too many array dimensions for Java class file format");
}
if (array) {
++rank;
@@ -223,60 +220,21 @@ SpecialType translateUnoTypeToDescriptor(
} else {
static rtl::OString const
simpleTypeDescriptors[codemaker::UnoType::SORT_ANY + 1][2] = {
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("V")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Void;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("Z")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Boolean;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("B")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Byte;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("S")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Short;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("S")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Short;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("I")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Integer;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("I")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Integer;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("J")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Long;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("J")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Long;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("F")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Float;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("D")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Double;"))
- },
- { rtl::OString(RTL_CONSTASCII_STRINGPARAM("C")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Character;"))
- },
- { rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/String;")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Ljava/lang/String;"))
- },
- { rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Lcom/sun/star/uno/Type;")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Lcom/sun/star/uno/Type;"))
- },
- { rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Object;")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Object;"))
- } };
+ { "V", "Ljava/lang/Void;" },
+ { "Z", "Ljava/lang/Boolean;" },
+ { "B", "Ljava/lang/Byte;" },
+ { "S", "Ljava/lang/Short;" },
+ { "S", "Ljava/lang/Short;" },
+ { "I", "Ljava/lang/Integer;" },
+ { "I", "Ljava/lang/Integer;" },
+ { "J", "Ljava/lang/Long;" },
+ { "J", "Ljava/lang/Long;" },
+ { "F", "Ljava/lang/Float;" },
+ { "D", "Ljava/lang/Double;" },
+ { "C", "Ljava/lang/Character;" },
+ { "Ljava/lang/String;", "Ljava/lang/String;" },
+ { "Lcom/sun/star/uno/Type;", "Lcom/sun/star/uno/Type;" },
+ { "Ljava/lang/Object;", "Ljava/lang/Object;" } };
rtl::OString const & s
= simpleTypeDescriptors[sort][rank == 0 && classType];
if (descriptor != 0) {
@@ -520,10 +478,7 @@ sal_uInt16 TypeInfo::generateCode(
OSL_ASSERT(dependencies != 0);
switch (m_kind) {
case KIND_MEMBER:
- code.instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/MemberTypeInfo")));
+ code.instrNew("com/sun/star/lib/uno/typeinfo/MemberTypeInfo");
code.instrDup();
code.loadStringConstant(m_name);
code.loadIntegerConstant(m_index);
@@ -531,105 +486,57 @@ sal_uInt16 TypeInfo::generateCode(
if (m_polymorphicUnoType.kind != PolymorphicUnoType::KIND_NONE) {
generatePolymorphicUnoTypeCode(code, dependencies);
code.loadIntegerConstant(m_typeParameterIndex);
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/MemberTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;IILcom/sun/star/uno/Type;I)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/MemberTypeInfo"
+ ,"<init>", "(Ljava/lang/String;IILcom/sun/star/uno/Type;I)V");
return 8;
} else if (m_typeParameterIndex >= 0) {
code.instrAconstNull();
code.loadIntegerConstant(m_typeParameterIndex);
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/MemberTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;IILcom/sun/star/uno/Type;I)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/MemberTypeInfo"
+ ,"<init>", "(Ljava/lang/String;IILcom/sun/star/uno/Type;I)V");
return 6;
} else {
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/MemberTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("(Ljava/lang/String;II)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/MemberTypeInfo"
+ ,"<init>", "(Ljava/lang/String;II)V");
return 4;
}
case KIND_ATTRIBUTE:
- code.instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/AttributeTypeInfo")));
+ code.instrNew("com/sun/star/lib/uno/typeinfo/AttributeTypeInfo");
code.instrDup();
code.loadStringConstant(m_name);
code.loadIntegerConstant(m_index);
code.loadIntegerConstant(m_flags);
if (m_polymorphicUnoType.kind != PolymorphicUnoType::KIND_NONE) {
generatePolymorphicUnoTypeCode(code, dependencies);
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/AttributeTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;IILcom/sun/star/uno/Type;)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/AttributeTypeInfo"
+ ,"<init>", "(Ljava/lang/String;IILcom/sun/star/uno/Type;)V");
return 8;
} else {
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/AttributeTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("(Ljava/lang/String;II)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/AttributeTypeInfo"
+ ,"<init>", "(Ljava/lang/String;II)V");
return 4;
}
case KIND_METHOD:
- code.instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/MethodTypeInfo")));
+ code.instrNew("com/sun/star/lib/uno/typeinfo/MethodTypeInfo");
code.instrDup();
code.loadStringConstant(m_name);
code.loadIntegerConstant(m_index);
code.loadIntegerConstant(m_flags);
if (m_polymorphicUnoType.kind != PolymorphicUnoType::KIND_NONE) {
generatePolymorphicUnoTypeCode(code, dependencies);
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/MethodTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;IILcom/sun/star/uno/Type;)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/MethodTypeInfo"
+ ,"<init>", "(Ljava/lang/String;IILcom/sun/star/uno/Type;)V");
return 8;
} else {
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/MethodTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("(Ljava/lang/String;II)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/MethodTypeInfo"
+ ,"<init>", "(Ljava/lang/String;II)V");
return 4;
}
case KIND_PARAMETER:
- code.instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/ParameterTypeInfo")));
+ code.instrNew("com/sun/star/lib/uno/typeinfo/ParameterTypeInfo");
code.instrDup();
code.loadStringConstant(m_name);
code.loadStringConstant(m_methodName);
@@ -637,25 +544,13 @@ sal_uInt16 TypeInfo::generateCode(
code.loadIntegerConstant(m_flags);
if (m_polymorphicUnoType.kind != PolymorphicUnoType::KIND_NONE) {
generatePolymorphicUnoTypeCode(code, dependencies);
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/ParameterTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;Ljava/lang/String;II"
- "Lcom/sun/star/uno/Type;)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/ParameterTypeInfo"
+ ,"<init>", "(Ljava/lang/String;Ljava/lang/String;II"
+ "Lcom/sun/star/uno/Type;)V");
return 9;
} else {
- code.instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/ParameterTypeInfo")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;Ljava/lang/String;II)V")));
+ code.instrInvokespecial("com/sun/star/lib/uno/typeinfo/ParameterTypeInfo"
+ ,"<init>", "(Ljava/lang/String;Ljava/lang/String;II)V");
return 5;
}
@@ -671,33 +566,16 @@ void TypeInfo::generatePolymorphicUnoTypeCode(
OSL_ASSERT(
dependencies != 0
&& m_polymorphicUnoType.kind != PolymorphicUnoType::KIND_NONE);
- code.instrNew(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")));
+ code.instrNew("com/sun/star/uno/Type");
code.instrDup();
code.loadStringConstant(m_polymorphicUnoType.name);
if (m_polymorphicUnoType.kind == PolymorphicUnoType::KIND_STRUCT) {
- code.instrGetstatic(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/TypeClass")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("STRUCT")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Lcom/sun/star/uno/TypeClass;")));
+ code.instrGetstatic("com/sun/star/uno/TypeClass", "STRUCT", "Lcom/sun/star/uno/TypeClass;");
} else {
- code.instrGetstatic(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/TypeClass")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("SEQUENCE")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Lcom/sun/star/uno/TypeClass;")));
+ code.instrGetstatic("com/sun/star/uno/TypeClass", "SEQUENCE", "Lcom/sun/star/uno/TypeClass;");
}
- dependencies->insert(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/TypeClass")));
- code.instrInvokespecial(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;Lcom/sun/star/uno/TypeClass;)V")));
+ dependencies->insert("com/sun/star/uno/TypeClass");
+ code.instrInvokespecial("com/sun/star/uno/Type", "<init>", "(Ljava/lang/String;Lcom/sun/star/uno/TypeClass;)V");
}
void writeClassFile(
@@ -723,10 +601,7 @@ void writeClassFile(
FileStream tempfile;
tempfile.createTempFile(getTempDir(filename));
if (!tempfile.isValid()) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Cannot create temporary file for "))
- + filename);
+ throw CannotDumpException("Cannot create temporary file for " + filename);
}
rtl::OString tempname(tempfile.getName());
try {
@@ -753,10 +628,7 @@ void addTypeInfo(
OSL_ASSERT(dependencies != 0 && classFile != 0);
std::vector< TypeInfo >::size_type typeInfos = typeInfo.size();
if (typeInfos > SAL_MAX_INT32) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "UNOTYPEINFO array too big for Java class file format")));
+ throw CannotDumpException("UNOTYPEINFO array too big for Java class file format");
}
if (typeInfos != 0) {
classFile->addField(
@@ -772,10 +644,7 @@ void addTypeInfo(
std::auto_ptr< ClassFile::Code > code(classFile->newCode());
SAL_WNODEPRECATED_DECLARATIONS_POP
code->loadIntegerConstant(static_cast< sal_Int32 >(typeInfos));
- code->instrAnewarray(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/lib/uno/typeinfo/TypeInfo")));
+ code->instrAnewarray("com/sun/star/lib/uno/typeinfo/TypeInfo");
sal_Int32 index = 0;
sal_uInt16 stack = 0;
for (std::vector< TypeInfo >::const_iterator i(typeInfo.begin());
@@ -786,17 +655,10 @@ void addTypeInfo(
stack = std::max(stack, i->generateCode(*code, dependencies));
code->instrAastore();
}
- code->instrPutstatic(
- className, rtl::OString(RTL_CONSTASCII_STRINGPARAM("UNOTYPEINFO")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "[Lcom/sun/star/lib/uno/typeinfo/TypeInfo;")));
+ code->instrPutstatic(className, "UNOTYPEINFO", "[Lcom/sun/star/lib/uno/typeinfo/TypeInfo;");
code->instrReturn();
if (stack > SAL_MAX_UINT16 - 4) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Stack too big for Java class file format")));
+ throw CannotDumpException("Stack too big for Java class file format");
}
code->setMaxStackAndLocals(static_cast< sal_uInt16 >(stack + 4), 0);
classFile->addMethod(
@@ -821,8 +683,7 @@ void handleEnumType(
if (fields == 0 || reader.getSuperTypeCount() != 0
|| reader.getMethodCount() != 0 || reader.getReferenceCount() != 0)
{
- throw CannotDumpException(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("Bad type information")));
+ throw CannotDumpException("Bad type information");
//TODO
}
rtl::OString className(codemaker::convertString(reader.getTypeName()));
@@ -843,9 +704,7 @@ void handleEnumType(
|| reader.getFieldFlags(i) != RT_ACCESS_CONST
|| reader.getFieldTypeName(i).getLength() != 0)
{
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Bad type information"))); //TODO
+ throw CannotDumpException("Bad type information"); //TODO
}
rtl::OString fieldName(
codemaker::convertString(reader.getFieldName(i)));
@@ -858,7 +717,7 @@ void handleEnumType(
static_cast< ClassFile::AccessFlags >(
ClassFile::ACC_PUBLIC | ClassFile::ACC_STATIC
| ClassFile::ACC_FINAL),
- fieldName + rtl::OString(RTL_CONSTASCII_STRINGPARAM("_value")),
+ fieldName + "_value",
rtl::OString(RTL_CONSTASCII_STRINGPARAM("I")),
cf->addIntegerInfo(fieldValue.m_value.aLong), rtl::OString());
}
@@ -867,10 +726,7 @@ void handleEnumType(
SAL_WNODEPRECATED_DECLARATIONS_POP
code->loadLocalReference(0);
code->loadLocalInteger(1);
- code->instrInvokespecial(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Enum")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(I)V")));
+ code->instrInvokespecial("com/sun/star/uno/Enum", "<init>", "(I)V");
code->instrReturn();
code->setMaxStackAndLocals(2, 2);
cf->addMethod(
@@ -979,9 +835,7 @@ void handleEnumType(
code->instrNew(className);
code->instrDup();
code->loadIntegerConstant(reader.getFieldValue(i).m_value.aLong);
- code->instrInvokespecial(
- className, rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(I)V")));
+ code->instrInvokespecial(className, "<init>", "(I)V");
code->instrPutstatic(
className,
codemaker::convertString(reader.getFieldName(i)),
@@ -1046,38 +900,19 @@ sal_uInt16 addFieldInit(
case codemaker::UnoType::SORT_STRING:
code->loadLocalReference(0);
code->loadStringConstant(rtl::OString());
- code->instrPutfield(
- className, fieldName,
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/String;")));
+ code->instrPutfield(className, fieldName, "Ljava/lang/String;");
return 2;
case codemaker::UnoType::SORT_TYPE:
code->loadLocalReference(0);
- code->instrGetstatic(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("VOID")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Lcom/sun/star/uno/Type;")));
- code->instrPutfield(
- className, fieldName,
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Lcom/sun/star/uno/Type;")));
+ code->instrGetstatic("com/sun/star/uno/Type", "VOID", "Lcom/sun/star/uno/Type;");
+ code->instrPutfield(className, fieldName, "Lcom/sun/star/uno/Type;");
return 2;
case codemaker::UnoType::SORT_ANY:
code->loadLocalReference(0);
- code->instrGetstatic(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Any")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("VOID")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Lcom/sun/star/uno/Any;")));
- code->instrPutfield(
- className, fieldName,
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("Ljava/lang/Object;")));
+ code->instrGetstatic("com/sun/star/uno/Any", "VOID", "Lcom/sun/star/uno/Any;");
+ code->instrPutfield(className, fieldName, "Ljava/lang/Object;");
return 2;
case codemaker::UnoType::SORT_COMPLEX:
@@ -1087,10 +922,7 @@ sal_uInt16 addFieldInit(
code->loadLocalReference(0);
typereg::Reader reader(manager.getTypeReader(nucleus));
if (reader.getFieldCount() == 0) {
- throw CannotDumpException(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Bad type information"))); //TODO
+ throw CannotDumpException("Bad type information"); //TODO
}
rtl::OStringBuffer descBuf;
translateUnoTypeToDescriptor(
@@ -1111,10 +943,7 @@ sal_uInt16 addFieldInit(
code->loadLocalReference(0);
code->instrNew(nucleus);
code->instrDup();
- code->instrInvokespecial(
- nucleus,
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("()V")));
+ code->instrInvokespecial(nucleus, "<init>", "()V");
rtl::OStringBuffer desc;
translateUnoTypeToDescriptor(
manager, sort, typeClass, nucleus, 0,
@@ -1190,16 +1019,10 @@ sal_uInt16 addLoadLocal(
switch (sort) {
case codemaker::UnoType::SORT_BOOLEAN:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Boolean")));
+ code->instrNew("java/lang/Boolean");
code->instrDup();
code->loadLocalInteger(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Boolean")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(Z)V")));
+ code->instrInvokespecial("java/lang/Boolean", "<init>", "(Z)V");
stack = 3;
} else {
code->loadLocalInteger(*index);
@@ -1210,16 +1033,10 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_BYTE:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Byte")));
+ code->instrNew("java/lang/Byte");
code->instrDup();
code->loadLocalInteger(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Byte")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(B)V")));
+ code->instrInvokespecial("java/lang/Byte", "<init>", "(B)V");
stack = 3;
} else {
code->loadLocalInteger(*index);
@@ -1230,16 +1047,10 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_SHORT:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Short")));
+ code->instrNew("java/lang/Short");
code->instrDup();
code->loadLocalInteger(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Short")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(S)V")));
+ code->instrInvokespecial("java/lang/Short", "<init>", "(S)V");
stack = 3;
} else {
code->loadLocalInteger(*index);
@@ -1250,38 +1061,15 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_UNSIGNED_SHORT:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Any")));
+ code->instrNew("com/sun/star/uno/Any");
code->instrDup();
- code->instrGetstatic(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Type")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("UNSIGNED_SHORT")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Lcom/sun/star/uno/Type;")));
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Short")));
+ code->instrGetstatic("com/sun/star/uno/Type", "UNSIGNED_SHORT", "Lcom/sun/star/uno/Type;");
+ code->instrNew("java/lang/Short");
code->instrDup();
code->loadLocalInteger(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Short")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(S)V")));
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Any")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Lcom/sun/star/uno/Type;Ljava/lang/Object;)"
- "V")));
+ code->instrInvokespecial("java/lang/Short", "<init>", "(S)V");
+ code->instrInvokespecial("com/sun/star/uno/Any", "<init>",
+ "(Lcom/sun/star/uno/Type;Ljava/lang/Object;)V");
stack = 6;
} else {
code->loadLocalInteger(*index);
@@ -1292,16 +1080,10 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_LONG:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Integer")));
+ code->instrNew("java/lang/Integer");
code->instrDup();
code->loadLocalInteger(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Integer")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(I)V")));
+ code->instrInvokespecial("java/lang/Integer", "<init>", "(I)V");
stack = 3;
} else {
code->loadLocalInteger(*index);
@@ -1312,38 +1094,15 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_UNSIGNED_LONG:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Any")));
+ code->instrNew("com/sun/star/uno/Any");
code->instrDup();
- code->instrGetstatic(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Type")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("UNSIGNED_LONG")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Lcom/sun/star/uno/Type;")));
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Integer")));
+ code->instrGetstatic("com/sun/star/uno/Type", "UNSIGNED_LONG", "Lcom/sun/star/uno/Type;");
+ code->instrNew("java/lang/Integer");
code->instrDup();
code->loadLocalInteger(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Integer")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(I)V")));
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Any")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Lcom/sun/star/uno/Type;Ljava/lang/Object;)"
- "V")));
+ code->instrInvokespecial("java/lang/Integer", "<init>", "(I)V");
+ code->instrInvokespecial("com/sun/star/uno/Any", "<init>"
+ ,"(Lcom/sun/star/uno/Type;Ljava/lang/Object;)V");
stack = 6;
} else {
code->loadLocalInteger(*index);
@@ -1354,9 +1113,7 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_HYPER:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Long")));
+ code->instrNew("java/lang/Long");
code->instrDup();
code->loadLocalLong(*index);
code->instrInvokespecial(
@@ -1374,10 +1131,7 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_UNSIGNED_HYPER:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Any")));
+ code->instrNew("com/sun/star/uno/Any");
code->instrDup();
code->instrGetstatic(
rtl::OString(
@@ -1388,9 +1142,7 @@ sal_uInt16 addLoadLocal(
rtl::OString(
RTL_CONSTASCII_STRINGPARAM(
"Lcom/sun/star/uno/Type;")));
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Long")));
+ code->instrNew("java/lang/Long");
code->instrDup();
code->loadLocalLong(*index);
code->instrInvokespecial(
@@ -1416,16 +1168,10 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_FLOAT:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Float")));
+ code->instrNew("java/lang/Float");
code->instrDup();
code->loadLocalFloat(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Float")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(F)V")));
+ code->instrInvokespecial("java/lang/Float", "<init>", "(F)V");
stack = 3;
} else {
code->loadLocalFloat(*index);
@@ -1436,16 +1182,10 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_DOUBLE:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Double")));
+ code->instrNew("java/lang/Double");
code->instrDup();
code->loadLocalDouble(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Double")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("(D)V")));
+ code->instrInvokespecial("java/lang/Double", "<init>", "(D)V");
stack = 4;
} else {
code->loadLocalDouble(*index);
@@ -1456,9 +1196,7 @@ sal_uInt16 addLoadLocal(
case codemaker::UnoType::SORT_CHAR:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("java/lang/Character")));
+ code->instrNew("java/lang/Character");
code->instrDup();
code->loadLocalInteger(*index);
code->instrInvokespecial(
@@ -1492,15 +1230,9 @@ sal_uInt16 addLoadLocal(
case RT_TYPE_STRUCT:
if (any) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Any")));
+ code->instrNew("com/sun/star/uno/Any");
code->instrDup();
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Type")));
+ code->instrNew("com/sun/star/uno/Type");
code->instrDup();
code->loadStringConstant(
createUnoName(manager, nucleus, rank, args));
@@ -1516,25 +1248,11 @@ sal_uInt16 addLoadLocal(
rtl::OString(
RTL_CONSTASCII_STRINGPARAM(
"com/sun/star/uno/TypeClass")));
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Type")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;"
- "Lcom/sun/star/uno/TypeClass;)V")));
+ code->instrInvokespecial("com/sun/star/uno/Type", "<init>"
+ ,"(Ljava/lang/String;Lcom/sun/star/uno/TypeClass;)V");
code->loadLocalReference(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Any")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Lcom/sun/star/uno/Type;"
- "Ljava/lang/Object;)V")));
+ code->instrInvokespecial("com/sun/star/uno/Any", "<init>"
+ ,"(Lcom/sun/star/uno/Type;Ljava/lang/Object;)V");
stack = 6;
} else {
code->loadLocalReference(*index);
@@ -1544,55 +1262,21 @@ sal_uInt16 addLoadLocal(
break;
case RT_TYPE_INTERFACE:
- if (any
- && (nucleus
- != rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/XInterface"))))
+ if (any && nucleus != "com/sun/star/uno/XInterface")
{
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Any")));
+ code->instrNew("com/sun/star/uno/Any");
code->instrDup();
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Type")));
+ code->instrNew("com/sun/star/uno/Type");
code->instrDup();
code->loadStringConstant(nucleus.replace('/', '.'));
- code->instrGetstatic(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/TypeClass")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("INTERFACE")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "Lcom/sun/star/uno/TypeClass;")));
- dependencies->insert(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/TypeClass")));
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Type")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Ljava/lang/String;"
- "Lcom/sun/star/uno/TypeClass;)V")));
+ code->instrGetstatic("com/sun/star/uno/TypeClass", "INTERFACE"
+ , "Lcom/sun/star/uno/TypeClass;");
+ dependencies->insert("com/sun/star/uno/TypeClass");
+ code->instrInvokespecial("com/sun/star/uno/Type", "<init>"
+ ,"(Ljava/lang/String;Lcom/sun/star/uno/TypeClass;)V");
code->loadLocalReference(*index);
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/Any")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "(Lcom/sun/star/uno/Type;"
- "Ljava/lang/Object;)V")));
+ code->instrInvokespecial("com/sun/star/uno/Any", "<init>"
+ ,"(Lcom/sun/star/uno/Type;Ljava/lang/Object;)V");
stack = 6;
} else {
code->loadLocalReference(*index);
@@ -1661,22 +1345,13 @@ sal_uInt16 addLoadLocal(
}
}
if (wrap) {
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Any")));
+ code->instrNew("com/sun/star/uno/Any");
code->instrDup();
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")));
+ code->instrNew("com/sun/star/uno/Type");
code->instrDup();
code->loadStringConstant(
createUnoName(manager, nucleus, rank, args));
- code->instrInvokespecial(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("(Ljava/lang/String;)V")));
+ code->instrInvokespecial("com/sun/star/uno/Type", "<init>", "(Ljava/lang/String;)V");
code->loadLocalReference(*index);
code->instrInvokespecial(
rtl::OString(
@@ -1937,9 +1612,7 @@ void handleAggregatingType(
std::auto_ptr< ClassFile::Code > code(cf->newCode());
SAL_WNODEPRECATED_DECLARATIONS_POP
code->loadLocalReference(0);
- code->instrInvokespecial(
- superClass, rtl::OString(RTL_CONSTASCII_STRINGPARAM("<init>")),
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("()V")));
+ code->instrInvokespecial(superClass, "<init>", "()V");
sal_uInt16 stack = 0;
for (sal_uInt16 i = firstField; i < fields; ++i) {
stack = std::max(
@@ -2736,10 +2409,7 @@ void addConstructor(
localIndex = std::max< sal_uInt16 >(localIndex, 2);
code->storeLocalReference(1);
// stack: -
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/DeploymentException")));
+ code->instrNew("com/sun/star/uno/DeploymentException");
// stack: ex
code->instrDup();
// stack: ex ex
@@ -2869,9 +2539,7 @@ void handleService(
SAL_WNODEPRECATED_DECLARATIONS_PUSH
std::auto_ptr< ClassFile::Code > code(cf->newCode());
SAL_WNODEPRECATED_DECLARATIONS_POP
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")));
+ code->instrNew("com/sun/star/uno/Type");
// stack: type
code->instrDup();
// stack: type type
@@ -2912,10 +2580,7 @@ void handleService(
code->branchHere(branch);
code->instrPop();
// stack: -
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/DeploymentException")));
+ code->instrNew("com/sun/star/uno/DeploymentException");
// stack: ex
code->instrDup();
// stack: ex ex
@@ -3060,8 +2725,7 @@ void handleSingleton(
rtl::OString(RTL_CONSTASCII_STRINGPARAM("()Ljava/lang/Object;")));
// stack: value
code->branchHere(branch1);
- code->instrNew(
- rtl::OString(RTL_CONSTASCII_STRINGPARAM("com/sun/star/uno/Type")));
+ code->instrNew("com/sun/star/uno/Type");
// stack: value type
code->instrDup();
// stack: value type type
@@ -3101,10 +2765,7 @@ void handleSingleton(
code->branchHere(branch3);
code->instrPop();
// stack: -
- code->instrNew(
- rtl::OString(
- RTL_CONSTASCII_STRINGPARAM(
- "com/sun/star/uno/DeploymentException")));
+ code->instrNew("com/sun/star/uno/DeploymentException");
// stack: ex
code->instrDup();
// stack: ex ex