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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? iuilink.cpp

?? 英文版的 想要的話可以下載了 為大家服務(wù)
?? CPP
字號:
/*
 * IUILINK.CPP
 * Patron Chapter 22
 *
 * Implementation of an object with the IOleUILinkContainer
 * interface necessary to use the standard Links Dialog.  This
 * is implemented as a stand-along object with access to the CPage
 * with which its associated, primiarily because it is only used
 * for the one dialog.  Therefore this object has it's own IUnknown.
 * In addition, we use the Links Assistant object developed in this
 * chapter to simplify our own code.
 *
 * Copyright (c)1993-1995 Microsoft Corporation, All Rights Reserved
 *
 * Kraig Brockschmidt, Microsoft
 * Internet  :  kraigb@microsoft.com
 * Compuserve:  >INTERNET:kraigb@microsoft.com
 */


#include "patron.h"


/*
 * CIOleUILinkContainer::CIOleUILinkContainer
 * CIOleUILinkContainer::~CIOleUILinkContainer
 *
 * Parameters (Constructor):
 *  pPage           PCPage of the page we're in.
 */

CIOleUILinkContainer::CIOleUILinkContainer(PCPage pPage)
    {
    m_cRef=0;
    m_pPage=pPage;
    m_iTenant=0;
    m_pDelIUILinks=NULL;
    m_fDirty=FALSE;
    return;
    }

CIOleUILinkContainer::~CIOleUILinkContainer(void)
    {
    ReleaseInterface(m_pDelIUILinks);
    return;
    }



/*
 * CIOleUILinkContainer::Init
 *
 * Purpose:
 *  Performs initialization on the object that might fail.  In
 *  particular this creates an object of CLSID_LinksAssistant that
 *  helps in implementing this interface.
 *
 * Parameters:
 *  None
 *
 * Return Value:
 *  BOOL            TRUE if successful, FALSE otherwise.
 */

BOOL CIOleUILinkContainer::Init(void)
    {
    HRESULT     hr;

    hr=CoCreateInstance(CLSID_LinksAssistant, NULL
        , CLSCTX_INPROC_SERVER, IID_IOleUILinkContainer
        , (PPVOID)&m_pDelIUILinks);

    return SUCCEEDED(hr);
    }





/*
 * CIOleUILinkContainer::QueryInterface
 * CIOleUILinkContainer::AddRef
 * CIOleUILinkContainer::Release
 *
 * Purpose:
 *  IUnknown members for CIOleUILinkContainer object.
 */

STDMETHODIMP CIOleUILinkContainer::QueryInterface(REFIID riid
    , PPVOID ppv)
    {
    *ppv=NULL;

    if (IID_IUnknown==riid || IID_IOleUILinkContainer==riid)
        {
        *ppv=this;
        AddRef();
        return NOERROR;
        }

    return ResultFromScode(E_NOINTERFACE);
    }


STDMETHODIMP_(ULONG) CIOleUILinkContainer::AddRef(void)
    {
    return ++m_cRef;
    }

STDMETHODIMP_(ULONG) CIOleUILinkContainer::Release(void)
    {
    if (0!=--m_cRef)
        return m_cRef;

    delete this;
    return 0;
    }



/*
 * CIOleUILinkContainer::GetNextLink
 *
 * Purpose:
 *  Called when the Links dialog is filling its listbox.  Here we
 *  need to return a key for the first link if dwLink is zero, then
 *  return the next links if it's non-zero.
 *
 * Parameters:
 *  dwLink          DWORD last returned from this function.  Zero if
 *                  this is the first call to this function.
 *
 * Return Value:
 *  DWORD           Some value that identifies this object.  Zero
 *                  stops the sequence such that this function is
 *                  no longer called.
 */

STDMETHODIMP_(DWORD) CIOleUILinkContainer::GetNextLink(DWORD dwLink)
    {
    PCTenant        pTenant;

    //If we're told to start the sequence, set index to zero.
    if (0L==dwLink)
        m_iTenant=0;

    /*
     * On each subsequent call, find the next linked object in
     * this document and return it.  Make sure the index is
     * incremented for the next time this function is called.
     */
    for ( ; m_iTenant < m_pPage->m_cTenants; m_iTenant++)
        {
        if (m_pPage->TenantGet(m_iTenant, &pTenant, FALSE))
            {
            if (TENANTTYPE_LINKEDOBJECT==pTenant->TypeGet())
                {
                m_iTenant++;
                return (DWORD)pTenant;
                }
            }
        }

    //If we hit the end of list, this tells the dialog to stop.
    return 0L;
    }





/*
 * CIOleUILinkContainer::SetLinkUpdateOptions
 *
 * Purpose:
 *  Informs the application to call IOleLink::SetUpdateOptions for
 *  the object identified by dwLink.
 *
 * Parameters:
 *  dwLink          DWORD object identifier as returned from
 *                  GetNextLink.
 *  dwOptions       DWORD containing the new options.
 *
 * Return Value:
 *  HRESULT         Return value of IOleLink::SetUpdateOptions.
 */

STDMETHODIMP CIOleUILinkContainer::SetLinkUpdateOptions(DWORD dwLink
    , DWORD dwOptions)
    {
    LPOLELINK       pIOleLink;
    HRESULT         hr;

    if (NULL==dwLink)
        return ResultFromScode(E_FAIL);

    /*
     * Your responsibility is to call the object's
     * IOleLink::SetUpdateOptions function with dwOptions.  Simple?
     *
     * For Patron we must first get the object pointer obtainable
     * from the tenant's ObjectGet function, then QI for IOleLink.
     */

    hr=GetObjectInterface(dwLink, IID_IOleLink, (PPVOID)&pIOleLink);

    if (FAILED(hr))
        return hr;

    hr=pIOleLink->SetUpdateOptions(dwOptions);
    pIOleLink->Release();

    m_fDirty=SUCCEEDED(hr);
    return hr;
    }





/*
 * CIOleUILinkContainer::GetLinkUpdateOptions
 *
 * Purpose:
 *  Requests the container to call IOleLink::GetUpdateOptions for
 *  the object identified by dwLink.
 *
 * Parameters:
 *  dwLink          DWORD identifying the object
 *  pdwOptions      LPDWORD in which to store the options.
 *
 * Return Value:
 *  HRESULT         Return value of IOleLink::GetUpdateOptions
 */

STDMETHODIMP CIOleUILinkContainer::GetLinkUpdateOptions(DWORD dwLink
    , LPDWORD pdwOptions)
    {
    LPOLELINK       pIOleLink;
    HRESULT         hr;

    if (NULL==dwLink)
        return ResultFromScode(E_FAIL);

    hr=GetObjectInterface(dwLink, IID_IOleLink, (PPVOID)&pIOleLink);

    if (FAILED(hr))
        return hr;

    hr=pIOleLink->GetUpdateOptions(pdwOptions);
    pIOleLink->Release();

    return hr;
    }





/*
 * CIOleUILinkContainer::SetLinkSource
 *
 * Purpose:
 *  Changes the moniker to which an object is linked.
 *
 * Parameters:
 *  dwLink          DWORD identifying the object in question.
 *  pszName         LPTSTR to the displayable name of the source.
 *  cchName         ULONG length of the file portaion of pszName
 *  pchEaten        ULONG * in which to return the number of
 *                  characters used in parsing pszDisplayName.
 *  fValidate       BOOL indicating if we're to validate that the
 *                  source exists first.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, E_FAIL otherwise.
 */

STDMETHODIMP CIOleUILinkContainer::SetLinkSource(DWORD dwLink
    , LPTSTR pszName, ULONG cchName, ULONG *pchEaten
    , BOOL fValidate)
    {
    PCTenant        pTenant=(PCTenant)dwLink;
    HRESULT         hr;
    LPOLELINK       pIOleLink;

    if (NULL==dwLink)
        return ResultFromScode(E_FAIL);

    //This is for use in GetLinkSource, below.
    pTenant->m_fLinkAvail=FALSE;

    hr=GetObjectInterface(dwLink, IID_IOleLink, (PPVOID)&pIOleLink);

    if (FAILED(hr))
        return hr;

    hr=m_pDelIUILinks->SetLinkSource((DWORD)pIOleLink, pszName
        , cchName, pchEaten, fValidate);
    pIOleLink->Release();

    if (FAILED(hr))
        return hr;

    //hr will be S_FALSE if link is unavailable.
    pTenant->Repaint();
    pTenant->m_fLinkAvail=(NOERROR==hr);
    m_fDirty=TRUE;
    return NOERROR;
    }






/*
 * CIOleUILinkContainer::GetLinkSource
 *
 * Purpose:
 *  Retrieves various strings and values for this link source.
 *
 * Parameters:
 *  dwLink          DWORD identifying the object affected.
 *  ppszName        LPTSTR * in which to return the new source
 *                  name
 *  pcchName        ULONG * in which to return the length of
 *                  pszName
 *  ppszFullLink    LPTSTR * in which to return the full name of
 *                  the class of linked object.
 *  ppszShortLink   LPTSTR * in which to return the short name of
 *                  the class of linked object.
 *  pfSourceAvail   BOOL * in which to return if this is an
 *                  available link source.
 *  pfSelected      BOOL * in which to return if this object is
 *                  currently selected in the document.  This
 *                  selects the item in the listbox for this object.
 *
 * Return Value:
 *  HRESULT         NOERROR on success, error code otherwise.
 */

STDMETHODIMP CIOleUILinkContainer::GetLinkSource(DWORD dwLink
    , LPTSTR *ppszName, ULONG *pcchName, LPTSTR *ppszFullLink
    , LPTSTR *ppszShortLink, BOOL *pfSourceAvail, BOOL *pfSelected)
    {
    HRESULT         hr;
    PCTenant        pTenant=(PCTenant)dwLink;
    LPOLELINK       pIOleLink=NULL;
    LPOLEOBJECT     pIOleObject=NULL;
    LPMONIKER       pmk=NULL;
    LPMONIKER       pmkFirst=NULL;
    LPBC            pbc=NULL;

    if (NULL==dwLink)
        return ResultFromScode(E_FAIL);

    //We know what this is from SetLinkSource
    *pfSourceAvail=pTenant->m_fLinkAvail;

    if (pfSelected)
        *pfSelected=pTenant->FIsSelected();

    hr=GetObjectInterface(dwLink, IID_IOleLink, (PPVOID)&pIOleLink);

    if (FAILED(hr))
        return hr;

    hr=m_pDelIUILinks->GetLinkSource((DWORD)pIOleLink, ppszName
        , pcchName, ppszFullLink, ppszShortLink, pfSourceAvail
        , pfSelected);

    pIOleLink->Release();
    return hr;
    }





/*
 * CIOleUILinkContainer::OpenLinkSource
 *
 * Purpose:
 *  Asks the container to call DoVerb on this object with
 *  OLEIVERB_SHOW.
 *
 * Parameters:
 *  dwLink          DWORD identifying the linked object.
 *
 * Return Value:
 *  HRESULT         Standard.
 */

STDMETHODIMP CIOleUILinkContainer::OpenLinkSource(DWORD dwLink)
    {
    PCTenant        pTenant=(PCTenant)dwLink;

    //CHAPTER22MOD
    pTenant->Activate(OLEIVERB_OPEN, NULL);
    //End CHAPTER22MOD

    return NOERROR;
    }




/*
 * CIOleUILinkContainer::UpdateLink
 *
 * Purpose:
 *  Asks the container to update the link for this object.
 *
 * Parameters:
 *  dwLink          DWORD identifying the linked object.
 *  fErrorMessage   BOOL indicating if we can show errors.
 *  fErrorAction    BOOL making no sense whatsoever.
 *
 * Return Value:
 *  HRESULT         Standard.
 */

STDMETHODIMP CIOleUILinkContainer::UpdateLink(DWORD dwLink
    , BOOL fErrorMessage, BOOL fErrorAction)
    {
    PCTenant        pTenant=(PCTenant)dwLink;
    LPOLELINK       pIOleLink;
    HRESULT         hr;

    hr=GetObjectInterface(dwLink, IID_IOleLink, (PPVOID)&pIOleLink);

    if (FAILED(hr))
        return hr;

    hr=m_pDelIUILinks->UpdateLink((DWORD)pIOleLink, fErrorMessage
        , fErrorAction);

    pTenant->Repaint();
    pTenant->m_fLinkAvail=SUCCEEDED(hr);
    pIOleLink->Release();

    if (FAILED(hr))
        {
        if (fErrorMessage)
            {
            MessageBox(m_pPage->m_hWnd
                , TEXT("Could not update link."), TEXT("Patron")
                , MB_OK);
            }
        }
    else
        m_fDirty=TRUE;

    return hr;
    }






/*
 * CIOleUILinkContainer::CancelLink
 *
 * Purpose:
 *  Requests that the container turn this linked object into a
 *  static object.
 *
 * Parameters:
 *  dwLink          DWORD identifying the linked object.
 *
 * Return Value:
 *  HRESULT         Standard.
 */

STDMETHODIMP CIOleUILinkContainer::CancelLink(DWORD dwLink)
    {
    PCTenant        pTenant=(PCTenant)dwLink;
    LPOLELINK       pIOleLink;
    HRESULT         hr;

    hr=GetObjectInterface(dwLink, IID_IOleLink, (PPVOID)&pIOleLink);

    if (FAILED(hr))
        return hr;

    //This sets the source moniker to NULL.
    m_pDelIUILinks->CancelLink((DWORD)pIOleLink);
    pIOleLink->Release();

    //Go change this object over to a static one.
    pTenant->ConvertToStatic();

    m_fDirty=TRUE;
    return NOERROR;
    }






//PROTECTED FUNCTIONS INTERNAL TO CIOleUILinkContainer


/*
 * CIOleUILinkContainer::GetObjectInterface
 * (Protected)
 *
 * Purpose:
 *  Retrieves and interface pointer for the object identified by
 *  dwLink
 *
 * Parameters:
 *  dwLink          DWORD identifying the object
 *  riid            REFIID of the interface desired.
 *  ppv             PPVOID into which we return the pointer.
 *
 * Return Value:
 *  HRESULT         NOERROR on success, error code otherwise.
 */

STDMETHODIMP CIOleUILinkContainer::GetObjectInterface(DWORD dwLink
    , REFIID riid, PPVOID ppv)
    {
    PCTenant        pTenant=(PCTenant)dwLink;
    LPUNKNOWN       pIUnknown;
    HRESULT         hr;

    pTenant->ObjectGet(&pIUnknown);
    hr=pIUnknown->QueryInterface(riid, ppv);
    pIUnknown->Release();

    return hr;
    }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
大桥未久av一区二区三区中文| 欧美网站一区二区| 一区二区三区加勒比av| 日韩免费高清电影| 欧美三级电影网| 不卡大黄网站免费看| 免费人成在线不卡| 天堂成人免费av电影一区| 亚洲欧美综合另类在线卡通| 亚洲精品一区二区三区福利 | 成人av电影免费在线播放| 蜜桃av一区二区| 亚洲一区在线免费观看| 亚洲精品一二三四区| 欧美激情一区二区三区四区| 精品久久久久一区| 69成人精品免费视频| 欧美在线观看你懂的| www.色综合.com| 国产成人av影院| 国内精品视频一区二区三区八戒| 视频在线观看一区二区三区| 亚洲激情在线播放| 亚洲久草在线视频| 亚洲视频免费在线| 亚洲男同1069视频| 国产精品网站导航| 亚洲国产电影在线观看| 国产午夜精品一区二区| 久久亚区不卡日本| 亚洲精品一区二区三区精华液| 日韩欧美亚洲一区二区| 欧美一区二区黄色| 欧美成人精品1314www| 欧美一区二区三区四区高清| 7777精品伊人久久久大香线蕉的 | 美女网站视频久久| 男人的天堂久久精品| 天天色 色综合| 日韩高清中文字幕一区| 青青草97国产精品免费观看无弹窗版| 午夜精品久久久久久| 日韩精品一级二级| 麻豆精品视频在线观看免费| 麻豆一区二区在线| 国产在线观看免费一区| 成人综合在线视频| gogo大胆日本视频一区| 91亚洲永久精品| 欧美专区亚洲专区| 日韩一区二区三区av| 亚洲精品一区在线观看| 国产精品嫩草影院com| 综合在线观看色| 一区二区成人在线| 亚洲成人先锋电影| 国产中文一区二区三区| 成人亚洲一区二区一| 91蝌蚪porny九色| 欧美日韩国产123区| 日韩欧美一二三| 国产精品欧美综合在线| 亚洲精品国产一区二区精华液| 亚洲国产另类精品专区| 麻豆久久一区二区| 国产传媒一区在线| 91久久精品一区二区三区| 欧美精品视频www在线观看| 亚洲精品在线一区二区| 亚洲欧洲精品一区二区三区| 亚洲最大色网站| 裸体在线国模精品偷拍| 成人三级在线视频| 欧美三级蜜桃2在线观看| 久久午夜色播影院免费高清| 亚洲柠檬福利资源导航| 久热成人在线视频| 色吊一区二区三区| wwwwww.欧美系列| 亚洲一区在线观看视频| 国产精品一区二区三区网站| 欧美视频日韩视频在线观看| 26uuu国产一区二区三区| 亚洲综合偷拍欧美一区色| 精品在线观看视频| 日本精品一级二级| 久久久蜜桃精品| 天天综合网 天天综合色| 成人性生交大片免费看中文| 91麻豆精品国产91久久久 | 人人精品人人爱| 成人av免费观看| 欧美大片日本大片免费观看| 亚洲色图一区二区三区| 国产一区二区三区四区五区美女 | 国产欧美在线观看一区| 视频一区免费在线观看| av网站免费线看精品| 日韩一区二区在线播放| 亚洲综合一区二区精品导航| 国产成人精品影视| 日韩一区二区免费高清| 亚洲综合色视频| 成人激情校园春色| 26uuu国产一区二区三区| 日韩精品久久理论片| 色婷婷久久综合| 中文成人综合网| 久久99精品国产麻豆不卡| 欧美日韩黄色一区二区| 亚洲欧美色图小说| 国产99一区视频免费| 久久这里只有精品6| 蜜臀久久99精品久久久画质超高清 | 日韩女优视频免费观看| 亚洲一区二区三区四区在线| 99视频精品免费视频| 国产日产精品1区| 国产自产高清不卡| 精品剧情在线观看| 精品一区免费av| 精品国产乱码久久久久久闺蜜| 日韩电影在线一区二区| 欧美精品精品一区| 日韩激情视频在线观看| 欧美日韩久久一区二区| 香蕉久久夜色精品国产使用方法| 91福利国产精品| 亚洲电影欧美电影有声小说| 日本大香伊一区二区三区| 国产精品毛片久久久久久久| 成人一区二区三区| 国产精品欧美久久久久无广告| 成人免费视频一区| 国产精品国模大尺度视频| 99在线精品观看| 亚洲色欲色欲www在线观看| 91在线视频播放| 一区二区在线观看av| 欧美最新大片在线看| 五月婷婷久久综合| 日韩一区和二区| 精品一区二区三区不卡| 久久久www成人免费毛片麻豆| 国产美女精品在线| 国产精品网站在线播放| 色综合久久综合网97色综合| 亚洲一区二区在线播放相泽| 欧美日韩一区不卡| 老司机精品视频线观看86| 国产无人区一区二区三区| 懂色av一区二区夜夜嗨| 综合av第一页| 欧美人与性动xxxx| 精彩视频一区二区三区| 欧美激情一区二区| 91国偷自产一区二区使用方法| 婷婷综合在线观看| 精品国产一区二区三区久久影院| 国产成人久久精品77777最新版本| 中文字幕亚洲在| 精品视频在线免费观看| 国产自产高清不卡| 亚洲免费观看高清完整版在线观看| 欧美日韩另类国产亚洲欧美一级| 另类小说综合欧美亚洲| 欧美福利一区二区| 国产精品久久久久久户外露出| 日韩av不卡在线观看| 在线观看国产日韩| 奇米色一区二区| 国产日韩高清在线| 欧美中文字幕一区二区三区| 久久国产人妖系列| 亚洲日本丝袜连裤袜办公室| 欧美日韩极品在线观看一区| 国内精品免费**视频| 亚洲精品视频在线看| 精品精品国产高清一毛片一天堂| 成人福利电影精品一区二区在线观看| 亚洲妇熟xx妇色黄| 久久久久久久综合| 91久久一区二区| 国产一区啦啦啦在线观看| 亚洲国产成人av| 中文字幕 久热精品 视频在线| 欧美色手机在线观看| 国产精品中文有码| 日韩精品视频网| 亚洲伦理在线免费看| 久久久久久麻豆| 欧美一级片在线看| 91豆麻精品91久久久久久| 国产美女av一区二区三区| 午夜电影网一区| 亚洲欧美日韩中文播放| 亚洲精品在线免费观看视频| 欧美日韩免费电影| 色综合久久久久久久久久久| 国产成人精品免费网站|