📄 stdevs.cpp
字号:
// otherwise, you need to read the file system object and figure out the list of object ID's that
// have changed.
if ( pNotify->uFlags & ONF_DELETED )
{
// object has been deleted
pNotify->cOidDel = 1;
}
else if ( ( rgProps[ uixFlags ].val.uiVal & v_uPartnerBit ) != 0 )
{
// object has been deleted
pNotify->cOidChg = 1;
if ( rgProps[ uixFlags ].val.uiVal & SF_CHG_IN_SYNC )
{
rgProps[ uixFlags ].val.uiVal &= ~SF_CHG_IN_SYNC;
fSave = TRUE;
}
}
fRet = TRUE;
Exit:
if ( fSave && CeSeekDatabase( hDatabase, CEDB_SEEK_CEOID, pNotify->oidObject, &dwIndex ) == pNotify->oidObject )
CeWriteRecordProps( hDatabase, pNotify->oidObject, cProps, rgProps );
if ( hDatabase != INVALID_HANDLE_VALUE )
CloseHandle( hDatabase );
if ( rgProps )
LocalFree( rgProps );
return fRet;
}
/*++
EXTERN_C BOOL SyncData
Allow desktop to send/receive data
--*/
EXTERN_C BOOL SyncData( PSDREQUEST psd )
{
// do we need to read or write data?
if ( psd->fSet )
{
}
else
{
switch( psd->uCode )
{
case 1:
// set the size of the database volume name we are about to return
psd->cbData = ( wcslen( v_szDBVol ) + 1 ) * sizeof( WCHAR );
// Note: ActiveSync manage will call this routine twice, first with lpbData set to NULL
// after cbData is returned, ActiveSync manager allocates the memory and call this routine again
if ( psd->lpbData )
wcscpy( (LPTSTR)psd->lpbData, v_szDBVol );
break;
}
}
return TRUE;
}
/*++
EXTERN_C BOOL GetObjTypeInfo
Return object type related information in the given structure
--*/
EXTERN_C BOOL GetObjTypeInfo( POBJTYPEINFO pInfo )
{
if ( pInfo->cbStruct != sizeof( OBJTYPEINFO ) )
return FALSE;
CEOIDINFO oidInfo;
if ( !Open( NULL, &v_oidDb ) )
return FALSE;
ClearStruct( oidInfo );
CeOidGetInfoEx( &v_guid, v_oidDb, &oidInfo );
wcscpy( pInfo->szName, oidInfo.infDatabase.szDbaseName );
pInfo->cObjects = oidInfo.infDatabase.wNumRecords;
pInfo->cbAllObj = oidInfo.infDatabase.dwSize;
pInfo->ftLastModified = oidInfo.infDatabase.ftLastModified;
return TRUE;
}
/*++
--*/
EXTERN_C BOOL ReportStatus( LPWSTR lpszObjType, UINT uCode, UINT uParam )
{
HWND hwnd;
switch( uCode )
{
case RSC_BEGIN_SYNC:
break;
case RSC_END_SYNC:
// post a message to the Stock Portfolio app so it will refresh the display
hwnd = FindWindow( SZ_WND_CLASS, NULL );
if ( hwnd )
PostMessage( hwnd, WM_DATA_CHANGED, 0, 0 );
break;
}
return TRUE;
}
//
// =*=*================== Data Handler ===================================
//
CDataHandler::CDataHandler()
{
m_cRef = 1;
}
CDataHandler::~CDataHandler()
{
}
/*++
--*/
STDMETHODIMP_(ULONG) CDataHandler::AddRef()
{
ULONG urc;
urc = (ULONG)InterlockedIncrement( &m_cRef );
return(urc);
}
/*++
--*/
STDMETHODIMP_(ULONG) CDataHandler::Release()
{
ULONG urc;
urc = (ULONG)InterlockedDecrement( &m_cRef );
if (urc == 0 )
delete this;
return urc;
}
/*++
--*/
STDMETHODIMP CDataHandler::QueryInterface( REFIID iid, LPVOID *ppvObj )
{
*ppvObj = NULL;
return E_NOINTERFACE;
}
/*++
--*/
STDMETHODIMP CDataHandler::Reset( PREPLSETUP pSetup )
{
// we don't have resources to clean up
return NOERROR;
}
/*++
--*/
STDMETHODIMP CDataHandler::Setup( PREPLSETUP pSetup )
{
// we could be reading and writing at the same time, so need to save the pointer to setup struct differently
if ( pSetup->fRead )
m_pReadSetup = pSetup;
else
m_pWriteSetup = pSetup;
return NOERROR;
}
/*++
--*/
STDMETHODIMP CDataHandler::DeleteObj( PREPLSETUP pSetup )
{
DWORD dwIndex;
HANDLE hDatabase;
if ( !Open( &hDatabase ) )
return E_UNEXPECTED;
if ( CeSeekDatabase( hDatabase, CEDB_SEEK_CEOID, pSetup->oid, &dwIndex ) == pSetup->oid )
{
CeDeleteRecord( hDatabase, pSetup->oid );
CloseHandle( hDatabase );
return NOERROR;
}
CloseHandle( hDatabase );
return HRESULT_FROM_WIN32( ERROR_FILE_NOT_FOUND );
}
/*++
--*/
STDMETHODIMP CDataHandler::GetPacket( LPBYTE *lppbPacket, DWORD *pcbPacket, DWORD cbRecommend )
{
DWORD dwIndex;
CEPROPVAL *rgProps = NULL, *pProp;
DWORD cbProps;
WORD cProps;
UINT ix;
HRESULT hr = RWRN_LAST_PACKET;
HANDLE hDatabase = INVALID_HANDLE_VALUE;
if ( !Open( &hDatabase ) )
{
hr = E_FAIL;
goto Exit;
}
if ( CeSeekDatabase( hDatabase, CEDB_SEEK_CEOID, m_pReadSetup->oid, &dwIndex ) != m_pReadSetup->oid ||
CeReadRecordProps( hDatabase, CEDB_ALLOWREALLOC, &cProps, NULL, (LPBYTE *)&rgProps, &cbProps ) != m_pReadSetup->oid )
{
hr = HRESULT_FROM_WIN32( ERROR_FILE_NOT_FOUND );
goto Exit;
}
ClearStruct( m_packet );
for ( ix = 0, pProp = rgProps; ix < cProps; ix++, pProp++ )
{
switch( pProp->propid )
{
case HHPR_SYMBOL: wcscpy( m_packet.wszSym, pProp->val.lpwstr ); break;
case HHPR_COMPANY: wcscpy( m_packet.wszCompany, pProp->val.lpwstr ); break;
case HHPR_PRICE: wcscpy( m_packet.wszLastPrice, pProp->val.lpwstr ); break;
case HHPR_PUR_DATE: wcscpy( m_packet.wszPurDate, pProp->val.lpwstr ); break;
case HHPR_PUR_PRICE: wcscpy( m_packet.wszPurPrice, pProp->val.lpwstr ); break;
case HHPR_GAIN_LOSS: wcscpy( m_packet.wszGain, pProp->val.lpwstr ); break;
case HHPR_UP_TIME: m_packet.ftUpdated = pProp->val.filetime; break;
}
}
Exit:
if ( rgProps )
LocalFree( rgProps );
if ( hDatabase != INVALID_HANDLE_VALUE )
CloseHandle( hDatabase );
*pcbPacket = sizeof( m_packet );
*lppbPacket = (LPBYTE)&m_packet;
return hr;
}
/*++
--*/
STDMETHODIMP CDataHandler::SetPacket( LPBYTE lpbPacket, DWORD cbPacket )
{
CEPROPVAL rgProps[8];
CEOID oid;
HANDLE hDatabase = INVALID_HANDLE_VALUE;
HRESULT hr = NOERROR;
PSTPACKET pPacket = (PSTPACKET)lpbPacket;
memset( rgProps, 0, sizeof( rgProps ) );
// write the packet
if ( cbPacket != sizeof( STPACKET ) )
{
hr = E_UNEXPECTED;
goto Exit;
}
if ( !Open( &hDatabase ) )
{
hr = E_FAIL;
goto Exit;
}
// must return the DB GUID as the volume ID
if ( !CHECK_SYSTEMGUID( &v_guid ) )
{
m_pWriteSetup->cbVolumeID = sizeof( CEGUID );
m_pWriteSetup->lpbVolumeID = (LPBYTE)&v_guid;
}
rgProps[0].propid = HHPR_SYMBOL;
rgProps[0].val.lpwstr = pPacket->wszSym;
rgProps[1].propid = HHPR_COMPANY;
rgProps[1].val.lpwstr = pPacket->wszCompany;
rgProps[2].propid = HHPR_PRICE;
rgProps[2].val.lpwstr = pPacket->wszLastPrice;
rgProps[3].propid = HHPR_PUR_DATE;
rgProps[3].val.lpwstr = pPacket->wszPurDate;
rgProps[4].propid = HHPR_PUR_PRICE;
rgProps[4].val.lpwstr = pPacket->wszPurPrice;
rgProps[5].propid = HHPR_GAIN_LOSS;
rgProps[5].val.lpwstr = pPacket->wszGain;
rgProps[6].propid = HHPR_UP_TIME;
rgProps[6].val.filetime = pPacket->ftUpdated;
rgProps[7].propid = HHPR_FLAGS;
rgProps[7].val.uiVal = SF_UPDATE_VIEW | ( ( SF_CHANGED1 | SF_CHANGED2 ) & ~v_uPartnerBit );
// create a new stock record or overwriting the existing record
if ( m_pWriteSetup->dwFlags & RSF_NEW_OBJECT )
oid = m_pWriteSetup->oidNew = CeWriteRecordProps( hDatabase, 0, Dim( rgProps ), rgProps );
else
oid = CeWriteRecordProps( hDatabase, m_pWriteSetup->oidNew, Dim( rgProps ), rgProps );
if ( !oid )
{
// most likely because we're out of memory
hr = E_OUTOFMEMORY;
goto Exit;
}
Exit:
if ( hDatabase != INVALID_HANDLE_VALUE )
CloseHandle( hDatabase );
return hr;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -