/*
 * Copyright (C) Texas Instruments - http://www.ti.com/
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/**
* @file CameraProperties.cpp
*
* This file maps the CameraHardwareInterface to the Camera interfaces on OMAP4 (mainly OMX).
*
*/

#include "CameraProperties.h"

#define CAMERA_ROOT         "CameraRoot"
#define CAMERA_INSTANCE     "CameraInstance"

namespace Ti {
namespace Camera {

// lower entries have higher priority
static const char* g_camera_adapters[] = {
#ifdef OMAP4_SUPPORT_OMX_CAMERA_ADAPTER
    "libomxcameraadapter.so",
#endif
#ifdef OMAP4_SUPPORT_USB_CAMERA_ADAPTER
    "libusbcameraadapter.so"
#endif
};

/*********************************************************
 CameraProperties - public function implemetation
**********************************************************/

CameraProperties::CameraProperties() : mCamerasSupported(0)
{
    LOG_FUNCTION_NAME;

    mCamerasSupported = 0;
    mInitialized = 0;

    LOG_FUNCTION_NAME_EXIT;
}

CameraProperties::~CameraProperties()
{
    LOG_FUNCTION_NAME;

    LOG_FUNCTION_NAME_EXIT;
}


// Initializes the CameraProperties class
status_t CameraProperties::initialize()
{
    LOG_FUNCTION_NAME;

    status_t ret;

    android::AutoMutex lock(mLock);

    if(mInitialized)
        return NO_ERROR;

    ret = loadProperties();

    if (ret == NO_ERROR) {
        mInitialized = 1;
    }

    LOG_FUNCTION_NAME_EXIT;

    return ret;
}

extern "C" status_t CameraAdapter_Capabilities(CameraProperties::Properties* properties_array,
        int starting_camera, int max_camera, int & supported_cameras);

///Loads all the Camera related properties
status_t CameraProperties::loadProperties()
{
    LOG_FUNCTION_NAME;

    status_t ret = NO_ERROR;

    //Must be re-initialized here, since loadProperties() could potentially be called more than once.
    mCamerasSupported = 0;

    // adapter updates capabilities and we update camera count
    const status_t err = CameraAdapter_Capabilities(mCameraProps, mCamerasSupported,
            MAX_CAMERAS_SUPPORTED, mCamerasSupported);

    if(err != NO_ERROR) {
        CAMHAL_LOGE("error while getting capabilities");
        ret = UNKNOWN_ERROR;
    } else if (mCamerasSupported == 0) {
        CAMHAL_LOGE("camera busy. properties not loaded. num_cameras = %d", mCamerasSupported);
        ret = UNKNOWN_ERROR;
    } else if (mCamerasSupported > MAX_CAMERAS_SUPPORTED) {
        CAMHAL_LOGE("returned too many adapaters");
        ret = UNKNOWN_ERROR;
    } else {
        CAMHAL_LOGI("num_cameras = %d", mCamerasSupported);

        for (int i = 0; i < mCamerasSupported; i++) {
            mCameraProps[i].setSensorIndex(i);
            mCameraProps[i].dump();
        }
    }

    CAMHAL_LOGV("mCamerasSupported = %d", mCamerasSupported);
    LOG_FUNCTION_NAME_EXIT;
    return ret;
}

// Returns the number of Cameras found
int CameraProperties::camerasSupported()
{
    LOG_FUNCTION_NAME;
    return mCamerasSupported;
}

} // namespace Camera
} // namespace Ti