Initial commit: Complete open-source Decal rebuild
All 5 phases of the open-source Decal rebuild: Phase 1: 14 decompiled .NET projects (Interop.*, Adapter, FileService, DecalUtil) Phase 2: 10 native DLLs rewritten as C# COM servers with matching GUIDs - DecalDat, DHS, SpellFilter, DecalInput, DecalNet, DecalFilters - Decal.Core, DecalControls, DecalRender, D3DService Phase 3: C++ shims for Inject.DLL (D3D9 hooking) and LauncherHook.DLL Phase 4: DenAgent WinForms tray application Phase 5: WiX installer and build script 25 C# projects building with 0 errors. Native C++ projects require VS 2022 + Windows SDK (x86). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
commit
d1442e3747
1382 changed files with 170725 additions and 0 deletions
96
Native/DecalInput/Timer.cpp
Normal file
96
Native/DecalInput/Timer.cpp
Normal file
|
|
@ -0,0 +1,96 @@
|
|||
// Timer.cpp : Implementation of cTimer
|
||||
#include "stdafx.h"
|
||||
#include "DecalInput.h"
|
||||
#include "Timer.h"
|
||||
|
||||
#include "InputService.h"
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// cTimer
|
||||
|
||||
STDMETHODIMP cTimer::Start(long Interval)
|
||||
{
|
||||
if( cInputService::g_p == NULL )
|
||||
{
|
||||
_ASSERT( FALSE );
|
||||
return E_FAIL;
|
||||
}
|
||||
|
||||
if( Interval <= 0 )
|
||||
{
|
||||
_ASSERT( FALSE );
|
||||
return E_INVALIDARG;
|
||||
}
|
||||
|
||||
if( m_bStarted )
|
||||
Stop();
|
||||
|
||||
m_nStart = static_cast< long >( ::timeGetTime() );
|
||||
m_nInterval = Interval;
|
||||
|
||||
static_cast< IDispatch * >( cInputService::g_p )->AddRef();
|
||||
cInputService::g_p->m_timers.push_back( this );
|
||||
|
||||
m_bStarted = true;
|
||||
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
STDMETHODIMP cTimer::Stop()
|
||||
{
|
||||
if( cInputService::g_p == NULL )
|
||||
{
|
||||
_ASSERT( FALSE );
|
||||
return E_FAIL;
|
||||
}
|
||||
|
||||
if( !m_bStarted )
|
||||
return S_FALSE;
|
||||
|
||||
m_bStarted = false;
|
||||
|
||||
// Remove from the input service
|
||||
for( cInputService::cTimerList::iterator i = cInputService::g_p->m_timers.begin(); i != cInputService::g_p->m_timers.end(); ++ i )
|
||||
{
|
||||
if( *i == this )
|
||||
{
|
||||
cInputService::g_p->m_timers.erase( i );
|
||||
static_cast< IDispatch * >( cInputService::g_p )->Release();
|
||||
return S_OK;
|
||||
}
|
||||
}
|
||||
|
||||
_ASSERT( FALSE );
|
||||
return E_FAIL;
|
||||
}
|
||||
|
||||
STDMETHODIMP cTimer::get_Tag(VARIANT *pVal)
|
||||
{
|
||||
if( pVal == NULL )
|
||||
{
|
||||
_ASSERT( FALSE );
|
||||
return E_POINTER;
|
||||
}
|
||||
|
||||
return ::VariantCopy( pVal, &m_tag );
|
||||
}
|
||||
|
||||
STDMETHODIMP cTimer::put_Tag(VARIANT newVal)
|
||||
{
|
||||
m_tag = newVal;
|
||||
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
STDMETHODIMP cTimer::get_Running(VARIANT_BOOL *pVal)
|
||||
{
|
||||
if( pVal == NULL )
|
||||
{
|
||||
_ASSERT( FALSE );
|
||||
return E_POINTER;
|
||||
}
|
||||
|
||||
*pVal = ( m_bStarted ) ? VARIANT_TRUE : VARIANT_FALSE;
|
||||
|
||||
return S_OK;
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue