summaryrefslogtreecommitdiff
path: root/src/corelib
diff options
context:
space:
mode:
Diffstat (limited to 'src/corelib')
-rw-r--r--src/corelib/x11/fpg_x11.pas72
1 files changed, 72 insertions, 0 deletions
diff --git a/src/corelib/x11/fpg_x11.pas b/src/corelib/x11/fpg_x11.pas
index 4b6b0fe3..6419818c 100644
--- a/src/corelib/x11/fpg_x11.pas
+++ b/src/corelib/x11/fpg_x11.pas
@@ -649,6 +649,71 @@ begin
XSendEvent(xapplication.Display, e.requestor, false, 0, @e );
end;
+function IsTopLevel(AWin: TWindow): Boolean;
+var
+ actualtype: TAtom = None;
+ actualformat: cint;
+ count, remaining: culong;
+ data: pchar = nil;
+begin
+// writeln('IsTopLevel ');
+ XGetWindowProperty(xapplication.Display, AWin, xapplication.xia_wm_state, 0, 0,
+ TBool(False), AnyPropertyType, @actualtype, @actualformat, @count,
+ @remaining, @data);
+ if data <> nil then
+ XFree(data);
+ Result := actualtype <> None;
+end;
+
+function FindWindow(ARoot: TWindow; const x, y: cint): TWindow;
+var
+ wattr: TXWindowAttributes;
+ r, p: TWindow;
+ children: PWindowArray = nil;
+ numch: cuint = 0;
+ i: integer;
+begin
+// writeln('FindWindow ');
+ XGetWindowAttributes(xapplication.Display, ARoot, @wattr);
+ if (wattr.map_state <> IsUnmapped) and
+ ((x >= wattr.x) and (x < (wattr.x + wattr.width))) and
+ ((y >= wattr.y) and (y < (wattr.y + wattr.height))) then
+ begin
+ // mapped and inside, is it a top-level?
+ if (IsTopLevel(ARoot)) then
+ begin
+ Result := ARoot;
+ exit;
+ end;
+// writeln('Query Tree');
+ if XQueryTree(xapplication.Display, ARoot, @r, @p, @children, @numch) <> 0 then
+ begin
+ if (numch > 0) and (children <> nil) then
+ begin
+ r := None;
+ { upon return from XQueryTree, children are listed in the current
+ stacking order, from bottom-most (first) to top-most (last) }
+ for i := numch-1 downto 0 do
+ begin
+ r := FindWindow(children^[i], x - wattr.x, y - wattr.y);
+ if r <> None then
+ break;
+ end;
+
+ XFree(children);
+ if r <> None then
+ begin
+ Result := r;
+ exit;
+ end;
+ Result := ARoot; // a fallback Result - we should never get here though
+ end;
+ end;
+ end
+ else
+ Result := None;
+end;
+
// File utils
function ExtractTargetSymLinkPath(ALink: string): string;
begin
@@ -663,6 +728,13 @@ end;
{ TfpgX11Application }
+procedure TfpgX11Application.SetDrag(const AValue: TfpgX11Drag);
+begin
+ if Assigned(FDrag) then
+ FDrag.Free;
+ FDrag := AValue;
+end;
+
function TfpgX11Application.ConvertShiftState(AState: Cardinal): TShiftState;
begin
Result := [];