Skip to content

Commit

Permalink
Fix build against widgetset different from win32
Browse files Browse the repository at this point in the history
  • Loading branch information
salvadorbs committed Jan 5, 2024
1 parent b4f4d75 commit e726b35
Show file tree
Hide file tree
Showing 25 changed files with 76 additions and 528 deletions.
10 changes: 5 additions & 5 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ env:
FPC_URL: 'gitlab'
FPC_BRANCH: 'release_3_2_2'
LAZ_URL: 'gitlab'
LAZ_REVISION_2_4: '5719672f10190551b9af7dd7f1761aae1c280297'
LAZ_REVISION_2_4: 'lazarus_3_0'
LAZ_DIR: 'fpcLaz'
FPCUP_OPT: '' #'--lazopt="-g -gl" --fpcopt="-g -gl"'
VTV_SOURCE: '${{ github.workspace }}/vtv_src'
Expand Down Expand Up @@ -93,8 +93,8 @@ jobs:
- name: Install Dependencies (Ubuntu - only QT5)
if: contains( matrix.os, 'ubuntu') && matrix.build-widgetset == 'qt5'
run: |
wget https://github.com/davidbannon/libqt5pas/releases/download/v1.2.12/libqt5pas1_2.12-3_amd64.deb
wget https://github.com/davidbannon/libqt5pas/releases/download/v1.2.12/libqt5pas-dev_2.12-3_amd64.deb
wget https://github.com/davidbannon/libqt5pas/releases/download/v1.2.15/libqt5pas1_2.15-1_amd64.deb
wget https://github.com/davidbannon/libqt5pas/releases/download/v1.2.15/libqt5pas-dev_2.15-1_amd64.deb
sudo apt-get update
sudo apt-get -m -y install qt5-qmake qtbase5-dev qt5-default libqt5x11extras5-dev libxcb-keysyms1-dev
sudo apt-get -m -y install ./libqt5pas1_2.12-3_amd64.deb
Expand All @@ -103,8 +103,8 @@ jobs:
- name: Install Dependencies (Ubuntu - only QT6)
if: contains( matrix.os, 'ubuntu') && matrix.build-widgetset == 'qt6'
run: |
wget https://github.com/davidbannon/libqt6pas/releases/download/v6.2.5/libqt6pas6_6.2.5-1_amd64.deb
wget https://github.com/davidbannon/libqt6pas/releases/download/v6.2.5/libqt6pas6-dev_6.2.5-1_amd64.deb
wget https://github.com/davidbannon/libqt6pas/releases/download/v6.2.7/libqt6pas6_6.2.7-1_amd64.deb
wget https://github.com/davidbannon/libqt6pas/releases/download/v6.2.7/libqt6pas6-dev_6.2.7-1_amd64.deb
sudo apt-get update
sudo apt-get -m -y install qt6-base-dev libxcb-keysyms1-dev libgl-dev qt6-base-private-dev
sudo apt-get -m -y install ./libqt6pas6_6.2.5-1_amd64.deb
Expand Down
2 changes: 1 addition & 1 deletion Demos/OLE/Main.pas
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
interface

uses
Windows, LCLIntf, {$ifdef lclwin32}ActiveX{$else}FakeActiveX{$endif}, SysUtils, Forms, Dialogs, Graphics, VirtualTrees.BaseTree,
Windows, LCLIntf, {$ifdef lclwin32}ActiveX,{$endif} virtualdragmanager, SysUtils, Forms, Dialogs, Graphics, VirtualTrees.BaseTree,
VirtualTrees, ActnList, ComCtrls, ExtCtrls, StdCtrls, Controls, Classes, Buttons,
LResources, VirtualTrees.Types, VirtualTrees.Header, VirtualTrees.ClipBoard;

Expand Down
2 changes: 1 addition & 1 deletion Demos/dragdrop/fmain.pas
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ interface
uses
Classes, SysUtils, FileUtil, Forms, Controls, Graphics, Dialogs, StdCtrls,
VirtualTrees, VirtualTrees.BaseTree, VirtualTrees.Header, VirtualTrees.Types,
{$ifdef windows}ActiveX{$else}FakeActiveX{$endif};
{$ifdef windows}ActiveX,{$endif} virtualdragmanager;

type

Expand Down
7 changes: 2 additions & 5 deletions Source/VTConfig.inc
Original file line number Diff line number Diff line change
Expand Up @@ -34,17 +34,14 @@

{$define EnableAlphaBlend}

{$ifdef Windows}
{$define EnableWinDataObject}
{$endif}

//Don't enable this because oleacc is not available for FreePascal
{.$define EnableAccessible}

{.$define DelphiStyleServices}

{$if defined(LCLWin32) or defined(LCLWinCE)}
{$if defined(LCLWin32) or defined(LCLWin64) or defined(LCLWinCE)}
{$define LCLWin}
{$define EnableWinDataObject}
{$endif}

//Logging on console
Expand Down
11 changes: 5 additions & 6 deletions Source/VirtualTrees.AncestorLcl.pas
Original file line number Diff line number Diff line change
Expand Up @@ -7,20 +7,19 @@ interface
{$I VTConfig.inc}

uses
Classes, Controls, Graphics, DelphiCompat, Forms, Types, StrUtils,
Classes, Controls, Graphics, DelphiCompat, Forms, Types, StrUtils, LMessages,
OleUtils, Themes,
{$ifdef Windows}
Windows,
ActiveX,
CommCtrl,
UxTheme,
{$else}
FakeActiveX,
{$endif}
{$ifdef EnableAccessible}
oleacc, // for MSAA IAccessible support
{$endif}
VirtualTrees.BaseTree,
virtualdragmanager,
VirtualTrees.Types, LCLType, LCLIntf;

type
Expand All @@ -46,7 +45,7 @@ TVirtualTreeHintWindow = class(THintWindow)
FHintData: TVTHintData;
FTextHeight: TDimension;
procedure CMTextChanged(var Message: TMessage); message CM_TEXTCHANGED;
procedure WMEraseBkgnd(var Message: TWMEraseBkgnd); message WM_ERASEBKGND;
procedure WMEraseBkgnd(var Message: TLMEraseBkgnd); message LM_ERASEBKGND;
strict protected
procedure CreateParams(var Params: TCreateParams); override;
procedure Paint; override;
Expand Down Expand Up @@ -167,7 +166,7 @@ procedure TVirtualTreeHintWindow.CMTextChanged(var Message: TMessage);

//----------------------------------------------------------------------------------------------------------------------

procedure TVirtualTreeHintWindow.WMEraseBkgnd(var Message: TWMEraseBkgnd);
procedure TVirtualTreeHintWindow.WMEraseBkgnd(var Message: TLMEraseBkgnd);

// The control is fully painted by own code so don't erase its background as this causes flickering.

Expand Down Expand Up @@ -486,7 +485,7 @@ function TVirtualTreeHintWindow.IsHintMsg(Msg: TMsg): Boolean;
begin
Result := inherited IsHintMsg(Msg) and HandleAllocated and IsWindowVisible(Handle);
// Avoid that mouse moves over the non-client area or cursor key presses cancel the current hint.
if Result and ((Msg.Message = WM_NCMOUSEMOVE) or ((Msg.Message >= WM_KEYFIRST) and (Msg.Message <= WM_KEYLAST) and (Msg.wparam in [VK_UP, VK_DOWN, VK_LEFT, VK_RIGHT]))) then
if Result and ((Msg.Message = LM_NCMOUSEMOVE) or ((Msg.Message >= LM_KEYFIRST) and (Msg.Message <= LM_KEYLAST) and (Msg.wparam in [VK_UP, VK_DOWN, VK_LEFT, VK_RIGHT]))) then
Result := False;
end;

Expand Down
24 changes: 11 additions & 13 deletions Source/VirtualTrees.BaseAncestorLcl.pas
Original file line number Diff line number Diff line change
Expand Up @@ -7,24 +7,20 @@ interface
{$I VTConfig.inc}

uses
Classes, Controls, Graphics,
Classes, Controls, Graphics, LCLIntf, LCLType, Types,
{$ifdef Windows}
Windows,
ActiveX,
CommCtrl,
UxTheme,
JwaWinAble,
{$else}
FakeActiveX,
{$endif}
DelphiCompat,
{$ifdef EnableAccessible}
oleacc, // for MSAA IAccessible support
{$endif}
VirtualTrees.Types,
LCLIntf,
LCLType,
Types;
virtualdragmanager;

type

Expand All @@ -46,7 +42,9 @@ TVTBaseAncestorLcl = class abstract(TCustomControl)
protected // methods
function DoRenderOLEData(const FormatEtcIn: TFormatEtc; out Medium: TStgMedium; ForClipboard: Boolean): HRESULT; virtual; abstract;
function RenderOLEData(const FormatEtcIn: TFormatEtc; out Medium: TStgMedium; ForClipboard: Boolean): HResult; virtual;
{$ifdef EnableAccessible}
procedure NotifyAccessibleEvent(pEvent: DWord = EVENT_OBJECT_STATECHANGE);
{$endif}
function PrepareDottedBrush(CurrentDottedBrush: TBrush; Bits: Pointer; const BitsLinesCount: Word): TBrush; virtual;
{$IFDEF DelphiStyleServices}
function CreateSystemImageSet(): TImageList;
Expand Down Expand Up @@ -96,11 +94,11 @@ TVTBaseAncestorLcl = class abstract(TCustomControl)
/// <summary>
/// Handle less alias for LCLIntf.SetScrollInfo
/// </summary>
function SetScrollInfo(Bar: Integer; const ScrollInfo: TScrollInfo; Redraw: Boolean): TDimension;
function SetScrollInfo(Bar: Integer; const ScrollInfo: LCLType.TScrollInfo; Redraw: Boolean): TDimension;
/// <summary>
/// Handle less alias for LCLIntf.GetScrollInfo
/// </summary>
function GetScrollInfo(Bar: Integer; var ScrollInfo: TScrollInfo): Boolean;
function GetScrollInfo(Bar: Integer; var ScrollInfo: LCLType.TScrollInfo): Boolean;
/// <summary>
/// Handle less alias for LCLIntf.GetScrollPos
/// </summary>
Expand Down Expand Up @@ -448,13 +446,13 @@ function TVTBaseAncestorLcl.InvalidateRect(lpRect: PRect; bErase: BOOL): BOOL;

//----------------------------------------------------------------------------------------------------------------------

{$ifdef EnableAccessible}
procedure TVTBaseAncestorLcl.NotifyAccessibleEvent(pEvent: DWord = EVENT_OBJECT_STATECHANGE);
begin
{$ifdef EnableAccessible}
begin
if Assigned(AccessibleItem) then
NotifyWinEvent(pEvent, Handle, OBJID_CLIENT, CHILDID_SELF);
{$endif}
end;
{$endif}

//----------------------------------------------------------------------------------------------------------------------

Expand Down Expand Up @@ -501,7 +499,7 @@ function TVTBaseAncestorLcl.SendWM_SETREDRAW(Updating: Boolean): LRESULT;

//----------------------------------------------------------------------------------------------------------------------

function TVTBaseAncestorLcl.SetScrollInfo(Bar: Integer; const ScrollInfo: TScrollInfo; Redraw: Boolean): TDimension;
function TVTBaseAncestorLcl.SetScrollInfo(Bar: Integer; const ScrollInfo: LCLType.TScrollInfo; Redraw: Boolean): TDimension;
begin
Result:= LCLIntf.SetScrollInfo(Handle, Bar, ScrollInfo, Redraw);
end;
Expand All @@ -517,7 +515,7 @@ procedure TVTBaseAncestorLcl.SetWindowTheme(const Theme: string);

//----------------------------------------------------------------------------------------------------------------------

function TVTBaseAncestorLcl.GetScrollInfo(Bar: Integer; var ScrollInfo: TScrollInfo): Boolean;
function TVTBaseAncestorLcl.GetScrollInfo(Bar: Integer; var ScrollInfo: LCLType.TScrollInfo): Boolean;
begin
Result:= LCLIntf.GetScrollInfo(Handle, Bar, ScrollInfo);
end;
Expand Down
21 changes: 15 additions & 6 deletions Source/VirtualTrees.BaseTree.pas
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,6 @@ interface
UxTheme,
Win32Int,
JwaWinAble,
{$else}
FakeActiveX,
{$endif}
OleUtils,
LCLIntf,
Expand All @@ -46,6 +44,7 @@ interface
, VirtualTrees.Classes
, VirtualTrees.Utils
, VirtualTrees.BaseAncestorLcl
, virtualdragmanager
;

var
Expand Down Expand Up @@ -4493,7 +4492,7 @@ procedure TBaseVirtualTree.PrepareBitmaps(NeedButtons, NeedLines: Boolean);
FillBitmap(FSelectedHotMinusBM);
// Weil die selbstgezeichneten Bitmaps sehen im Vcl Style scheiße aus
// Because the self-drawn bitmaps view Vcl Style shit
if Theme = 0 then
if (not VclStyleEnabled) {or (Theme = 0)} then
begin
if not(tsUseExplorerTheme in FStates) then
begin
Expand Down Expand Up @@ -4540,7 +4539,7 @@ procedure TBaseVirtualTree.PrepareBitmaps(NeedButtons, NeedLines: Boolean);
FillBitmap(FPlusBM);
FillBitmap(FHotPlusBM);
FillBitmap(FSelectedHotPlusBM);
if (not VclStyleEnabled) or (Theme = 0) then
if (not VclStyleEnabled) {or (Theme = 0)} then
begin
if not(tsUseExplorerTheme in FStates) then
begin
Expand Down Expand Up @@ -8555,7 +8554,7 @@ procedure TBaseVirtualTree.WMSetCursor(var Message: TLMSetCursor);
end
else
NewCursor := Cursor;
Windows.SetCursor(Screen.Cursors[NewCursor]);
LCLIntf.SetCursor(Screen.Cursors[NewCursor]);
Message.Result := 1;
end
else
Expand Down Expand Up @@ -10427,8 +10426,10 @@ procedure TBaseVirtualTree.DoChecked(Node: PVirtualNode);
begin
if Assigned(FOnChecked) then
FOnChecked(Self, Node);
{$ifdef EnableAccessible}
if (Self.UpdateCount = 0) then // See issue #1174
NotifyAccessibleEvent();
{$endif}
end;

//----------------------------------------------------------------------------------------------------------------------
Expand Down Expand Up @@ -10838,8 +10839,10 @@ procedure TBaseVirtualTree.DoExpanded(Node: PVirtualNode);
begin
if Assigned(FOnExpanded) then
FOnExpanded(Self, Node);
{$ifdef EnableAccessible}
if (Self.UpdateCount = 0) then // See issue #1174
NotifyAccessibleEvent();
{$endif}
end;

//----------------------------------------------------------------------------------------------------------------------
Expand All @@ -10859,12 +10862,14 @@ procedure TBaseVirtualTree.DoFocusChange(Node: PVirtualNode; Column: TColumnInde
begin
if Assigned(FOnFocusChanged) then
FOnFocusChanged(Self, Node, Column);
{$ifdef EnableAccessible}
NotifyAccessibleEvent(EVENT_OBJECT_LOCATIONCHANGE);
NotifyAccessibleEvent(EVENT_OBJECT_NAMECHANGE);
NotifyAccessibleEvent(EVENT_OBJECT_VALUECHANGE);
NotifyAccessibleEvent(EVENT_OBJECT_STATECHANGE);
NotifyAccessibleEvent(EVENT_OBJECT_SELECTION);
NotifyAccessibleEvent(EVENT_OBJECT_FOCUS);
{$endif}
end;

//----------------------------------------------------------------------------------------------------------------------
Expand Down Expand Up @@ -13145,7 +13150,7 @@ procedure TBaseVirtualTree.HandleIncrementalSearch(CharCode: Word);
//---------------------------------------------------------------------------
//todo: reimplement
{$ifndef INCOMPLETE_WINAPI}
function CodePageFromLocale(Language: LCID): Integer;
function CodePageFromLocale(Language: DWord): Integer;

// Determines the code page for a given locale.
// Unfortunately there is no easier way than this, currently.
Expand Down Expand Up @@ -14590,7 +14595,9 @@ procedure TBaseVirtualTree.MainColumnChanged;

begin
DoCancelEdit;
{$ifdef EnableAccessible}
NotifyAccessibleEvent();
{$endif}
end;

//----------------------------------------------------------------------------------------------------------------------
Expand Down Expand Up @@ -17868,7 +17875,9 @@ procedure TBaseVirtualTree.EndUpdate;
Invalidate;
UpdateDesigner;
end;
{$ifdef EnableAccessible}
NotifyAccessibleEvent(); // See issue #1174
{$endif}

DoUpdating(usEnd);
EnsureNodeSelected(False);
Expand Down
16 changes: 8 additions & 8 deletions Source/VirtualTrees.ClipBoard.pas
Original file line number Diff line number Diff line change
Expand Up @@ -35,9 +35,8 @@ interface
{$ifdef Windows}
, ActiveX
, JwaWinUser
{$else}
, FakeActiveX
{$endif}
, virtualdragmanager
;

type
Expand All @@ -47,7 +46,7 @@ TClipboardFormatEntry = record
end;

var
ClipboardDescriptions: array [1..CF_MAX - 1] of TClipboardFormatEntry = (
ClipboardDescriptions: array [1..VirtualTrees.Types.CF_MAX - 1] of TClipboardFormatEntry = (
(ID: CF_TEXT; Description: 'Plain text'), // Do not localize
(ID: CF_BITMAP; Description: 'Windows bitmap'), // Do not localize
(ID: CF_METAFILEPICT; Description: 'Windows metafile'), // Do not localize
Expand All @@ -63,8 +62,10 @@ TClipboardFormatEntry = record
(ID: CF_UNICODETEXT; Description: 'Unicode text'), // Do not localize
(ID: CF_ENHMETAFILE; Description: 'Enhanced metafile image'), // Do not localize
(ID: CF_HDROP; Description: 'File name(s)'), // Do not localize
(ID: CF_LOCALE; Description: 'Locale descriptor'), // Do not localize
(ID: CF_DIBV5; Description: 'DIB image V5') // Do not localize
(ID: CF_LOCALE; Description: 'Locale descriptor') // Do not localize
{
,(ID: CF_DIBV5; Description: 'DIB image V5') // Do not localize
}
);


Expand Down Expand Up @@ -176,8 +177,7 @@ procedure RegisterVTClipboardFormat(AFormat: TClipboardFormat; TreeClass: TVirtu
end
else
begin
GetClipboardFormatName(AFormat, Buffer, Length(Buffer));
TClipboardFormatList.Add(Buffer, TreeClass, Priority, FormatEtc);
TClipboardFormatList.Add(ClipboardFormatToMimeType(AFormat), TreeClass, Priority, FormatEtc);
end;
end;

Expand All @@ -195,7 +195,7 @@ function RegisterVTClipboardFormat(const Description: string; TreeClass: TVirtua
FormatEtc: TFormatEtc;

begin
Result := RegisterClipboardFormat(PChar(Description));
Result := ClipboardRegisterFormat(Description);
FormatEtc.cfFormat := Result;
FormatEtc.ptd := ptd;
FormatEtc.dwAspect := dwAspect;
Expand Down
9 changes: 4 additions & 5 deletions Source/VirtualTrees.DataObject.pas
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,10 @@ interface
Windows,
ActiveX,
JwaWinBase,
{$else}
FakeActiveX,
{$endif}
DelphiCompat
, VirtualTrees.Types;
, VirtualTrees.Types
, virtualdragmanager;

type
// IDataObject.SetData support
Expand Down Expand Up @@ -107,7 +106,7 @@ destructor TVTDataObject.Destroy;
begin
StgMedium := FindInternalStgMedium(FormatEtcArray[I].cfFormat);
if Assigned(StgMedium) then
ReleaseStgMedium(StgMedium^);
ReleaseStgMedium(StgMedium);
end;

FormatEtcArray := nil;
Expand Down Expand Up @@ -499,7 +498,7 @@ function TVTDataObject.SetData(const FormatEtc : TFormatEtc; var Medium : TStgMe
LocalStgMedium := FindInternalStgMedium(FormatEtcArray[Index].cfFormat);
if Assigned(LocalStgMedium) then
begin
ReleaseStgMedium(LocalStgMedium^);
ReleaseStgMedium(LocalStgMedium);
FillChar(LocalStgMedium^, SizeOf(LocalStgMedium^), #0);
end;
end
Expand Down
Loading

0 comments on commit e726b35

Please sign in to comment.