summaryrefslogtreecommitdiff
path: root/cpp/src/Slice/JavaUtil.cpp
diff options
context:
space:
mode:
authorMark Spruiell <mes@zeroc.com>2002-11-08 23:45:57 +0000
committerMark Spruiell <mes@zeroc.com>2002-11-08 23:45:57 +0000
commit4d37952bb042167d4ea13445682656a948a10d8a (patch)
treeb764f03cd883457472657d96a5f2db3c7c07e7a9 /cpp/src/Slice/JavaUtil.cpp
parentdocu fixes (diff)
downloadice-4d37952bb042167d4ea13445682656a948a10d8a.tar.bz2
ice-4d37952bb042167d4ea13445682656a948a10d8a.tar.xz
ice-4d37952bb042167d4ea13445682656a948a10d8a.zip
accept null as a sequence argument
Diffstat (limited to 'cpp/src/Slice/JavaUtil.cpp')
-rw-r--r--cpp/src/Slice/JavaUtil.cpp30
1 files changed, 30 insertions, 0 deletions
diff --git a/cpp/src/Slice/JavaUtil.cpp b/cpp/src/Slice/JavaUtil.cpp
index 8bd3fc4d03e..46acfc94811 100644
--- a/cpp/src/Slice/JavaUtil.cpp
+++ b/cpp/src/Slice/JavaUtil.cpp
@@ -773,6 +773,12 @@ Slice::JavaGenerator::writeSequenceMarshalUnmarshalCode(Output& out,
{
if(marshal)
{
+ out << nl << "if(" << v << " == null)";
+ out << sb;
+ out << nl << stream << ".writeSize(0);";
+ out << eb;
+ out << nl << "else";
+ out << sb;
out << nl << stream << ".writeSize(" << v << ".size());";
ostringstream o;
o << "__i" << iter;
@@ -841,6 +847,7 @@ Slice::JavaGenerator::writeSequenceMarshalUnmarshalCode(Output& out,
}
}
out << eb; // while
+ out << eb;
}
else
{
@@ -1101,6 +1108,12 @@ Slice::JavaGenerator::writeSequenceMarshalUnmarshalCode(Output& out,
{
if(marshal)
{
+ out << nl << "if(" << v << " == null)";
+ out << sb;
+ out << nl << stream << ".writeSize(0);";
+ out << eb;
+ out << nl << "else";
+ out << sb;
out << nl << stream << ".writeSize(" << v << ".length);";
out << nl << "for(int __i" << iter << " = 0; __i" << iter << " < " << v << ".length; __i" << iter
<< "++)";
@@ -1110,6 +1123,7 @@ Slice::JavaGenerator::writeSequenceMarshalUnmarshalCode(Output& out,
iter++;
writeMarshalUnmarshalCode(out, scope, seq->type(), o.str(), true, iter, false);
out << eb;
+ out << eb;
}
else
{
@@ -1472,6 +1486,13 @@ Slice::JavaGenerator::writeGenericSequenceMarshalUnmarshalCode(Output& out,
{
if(marshal)
{
+ out << nl << "if(" << v << " == null)";
+ out << sb;
+ out << nl << stream << ".startWriteSequence(" << name << ", 0);";
+ out << nl << stream << ".endWriteSequence();";
+ out << eb;
+ out << nl << "else";
+ out << sb;
out << nl << stream << ".startWriteSequence(" << name << ", " << v << ".size());";
ostringstream o;
o << "__i" << iter;
@@ -1541,6 +1562,7 @@ Slice::JavaGenerator::writeGenericSequenceMarshalUnmarshalCode(Output& out,
}
out << eb; // while
out << nl << stream << ".endWriteSequence();";
+ out << eb;
}
else
{
@@ -1806,6 +1828,13 @@ Slice::JavaGenerator::writeGenericSequenceMarshalUnmarshalCode(Output& out,
string typeS = getAbsolute(seq->scoped(), scope);
if(marshal)
{
+ out << nl << "if(" << v << " == null)";
+ out << sb;
+ out << nl << stream << ".startWriteSequence(" << name << ", 0);";
+ out << nl << stream << ".endWriteSequence();";
+ out << eb;
+ out << nl << "else";
+ out << sb;
out << nl << stream << ".startWriteSequence(" << name << ", " << v << ".length);";
out << nl << "for(int __i" << iter << " = 0; __i" << iter << " < " << v << ".length; __i" << iter
<< "++)";
@@ -1816,6 +1845,7 @@ Slice::JavaGenerator::writeGenericSequenceMarshalUnmarshalCode(Output& out,
writeGenericMarshalUnmarshalCode(out, scope, seq->type(), "\"e\"", o.str(), true, iter, false);
out << eb;
out << nl << stream << ".endWriteSequence();";
+ out << eb;
}
else
{