Ignore:
Timestamp:
Dec 15, 2011, 3:37:23 PM (14 years ago)
Author:
dmik
Message:

Port RICHED32, RSAENH, SCHANNEL, SECUR32 to GCC/kBuild.

File:
1 moved

Legend:

Unmodified
Added
Removed
  • branches/gcc-kmk/src/riched32/initterm.cpp

    r21842 r21896  
    1 /* $Id: initriched32.cpp,v 1.5 2003-01-07 13:21:55 sandervl Exp $ */
     1/* $Id: initterm.cpp,v 1.6 2001-09-05 13:37:19 bird Exp $ */
    22/*
    3  * DLL entry point
     3 * RICHED32 DLL entry point
    44 *
    55 * Copyright 1998 Sander van Leeuwen
    66 * Copyright 1998 Peter Fitzsimmons
    77 *
    8  *
    98 * Project Odin Software License can be found in LICENSE.TXT
    10  *
    119 */
    1210
    13 /*-------------------------------------------------------------*/
    14 /* INITERM.C -- Source for a custom dynamic link library       */
    15 /*              initialization and termination (_DLL_InitTerm) */
    16 /*              function.                                      */
    17 /*                                                             */
    18 /* When called to perform initialization, this sample function */
    19 /* gets storage for an array of integers, and initializes its  */
    20 /* elements with random integers.  At termination time, it     */
    21 /* frees the array.  Substitute your own special processing.   */
    22 /*-------------------------------------------------------------*/
    23 
    24 
    25 /* Include files */
    2611#define  INCL_DOSMODULEMGR
    2712#define  INCL_DOSPROCESS
     
    3722#include <initdll.h>
    3823
    39 extern "C" {
    40  //Win32 resource table (produced by wrc)
     24// Win32 resource table (produced by wrc)
    4125extern DWORD riched32_PEResTab;
    4226
     27static HMODULE dllHandle = 0;
     28
    4329BOOL WINAPI RICHED32_LibMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved);
    44 }
    45 static HMODULE dllHandle = 0;
    46 //******************************************************************************
    47 //******************************************************************************
     30
    4831static BOOL WINAPI OdinLibMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID fImpLoad)
    4932{
    50    BOOL ret;
     33    BOOL ret;
    5134
    52    switch (fdwReason)
    53    {
    54    case DLL_PROCESS_ATTACH:
    55        return RICHED32_LibMain(hinstDLL, fdwReason, fImpLoad);
     35    switch (fdwReason)
     36    {
     37    case DLL_PROCESS_ATTACH:
     38        return RICHED32_LibMain(hinstDLL, fdwReason, fImpLoad);
    5639
    57    case DLL_THREAD_ATTACH:
    58    case DLL_THREAD_DETACH:
    59        return RICHED32_LibMain(hinstDLL, fdwReason, fImpLoad);
     40    case DLL_THREAD_ATTACH:
     41    case DLL_THREAD_DETACH:
     42        return RICHED32_LibMain(hinstDLL, fdwReason, fImpLoad);
    6043
    61    case DLL_PROCESS_DETACH:
    62        ret = RICHED32_LibMain(hinstDLL, fdwReason, fImpLoad);
    63        return ret;
    64    }
    65    return FALSE;
     44    case DLL_PROCESS_DETACH:
     45        ret = RICHED32_LibMain(hinstDLL, fdwReason, fImpLoad);
     46        return ret;
     47    }
     48    return FALSE;
    6649}
    67 /****************************************************************************/
    68 /* _DLL_InitTerm is the function that gets called by the operating system   */
    69 /* loader when it loads and frees this DLL for each process that accesses   */
    70 /* this DLL.  However, it only gets called the first time the DLL is loaded */
    71 /* and the last time it is freed for a particular process.  The system      */
    72 /* linkage convention MUST be used because the operating system loader is   */
    73 /* calling this function.                                                   */
    74 /****************************************************************************/
    75 ULONG APIENTRY inittermRiched32(ULONG hModule, ULONG ulFlag)
     50
     51ULONG SYSTEM DLL_InitRichEd32(ULONG hModule)
    7652{
    77    size_t i;
    78    APIRET rc;
     53    CheckVersionFromHMOD(PE2LX_VERSION, hModule); /*PLF Wed  98-03-18 05:28:48*/
    7954
    80    /*-------------------------------------------------------------------------*/
    81    /* If ulFlag is zero then the DLL is being loaded so initialization should */
    82    /* be performed.  If ulFlag is 1 then the DLL is being freed so            */
    83    /* termination should be performed.                                        */
    84    /*-------------------------------------------------------------------------*/
     55    dllHandle = RegisterLxDll(hModule, OdinLibMain, (PVOID)&riched32_PEResTab);
     56    if (dllHandle == 0)
     57        return -1;
    8558
    86    switch (ulFlag) {
    87       case 0 :
    88          CheckVersionFromHMOD(PE2LX_VERSION, hModule); /*PLF Wed  98-03-18 05:28:48*/
    89          dllHandle = RegisterLxDll(hModule, OdinLibMain, (PVOID)&riched32_PEResTab);
    90          if(dllHandle == 0)
    91              return 0UL;
     59    return 0;
     60}
    9261
    93          break;
     62void SYSTEM DLL_TermRichEd32(ULONG hModule)
     63{
     64    if (dllHandle)
     65       UnregisterLxDll(dllHandle);
     66}
    9467
    95       case 1 :
    96          if(dllHandle) {
    97              UnregisterLxDll(dllHandle);
    98          }
    99          break;
    100       default  :
    101          return 0UL;
    102    }
     68ULONG SYSTEM DLL_Init(ULONG hModule)
     69{
     70    if (DLL_InitDefault(hModule) == -1)
     71        return -1;
     72    return DLL_InitRichEd32(hModule);
     73}
    10374
    104    /***********************************************************/
    105    /* A non-zero value must be returned to indicate success.  */
    106    /***********************************************************/
    107    return 1UL;
     75void SYSTEM DLL_Term(ULONG hModule)
     76{
     77    DLL_TermRichEd32(hModule);
     78    DLL_TermDefault(hModule);
    10879}
    109 //******************************************************************************
    110 //******************************************************************************
Note: See TracChangeset for help on using the changeset viewer.