From Free Pascal wiki
Jump to: navigation, search

English (en) | español (es)

fcl-registry is an FCL unit that provides access to the Windows registry.

Registry terms

RootKey: registry hive where you want to start accessing the registry. Examples: HKEY_LOCAL_MACHINE, HKEY_CURRENT_USER

Key: the path to the "directory" that contains individual data. This is a bit counter-intuitive but a holdover from compatibility with earlier versions of the registry.

Name/value: the actual name/value pairs in the Key "directory". Each key can have a default value, whose name is (an empty string.


Example that tries to get a value:

uses ... registry...
  CompileCommand: string='';
  Registry: TRegistry;
  Registry := TRegistry.Create;
    // Navigate to proper "directory":
    Registry.RootKey := HKEY_LOCAL_MACHINE;
    if Registry.OpenKeyReadOnly('\SOFTWARE\Classes\InnoSetupScriptFile\shell\Compile\Command') then
      CompileCommand:=Registry.ReadString(''); //read the value of the default name

Accessing 64 bit and 32 bit registry views

If you have 64 bit Windows, the registry is split up into a 64 bit and 32 bit (compatibility) part. By default, if you run a 32 bit process, you see the 32 bit part; if you run a 64 bit application, you see the 64 bit part.

You can also access the 32 bit part from 64 bit applications and vice versa. From MSDN: http://msdn.microsoft.com/en-us/library/windows/desktop/aa384129%28v=vs.85%29.aspx

  • KEY_WOW64_64KEY: Access a 64-bit key from either a 32-bit or 64-bit application.
  • KEY_WOW64_32KEY: Access a 32-bit key from either a 32-bit or 64-bit application.

These keys are defined in the registry unit so you can just use them: e.g. in the registry object's Access property, like this:

Registry := TRegistry.Create;
  Registry.Access:=Registry.Access or KEY_WOW64_64KEY;

or in the registry.create call, e.g.

TRegistry.Create(KEY_READ or KEY_WOW64_64KEY);

Administrative privileges

Depending on what you want to read/write in the registry, you may need administrator rights and elevation (Windows Vista+). Please see IDE_Window:_Project_Options#Use_manifest_file_to_set_execution_level_.28Windows_only.29

See also

Packages List