亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? asyncio.cpp

?? VC源碼:《DirectShow開發指南》范例源代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//------------------------------------------------------------------------------
// File: AsyncIo.cpp
//
// Desc: DirectShow sample code - base library with I/O functionality.
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//------------------------------------------------------------------------------


#include <streams.h>
#include "asyncio.h"

// --- CAsyncRequest ---


// implementation of CAsyncRequest representing a single
// outstanding request. All the i/o for this object is done
// in the Complete method.


// init the params for this request.
// Read is not issued until the complete call
HRESULT
CAsyncRequest::Request(
    CAsyncIo *pIo,
    CAsyncStream *pStream,
    LONGLONG llPos,
    LONG lLength,
    BOOL bAligned,
    BYTE* pBuffer,
    LPVOID pContext,    // filter's context
    DWORD dwUser)   // downstream filter's context
{
    m_pIo = pIo;
    m_pStream = pStream;
    m_llPos = llPos;
    m_lLength = lLength;
    m_bAligned = bAligned;
    m_pBuffer = pBuffer;
    m_pContext = pContext;
    m_dwUser = dwUser;
    m_hr = VFW_E_TIMEOUT;   // not done yet

    return S_OK;
}


// issue the i/o if not overlapped, and block until i/o complete.
// returns error code of file i/o
//
//
HRESULT
CAsyncRequest::Complete()
{
    m_pStream->Lock();

    m_hr = m_pStream->SetPointer(m_llPos);
    if(S_OK == m_hr)
    {
        DWORD dwActual;

        m_hr = m_pStream->Read(m_pBuffer, m_lLength, m_bAligned, &dwActual);
        if(m_hr == OLE_S_FIRST)
        {
            if(m_pContext)
            {
                IMediaSample *pSample = reinterpret_cast<IMediaSample *>(m_pContext);
                pSample->SetDiscontinuity(TRUE);
                m_hr = S_OK;
            }
        }

        if(FAILED(m_hr))
        {
        }
        else if(dwActual != (DWORD)m_lLength)
        {
            // tell caller size changed - probably because of EOF
            m_lLength = (LONG) dwActual;
            m_hr = S_FALSE;
        }
        else
        {
            m_hr = S_OK;
        }
    }

    m_pStream->Unlock();
    return m_hr;
}


// --- CAsyncIo ---

// note - all events created manual reset

CAsyncIo::CAsyncIo(CAsyncStream *pStream)
         : m_hThread(NULL),
           m_evWork(TRUE),
           m_evDone(TRUE),
           m_evStop(TRUE),
           m_listWork(NAME("Work list")),
           m_listDone(NAME("Done list")),
           m_bFlushing(FALSE),
           m_cItemsOut(0),
           m_bWaiting(FALSE),
           m_pStream(pStream)
{

}


CAsyncIo::~CAsyncIo()
{
    // move everything to the done list
    BeginFlush();

    // shutdown worker thread
    CloseThread();

    // empty the done list
    POSITION pos = m_listDone.GetHeadPosition();
    while(pos)
    {
        CAsyncRequest* pRequest = m_listDone.GetNext(pos);
        delete pRequest;
    }

    m_listDone.RemoveAll();
}


// ready for async activity - call this before calling Request.
//
// start the worker thread if we need to
//
// !!! use overlapped i/o if possible
HRESULT
CAsyncIo::AsyncActive(void)
{
    return StartThread();
}

// call this when no more async activity will happen before
// the next AsyncActive call
//
// stop the worker thread if active
HRESULT
CAsyncIo::AsyncInactive(void)
{
    return CloseThread();
}


// add a request to the queue.
HRESULT
CAsyncIo::Request(
                LONGLONG llPos,
                LONG lLength,
                BOOL bAligned,
                BYTE * pBuffer,
                LPVOID pContext,
                DWORD dwUser)
{
    if(bAligned)
    {
        if(!IsAligned(llPos) ||
            !IsAligned(lLength) ||
            !IsAligned((LONG) pBuffer))
        {
            return VFW_E_BADALIGN;
        }
    }

    CAsyncRequest* pRequest = new CAsyncRequest;
    if (!pRequest)
        return E_OUTOFMEMORY;

    HRESULT hr = pRequest->Request(this,
                                   m_pStream,
                                   llPos,
                                   lLength,
                                   bAligned,
                                   pBuffer,
                                   pContext,
                                   dwUser);
    if(SUCCEEDED(hr))
    {
        // might fail if flushing
        hr = PutWorkItem(pRequest);
    }

    if(FAILED(hr))
    {
        delete pRequest;
    }

    return hr;
}


// wait for the next request to complete
HRESULT
CAsyncIo::WaitForNext(
    DWORD dwTimeout,
    LPVOID * ppContext,
    DWORD  * pdwUser,
    LONG   * pcbActual)
{
    CheckPointer(ppContext,E_POINTER);
    CheckPointer(pdwUser,E_POINTER);
    CheckPointer(pcbActual,E_POINTER);

    // some errors find a sample, others don't. Ensure that
    // *ppContext is NULL if no sample found
    *ppContext = NULL;

    // wait until the event is set, but since we are not
    // holding the critsec when waiting, we may need to re-wait
    for(;;)
    {
        if(!m_evDone.Wait(dwTimeout))
        {
            // timeout occurred
            return VFW_E_TIMEOUT;
        }

        // get next event from list
        CAsyncRequest* pRequest = GetDoneItem();
        if(pRequest)
        {
            // found a completed request

            // check if ok
            HRESULT hr = pRequest->GetHResult();
            if(hr == S_FALSE)
            {
                // this means the actual length was less than
                // requested - may be ok if he aligned the end of file
                if((pRequest->GetActualLength() +
                    pRequest->GetStart()) == Size())
                {
                    hr = S_OK;
                }
                else
                {
                    // it was an actual read error
                    hr = E_FAIL;
                }
            }

            // return actual bytes read
            *pcbActual = pRequest->GetActualLength();

            // return his context
            *ppContext = pRequest->GetContext();
            *pdwUser = pRequest->GetUser();

            delete pRequest;
            return hr;
        }
        else
        {
            //  Hold the critical section while checking the list state
            CAutoLock lck(&m_csLists);
            if(m_bFlushing && !m_bWaiting)
            {
                // can't block as we are between BeginFlush and EndFlush

                // but note that if m_bWaiting is set, then there are some
                // items not yet complete that we should block for.

                return VFW_E_WRONG_STATE;
            }
        }

        // done item was grabbed between completion and
        // us locking m_csLists.
    }
}


// perform a synchronous read request on this thread.
// Need to hold m_csFile while doing this (done in request object)
HRESULT
CAsyncIo::SyncReadAligned(
                        LONGLONG llPos,
                        LONG lLength,
                        BYTE * pBuffer,
                        LONG * pcbActual,
                        PVOID pvContext)
{
    CheckPointer(pcbActual,E_POINTER);

    if(!IsAligned(llPos) ||
        !IsAligned(lLength) ||
        !IsAligned((LONG) pBuffer))
    {
        return VFW_E_BADALIGN;
    }

    CAsyncRequest request;

    HRESULT hr = request.Request(this,
                                m_pStream,
                                llPos,
                                lLength,
                                TRUE,
                                pBuffer,
                                pvContext,
                                0);
    if(FAILED(hr))
        return hr;

    hr = request.Complete();

    // return actual data length
    *pcbActual = request.GetActualLength();
    return hr;
}


HRESULT
CAsyncIo::Length(LONGLONG *pllTotal, LONGLONG *pllAvailable)
{
    CheckPointer(pllTotal,E_POINTER);

    *pllTotal = m_pStream->Size(pllAvailable);
    return S_OK;
}


// cancel all items on the worklist onto the done list
// and refuse further requests or further WaitForNext calls
// until the end flush
//
// WaitForNext must return with NULL only if there are no successful requests.
// So Flush does the following:
// 1. set m_bFlushing ensures no more requests succeed
// 2. move all items from work list to the done list.
// 3. If there are any outstanding requests, then we need to release the
//    critsec to allow them to complete. The m_bWaiting as well as ensuring
//    that we are signalled when they are all done is also used to indicate
//    to WaitForNext that it should continue to block.
// 4. Once all outstanding requests are complete, we force m_evDone set and
//    m_bFlushing set and m_bWaiting false. This ensures that WaitForNext will
//    not block when the done list is empty.
HRESULT
CAsyncIo::BeginFlush()
{
    // hold the lock while emptying the work list
    {
        CAutoLock lock(&m_csLists);

        // prevent further requests being queued.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品免费在线| 亚洲一区二区欧美激情| 宅男噜噜噜66一区二区66| 日韩一级大片在线| 欧美va日韩va| 亚洲免费电影在线| 日本免费在线视频不卡一不卡二| 国产精品亚洲午夜一区二区三区| 暴力调教一区二区三区| 在线电影一区二区三区| 91超碰这里只有精品国产| 久久精品人人做人人爽97| 亚洲成人在线免费| 成人app在线| 欧美亚洲精品一区| 精品电影一区二区三区| 亚洲女同一区二区| 国产一区二区三区观看| 欧美日韩一区二区三区视频| 国产精品亲子乱子伦xxxx裸| 天堂成人国产精品一区| av网站一区二区三区| 欧美日精品一区视频| 中文子幕无线码一区tr| 日韩成人伦理电影在线观看| av中文字幕亚洲| 久久午夜色播影院免费高清| 午夜精品福利一区二区三区av | 欧美色图激情小说| 欧美一级日韩不卡播放免费| 亚洲制服欧美中文字幕中文字幕| 成人动漫视频在线| 日韩一卡二卡三卡四卡| 一区二区激情视频| a在线播放不卡| 国产精品久久久久久久久搜平片| 久久成人精品无人区| 欧美精品v国产精品v日韩精品 | 精品午夜久久福利影院| 欧美色偷偷大香| 亚洲一区二区三区视频在线| 精品在线你懂的| 精品少妇一区二区三区免费观看| 亚洲国产精品一区二区久久恐怖片| 国产精选一区二区三区| 26uuu亚洲综合色欧美 | 久久午夜电影网| 午夜日韩在线观看| 欧美偷拍一区二区| 午夜婷婷国产麻豆精品| 在线观看av一区二区| 国产精品视频看| 懂色av一区二区三区免费看| 国产日本欧洲亚洲| 国产91在线|亚洲| 欧美激情艳妇裸体舞| 国产精品一区二区久激情瑜伽| 精品国产乱码久久久久久浪潮| 美国毛片一区二区三区| 精品福利在线导航| 国产成人亚洲综合色影视| 中文字幕免费一区| 97精品电影院| 香蕉乱码成人久久天堂爱免费| 成人性视频免费网站| 一色桃子久久精品亚洲| 欧美午夜片在线观看| 中文字幕亚洲区| 欧美视频一区二区在线观看| 麻豆精品视频在线| 亚洲免费观看高清| 久久综合九色综合97婷婷女人| 91视视频在线观看入口直接观看www | 国产精品久久三区| 欧美高清激情brazzers| 国产ts人妖一区二区| 亚洲成人久久影院| 久久精品免费在线观看| 欧美日韩成人一区| 波多野结衣在线aⅴ中文字幕不卡| 无码av中文一区二区三区桃花岛| 国产精品视频线看| 欧美不卡123| 欧美丝袜自拍制服另类| 成人av电影在线观看| 麻豆成人91精品二区三区| 亚洲色图在线播放| 精品粉嫩aⅴ一区二区三区四区| 欧美在线高清视频| 成人免费视频app| 久久精品国产色蜜蜜麻豆| 亚洲男人的天堂网| 国产精品久久久久久久久久久免费看| 欧美午夜寂寞影院| 色综合一区二区三区| 国产精华液一区二区三区| 日韩国产欧美一区二区三区| 亚洲永久精品大片| 国产精品家庭影院| 久久精子c满五个校花| 日韩一区二区电影| 欧美精品色综合| 欧美午夜精品一区二区蜜桃 | 国产永久精品大片wwwapp| 性欧美疯狂xxxxbbbb| 亚洲午夜国产一区99re久久| 中文字幕日本乱码精品影院| 国产欧美一区在线| 久久久久久久综合| 久久婷婷色综合| 精品成人免费观看| 久久久亚洲午夜电影| 亚洲精品一区二区三区99| 久久噜噜亚洲综合| 国产三级精品视频| 国产精品美女视频| 国产精品久久久久久久第一福利 | 成人激情综合网站| 国产suv精品一区二区6| 国产成人精品三级麻豆| 福利一区二区在线| 色综合久久久久久久| 日本韩国一区二区三区视频| 色综合咪咪久久| 欧美日韩免费视频| 欧美一级精品大片| 久久久国产一区二区三区四区小说| 国产日产欧美一区| 亚洲男人的天堂在线观看| 亚洲成人福利片| 老色鬼精品视频在线观看播放| 国产中文一区二区三区| 成人免费视频一区二区| 日本久久精品电影| 欧美一区午夜精品| 久久久三级国产网站| 国产精品第一页第二页第三页| 亚洲一区自拍偷拍| 蜜臀av性久久久久av蜜臀妖精| 国产麻豆9l精品三级站| 99精品欧美一区二区蜜桃免费| 欧美午夜不卡视频| www日韩大片| 亚洲女人的天堂| 开心九九激情九九欧美日韩精美视频电影| 亚洲国产高清在线观看视频| 伊人性伊人情综合网| 蜜臀av一级做a爰片久久| 成人免费毛片高清视频| 91福利在线导航| 精品精品欲导航| 亚洲欧美日本韩国| 久久狠狠亚洲综合| 色综合久久99| 精品国产一区二区三区不卡| 中文字幕视频一区| 久久精品国产亚洲aⅴ| 99久久久国产精品免费蜜臀| 日韩写真欧美这视频| 中文字幕亚洲在| 日本少妇一区二区| 99久久婷婷国产综合精品| 欧美一区二区人人喊爽| 中文字幕在线一区免费| 看电影不卡的网站| 欧美视频第二页| 欧美国产欧美综合| 日本中文字幕一区二区视频| a4yy欧美一区二区三区| 久久久青草青青国产亚洲免观| 亚洲123区在线观看| www.久久久久久久久| 精品少妇一区二区三区视频免付费 | 国产精品久久免费看| 激情综合网av| 4438亚洲最大| 亚洲高清免费一级二级三级| 99精品久久久久久| 中文文精品字幕一区二区| 久久丁香综合五月国产三级网站| 在线视频你懂得一区| 中文子幕无线码一区tr| 国产精品影视在线观看| 6080国产精品一区二区| 亚洲精品国产视频| 欧美日韩你懂得| 国产在线日韩欧美| 国产精品九色蝌蚪自拍| 在线播放中文一区| 日韩成人伦理电影在线观看| 欧美日韩在线播放三区| 久久99精品国产麻豆不卡| 中文字幕国产一区二区| av一二三不卡影片| 自拍偷拍亚洲综合| 久久久久久黄色| 色琪琪一区二区三区亚洲区| 麻豆成人免费电影| 亚洲va在线va天堂| 欧美韩国日本一区|