Module cRegistry.pkg

     1// cRegistry.pkg
     2// Author: SWB
     3
     4//  Registry Access Package
     5
     6Use Windows.pkg
     7Use RegistryAPI.pkg
     8
     9Enum_List // Registry Data types
    10    Define rdString
    11    Define rdDword
    12    Define rdBinary
    13    Define rdUnknown
    14End_Enum_List
    15
    16//Prototypes
    17Register_Function phRootKey      Returns Handle // HKEY_CURRENT_USER
    18Register_Function pfAccessRights Returns Integer // KEY_ALL_ACCESS - what access level should be used to open a Key?
    19Register_Function phCurrentKey   Returns Handle // low-level key
    20Register_Function pbLazyWrite    Returns Boolean // True
    21
    22Register_Function CountOfSubkeys      Returns Integer
    23Register_Function CountOfValues       Returns Integer
    24Register_Function CreateKey           String sKeyName Returns Integer   // return=error code
    25Register_Function DeleteKey           String sKeyName Returns Boolean       // Deleted successfully?
    26Register_Function DeleteValue         String sValueName Returns Boolean // Deleted successfully?
    27Register_Function GetSubkeys          Handle hoArray Returns Integer    // count of Subkeys
    28Register_Function GetValues           Handle hoArray Returns Integer    // count of Values
    29Register_Function KeyExists           String sKeyName Returns Boolean   // does the key exist?
    30Register_Function LongestDataLength   Returns Integer
    31Register_Function LongestSubkeyLength Returns Integer
    32Register_Function LongestValueLength  Returns Integer
    33Register_Function OpenKey             string sKeyName Returns Integer
    34Register_Function ReadBinary          String sValueName Address aValueData Integer iDataLength Returns Boolean
    35Register_Function ReadDword           String sValueName Returns DWord
    36Register_Function ReadString          String sValueName Returns String
    37Register_Function ValueExists         String sValueName Returns Integer // does the Value exist?
    38Register_Function ValueLength         String sValueName Returns Integer
    39Register_Function ValueType           String sValueName Returns Integer // what is the datatype of the Value?
    40Register_Procedure CloseKey
    41Register_Procedure WriteBinary        String sValueName Address aValueData Integer iDataLength
    42Register_Procedure WriteDword         String sValue DWord dwValueData
    43Register_Procedure WriteString        String sValue String sValueData
    44
    45
    46
    47
    48Class cRegistry is a cObject
    49    Procedure Construct_Object
    50        Forward Send Construct_Object
    51
    52        Property Handle phRootKey HKEY_CURRENT_USER
    53        Property UInteger pfAccessRights  KEY_ALL_ACCESS // what access level should be used to open a Key?
    54        Property Handle phCurrentKey
    55        Property Boolean pbLazyWrite True
    56    End_Procedure
    57
    58    Function CountOfSubkeys Returns Integer
    59        DWord dwCountOfSubkeys
    60        Integer iError
    61        String sError
    62
    63        Move 0 To dwCountOfSubkeys
    64        Move (RegQueryInfoKey(phCurrentKey(self), 0, 0, 0, AddressOf(dwCountOfSubkeys), 0, 0, 0, 0, 0, 0, 0)) To iError
    65        If iError Begin
    66            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
    67            Error DFERR_REGISTRY sError // Generic Windows Error
    68        End
    69        Function_Return dwCountOfSubkeys
    70    End_Function
    71
    72    Function CountOfValues Returns Integer
    73        DWord dwCountOfValues
    74        Integer iError
    75        String sError
    76
    77        Move 0 To dwCountOfValues
    78        Move (RegQueryInfoKey(phCurrentKey(self), 0, 0, 0, 0, 0, 0, AddressOf(dwCountOfValues), 0, 0, 0, 0)) To iError
    79        If iError Begin
    80            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
    81            Error DFERR_REGISTRY sError // Generic Windows Error
    82        End
    83
    84        Function_Return dwCountOfValues
    85    End_Function
    86
    87    Function LongestSubkeyLength Returns Integer
    88        DWord dwLongestSubkeyLength
    89        Integer iError
    90        String sError
    91
    92        Move 0 To dwLongestSubkeyLength
    93        Move (RegQueryInfoKey(phCurrentKey(self), 0, 0, 0, 0, AddressOf(dwLongestSubkeyLength), 0, 0, 0, 0, 0, 0)) To iError
    94        If iError Begin
    95            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
    96            Error DFERR_REGISTRY sError // Generic Windows Error
    97        End
    98
    99        Function_Return dwLongestSubkeyLength
   100    End_Function
   101
   102    Function LongestValueLength Returns Integer
   103        DWord dwLongestValueLength
   104        Integer iError
   105        String sError
   106
   107        Move 0 To dwLongestValueLength
   108        Move (RegQueryInfoKey(phCurrentKey(self), 0, 0, 0, 0, 0, 0, 0, AddressOf(dwLongestValueLength), 0, 0, 0)) To iError
   109        If iError Begin
   110            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   111            Error DFERR_REGISTRY sError // Generic Windows Error
   112        End
   113
   114        Function_Return dwLongestValueLength
   115    End_Function
   116
   117    Function LongestDataLength Returns Integer
   118        DWord dwLongestDataLength
   119        Integer iError
   120        String sError
   121
   122        Move 0 To dwLongestDataLength
   123        Move (RegQueryInfoKey(phCurrentKey(self), 0, 0, 0, 0, 0, 0, 0, 0, AddressOf(dwLongestDataLength), 0, 0)) To iError
   124        If iError Begin
   125            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   126            Error DFERR_REGISTRY sError // Generic Windows Error
   127        End
   128
   129        Function_Return dwLongestDataLength
   130    End_Function
   131
   132    Function ValueType String sValueName Returns Integer
   133        DWord dwType
   134        Integer iError eType
   135        String sError
   136
   137        Move 0 To dwType
   138        Move (RegQueryValueEx(phCurrentKey(self), ToAnsi(sValueName), 0, AddressOf(dwType), 0, 0)) To iError
   139        If iError Begin
   140            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   141            Error DFERR_REGISTRY sError // Generic Windows Error
   142        End
   143
   144        If (dwType = REG_SZ)          Move rdString To eType
   145        Else If (dwType = REG_DWORD)  Move rdDword To eType
   146        Else If (dwType = REG_BINARY) Move rdBinary To eType
   147        Else                          Move rdUnknown To eType
   148
   149        Function_Return eType
   150    End_Function
   151
   152    Function ValueLength String sValueName Returns Integer
   153        DWord dwSize
   154        Integer iError
   155        String sError
   156
   157        Move 0 To dwSize
   158        Move (RegQueryValueEx(phCurrentKey(self), ToAnsi(sValueName), 0, 0, 0, AddressOf(dwSize))) To iError
   159        If iError Begin
   160            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   161            Error DFERR_REGISTRY sError // Generic Windows Error
   162        End
   163
   164        Function_Return dwSize
   165    End_Function
   166
   167    Function CreateKey string sKeyName Returns Integer // return=error code
   168        // Calling CreateKey for an existing Key, merely opens it without error.
   169        Handle hKey hKeyOpened
   170        Integer iError
   171        String sError
   172
   173        Move 0 To hKeyOpened // initialize it so we can get its address
   174
   175        Get phRootKey To hKey
   176
   177        Move (RegCreateKeyEx(hKey, ToAnsi(sKeyName), 0, 0, REG_OPTION_NON_VOLATILE, pfAccessRights(self), 0, AddressOf(hKeyOpened), 0)) To iError
   178        If (iError =0) Set phCurrentKey To hKeyOpened
   179        Else Begin
   180            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   181            Error DFERR_REGISTRY sError // Generic Windows Error
   182        End
   183        Function_Return iError
   184    End_Function
   185
   186    Procedure CloseKey
   187        Integer iError
   188        Handle hKey
   189
   190        Get phCurrentKey To hKey
   191
   192        If (hKey <>0) Begin
   193            If (pbLazyWrite(self)) Move (RegCloseKey(hKey)) To iError
   194            Else Move (RegFlushKey(hKey)) To iError
   195
   196            Set phCurrentKey To 0
   197        End
   198    End_Procedure
   199
   200    Function OpenKey string sKeyName Returns Boolean
   201        Handle hKey hKeyOpened
   202        Integer iError
   203
   204        Move 0 To hKeyOpened // initialize it so we can get its address
   205
   206        Get phRootKey To hKey
   207        Move (RegOpenKeyEx(hKey, ToAnsi(sKeyName), 0, pfAccessRights(self), AddressOf(hKeyOpened))) To iError
   208        If (iError =0) Set phCurrentKey To hKeyOpened
   209
   210        Function_Return (iError=0)
   211    End_Function
   212
   213    Procedure WriteDword String sValue DWord dwValueData
   214        Handle hKey
   215        Integer iError
   216        Pointer lpsDWord
   217        String sDWord
   218        String sError
   219
   220        ZeroType tDWord To sDWord
   221        Put dwValueData To sDWord At tDWord.dword
   222        GetAddress of sDWord To lpsDWord
   223
   224        Get phCurrentKey To hKey
   225        Move (RegSetValueEx(hKey, ToAnsi(sValue), 0, REG_DWORD, lpsDWord, 4)) To iError
   226        If iError Begin
   227            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   228            Error DFERR_REGISTRY sError // Generic Windows Error
   229        End
   230    End_Procedure
   231
   232    Procedure WriteString String sValue String sValueData
   233        Handle hKey
   234        Integer iError cbData
   235        Pointer lpsValueData
   236        String sError
   237
   238        If (sValueData = "") Begin
   239             Move (Character(0)) To sValueData
   240             Move 1 To cbData
   241        End
   242        Else Begin
   243             Move (Length(sValueData) +1) To cbData
   244        End
   245        Move (ToAnsi(sValueData)) To sValueData
   246        GetAddress of sValueData To lpsValueData
   247
   248        Get phCurrentKey To hKey
   249        Move (RegSetValueEx(hKey, ToAnsi(sValue), 0, REG_SZ, lpsValueData, cbData)) To iError
   250        If iError Begin
   251            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   252            Error DFERR_REGISTRY sError // Generic Windows Error
   253        End
   254    End_Procedure
   255
   256    Procedure WriteBinary String sValueName Address aValueData Integer iDataLength
   257        Handle hKey
   258        Integer iError
   259        String sError
   260
   261        Get phCurrentKey To hKey
   262        Move (RegSetValueEx(hKey, ToAnsi(sValueName), 0, REG_BINARY, aValueData, iDataLength)) To iError
   263        If iError Begin
   264            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   265            Error DFERR_REGISTRY sError // Generic Windows Error
   266        End
   267    End_Procedure
   268
   269    Function ReadDword String sValueName Returns DWord
   270        Handle hKey
   271        Integer iError
   272        DWord dwValueData dwValueDataLength
   273        String sError
   274
   275        Move 0           To dwValueData
   276        Move tDWord_Size To dwValueDataLength
   277
   278        Get phCurrentKey To hKey
   279        Move (RegQueryValueEx(hKey, ToAnsi(sValueName), 0, 0, AddressOf(dwValueData), AddressOf(dwValueDataLength))) To iError
   280        If iError Begin
   281            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   282            Error DFERR_REGISTRY sError // Generic Windows Error
   283        End
   284
   285        Function_Return dwValueData
   286    End_Function
   287
   288    Function ReadString String sValueName Returns String
   289        Handle hKey
   290        Integer iError
   291        String sValueData
   292        DWord dwValueDataLength
   293        Pointer lpsValueData
   294        String sError
   295
   296        Move (Repeat(character(0), ValueLength(self, sValueName))) To sValueData
   297        GetAddress of sValueData To lpsValueData
   298
   299        Move (Length(sValueData)) To dwValueDataLength
   300
   301        Get phCurrentKey To hKey
   302        Move (RegQueryValueEx(hKey, ToAnsi(sValueName), 0, 0, lpsValueData, AddressOf(dwValueDataLength))) To iError
   303        If iError Begin
   304            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   305            Error DFERR_REGISTRY sError // Generic Windows Error
   306        End
   307
   308        Function_Return (ToOem(CString(sValueData)))
   309    End_Function
   310
   311    Function ReadBinary String sValueName Address aValueData Integer iDataLength Returns Boolean
   312        Handle hKey
   313        Integer iError
   314        String sError
   315
   316        Get phCurrentKey To hKey
   317        Move (RegQueryValueEx(hKey, ToAnsi(sValueName), 0, 0, aValueData, AddressOf(iDataLength))) To iError
   318        If iError Begin
   319            Move (FormatWinError(iError)) To sError // raise an error if the Query failed
   320            Error DFERR_REGISTRY sError // Generic Windows Error
   321        End
   322
   323        Function_Return (iDataLength >0)
   324    End_Function
   325
   326
   327    // Private....
   328    
   329    Function GetBaseKey Returns Handle
   330        Handle hBaseKey
   331        If (phCurrentKey(self) = 0)  Get phRootKey To hBaseKey
   332        Else Get phCurrentKey To hBaseKey
   333
   334        Function_Return hBaseKey
   335    End_Function
   336
   337    
   338    Function GetKey String sKeyName Returns Handle
   339        Handle hKeyOpened
   340        Integer iError
   341
   342        MOve 0 To hKeyOpened // initialize so we can get its address
   343
   344        Move (RegOpenKeyEx(GetBaseKey(self), ToAnsi(sKeyName), 0, pfAccessRights(self), AddressOf(hKeyOpened))) To iError
   345
   346        If (iError =0) Function_Return hKeyOpened
   347        Else           Function_Return 0
   348    End_Function
   349
   350    // Public
   351    Function KeyExists String sKeyName Returns Boolean
   352        Handle hKey
   353        Integer iVoid
   354
   355        Get GetKey sKeyName To hKey
   356        If hKey Move (RegCloseKey(hKey)) To iVoid
   357        Function_Return (hKey <>0)
   358    End_Function
   359
   360    Function ValueExists String sValueName Returns Boolean
   361        // Determines whether a Value exists for the currently-opened Key.
   362        Integer iError
   363        Dword dwDataType
   364        Move 0 To dwDataType // must initialize the variable to get its address
   365
   366        Move (RegQueryValueEx(phCurrentKey(self), ToAnsi(sValueName), 0, AddressOf(dwDataType), 0, 0)) To iError
   367
   368        Function_Return (iError=0)
   369    End_Function
   370
   371    Function DeleteKey String sKeyName Returns Boolean // Deleted successfully?
   372        Function_Return (ShDeleteKey(phRootKey(self), ToAnsi(sKeyName)) =0)
   373    End_Function
   374
   375    Function DeleteValue String sValueName Returns Boolean // Deleted successfully?
   376        Function_Return (RegDeleteValue(phCurrentKey(self), ToAnsi(sValueName)) =0)
   377    End_Function
   378
   379    Function GetSubkeys Handle hoArray Returns Integer // count of Values
   380        Integer iError
   381        Integer icValue iLongestSubkey
   382        Handle hKey
   383        DWord dwSubkeyNameLength
   384        String sSubkeyName sFileTime
   385        Pointer lpsSubkeyName lpsFileTime
   386
   387        Get LongestSubkeyLength To iLongestSubkey
   388        Move (Repeat(character(0), iLongestSubkey +1)) To sSubkeyName
   389        GetAddress of sSubkeyName To lpsSubkeyName
   390
   391        ZeroType tFileTime To sFileTime
   392        GetAddress of sFileTime To lpsFileTime
   393
   394        Get phCurrentKey To hKey
   395        Repeat
   396            Move (iLongestSubkey +1) To dwSubkeyNameLength
   397
   398            Move (RegEnumKeyEx(hKey, icValue, lpsSubkeyName, AddressOf(dwSubkeyNameLength), 0, 0, 0, lpsFileTime)) To iError
   399            If (iError =0) Begin
   400                Increment icValue
   401                Set Value of hoArray (Item_Count(hoArray)) To (ToOem(CString(sSubkeyName)))
   402            End
   403        Until (iError)
   404        Function_Return icValue
   405
   406    End_Function
   407
   408    Function GetValues Handle hoArray Returns Integer // count of Values
   409        Integer iError
   410        Integer icValue iLongestValue
   411        Handle hKey
   412        DWord dwValueNameLength
   413        String sValueName sValueNameSize
   414        Pointer lpsValueName
   415
   416        Get LongestValueLength To iLongestValue
   417        Move (Repeat(character(0), iLongestValue +1)) To sValueName
   418        GetAddress of sValueName To lpsValueName
   419
   420        Get phCurrentKey To hKey
   421        Repeat
   422            Move (iLongestValue +1) To dwValueNameLength
   423            Move (RegEnumValue(hKey, icValue, lpsValueName, AddressOf(dwValueNameLength), 0, 0, 0, 0)) To iError
   424            If (iError =0) Begin
   425                Increment icValue
   426                Set Value of hoArray (Item_Count(hoArray)) To (ToOem(CString(sValueName)))
   427            End
   428        Until (iError)
   429        Function_Return icValue
   430
   431    End_Function
   432
   433End_Class