Merge commit '79558e7e34580406527e20ed25bf65e6ce0bae54'

This commit is contained in:
Josh warner 2009-06-05 15:55:14 -06:00
commit 6c669b96bb
3 changed files with 9 additions and 7 deletions

View File

@ -417,8 +417,8 @@ architecture-specific parameters.
Step 8: Write a driver which starts the VM and runs the desired main Step 8: Write a driver which starts the VM and runs the desired main
method. Note the bootimageBin function, which will be called by the method. Note the bootimageBin function, which will be called by the
VM to get a handle to the embedded jar. We tell the VM about this VM to get a handle to the embedded boot image. We tell the VM about
function via the "avian.bootimage" property. this function via the "avian.bootimage" property.
Note also that this example includes no resources besides class files. Note also that this example includes no resources besides class files.
If our application loaded resources such as images and properties If our application loaded resources such as images and properties

View File

@ -44,6 +44,12 @@ class Stream {
void read(uint8_t* data, unsigned size) { void read(uint8_t* data, unsigned size) {
if (size > this->size - position_) { if (size > this->size - position_) {
// GCC 4.4 will give us an uninitialized value warning in read1
// unless we do this: (it's smart enough to track data flow
// across functions but not smart enough to see we won't return
// from Client::handleError)
*data = 0;
client->handleError(); client->handleError();
} else { } else {
memcpy(data, this->data + position_, size); memcpy(data, this->data + position_, size);

View File

@ -1560,11 +1560,7 @@ writeAccessor(Output* out, Object* member, Object* offset, bool unsafe = false)
} }
} }
if (memberOwner(member)->type == Object::Pod) {
out->write(">(o->body");
} else {
out->write(">(reinterpret_cast<uint8_t*>(o)"); out->write(">(reinterpret_cast<uint8_t*>(o)");
}
if (endsWith("[0]", typeName) if (endsWith("[0]", typeName)
or (member->type != Object::Scalar or (member->type != Object::Scalar
and memberTypeObject(member))) and memberTypeObject(member)))