Merge change 509 into donut

* changes:
  Fix a media server crash (bug 1807910): part one Add a factory method that creates a Camera object from a remote client
This commit is contained in:
Android (Google) Code Review
2009-04-23 15:58:38 -07:00
2 changed files with 15 additions and 2 deletions

View File

@@ -78,8 +78,8 @@ class Camera : public BnCameraClient, public IBinder::DeathRecipient
{
public:
// construct a camera client from an existing remote
Camera(const sp<ICamera>& camera);
Camera(const sp<ICamera>& camera); // to be removed
static sp<Camera> create(const sp<ICamera>& camera);
static sp<Camera> connect();
~Camera();
void init();

View File

@@ -75,6 +75,19 @@ Camera::Camera(const sp<ICamera>& camera)
}
}
sp<Camera> Camera::create(const sp<ICamera>& camera)
{
sp<Camera> c = new Camera();
// connect this client to existing camera remote
if (camera->connect(c) == NO_ERROR) {
c->mStatus = NO_ERROR;
c->mCamera = camera;
camera->asBinder()->linkToDeath(c);
}
return c;
}
void Camera::init()
{
mStatus = UNKNOWN_ERROR;