try {

    int result = RegOpenKeyEx(root, keyName, 0, KeyAccess.None, ref hkey);

    if (ERROR_SUCCESS != result) return result;

    byte[] bytes = null;

    uint length = 0;

    KeyType keyType = KeyType.None;

    result = RegQueryValueEx(hkey, valueName, IntPtr.Zero, ref keyType, null,

     ref length);

    bytes = new byte[Marshal.SizeOf(typeof(uint))];

    length = (uint)bytes.Length;

    keyType = KeyType.None;

    result = RegQueryValueEx(hkey, valueName, IntPtr.Zero, ref keyType, bytes,

     ref length);

    if (ERROR_SUCCESS != result) return result;

    dwordResult = BitConverter.ToUInt32(bytes, 0);

    return ERROR_SUCCESS;

   } finally {

    if (UIntPtr.Zero != hkey) {

     RegCloseKey(hkey);

    }

   }

  }

  ///

  /// Удаляет заданный параметр из раздела реестра

  ///

  /// Имя ключа

  /// Имя параметра

  /// В успешном случае возвращается

  /// ERROR_SUCCESS

  public static int DeleteValue(UIntPtr root, string keyName,

   string valueName) {

   UIntPtr hkey = UIntPtr.Zero;

   try {

    int result = RegOpenKeyEx(root, keyName, 0, KeyAccess.None, ref hkey);

    if (ERROR_SUCCESS != result) return result;

    return RegDeleteValue(hkey, valueName);

   } finally {

    if (UIntPtr.Zero != hkey) {

     RegCloseKey(hkey);

    }

   }

  }

  ///

  /// Типы ключей

  ///

  public enum KeyType : uint {

   None = 0,

   String = 1,

   Binary = 3,

   Dword = 4,

  }

  ///

  /// Тип доступа

  ///

  public enum KeyAccess : uint {

   None = 0x0000,

   QueryValue = 0x0001,

   SetValue = 0x0002,

   CreateSubKey = 0x0004,

   EnumerateSubKeys = 0x0008,

   Notify = 0x0010,

   CreateLink = 0x0020

  }

  ///

  /// HKEY_CLASSES_ROOT

  ///

  public static UIntPtr HKCR = new UintPtr(0x80000000);

  ///

  /// HKEY_CURRENT_USER

  ///

  public static UIntPtr HKCU = new UIntPtr(0x80000001);

  ///

  /// HKEY_LOCAL_MACHINE

  ///

  public static UIntPtr HKLM = new UIntPtr(0x80000002);

  ///

  /// HKEY_USERS

  ///

  public static UIntPtr HKU = new UintPtr(0x80000003);

  ///

  /// Возвращаемое значение в случае успеха

  ///

  public const int ERROR_SUCCESS = 0;

  ///

  /// Функция для создания заданного раздела реестра. Если раздел

  /// уже существует, то функция открывает его.

  ///

  /// [in] Дескриптор к открываемому разделу

  /// или одна из ветвей реестра:

  /// HKCR, HKCU, HKLM.

  /// [in] Имя для нового раздела. Данный

  /// раздел должен быть подразделом раздела, определенного в

  /// параметре hKey.

  ///

  /// [in] Зарезервированный параметр.

  /// Установлен равным 0

  /// [in] Имя класса или типа объекта

  /// Данный параметр игнорируется, если раздел уже существует

  ///

  /// [in] Игнорируется; установите

  /// равным 0

  ///

  /// [in] Игнорируется; установите

  /// равным 0

  ///

  /// [in] Установите в NULL.

  ///

  /// [out] Переменная, получаемая от

  /// дескриптора нового или открытого раздела

  /// Если вы больше не нуждаетесь в дескрипторе, то вызовите

Перейти на страницу:

Похожие книги