diff options
author | Tor Lillqvist <tml@iki.fi> | 2020-12-05 17:25:30 +0200 |
---|---|---|
committer | Tor Lillqvist <tml@collabora.com> | 2020-12-05 18:29:44 +0100 |
commit | 5bf61e98b0746a4afeb68a80e54b4eb4bf4ea89f (patch) | |
tree | 8176014c03a3d9ba0d9c134f4d9fb6f6d129825c /fpicker | |
parent | 4400f3c46ce838d8ba304205f1d710dd4f9001dc (diff) |
Fix crash or hang on macOS on arm64 when opening a file picker
There is no reason to not mention the NSOpenSavePanelDelegate protocol
that AquaFilePickerDelegate implements.
The way we used objc_msgSend() caused a crash or hang. (I saw both,
depending on whether the code was built for debugging or not). For
some reason we used to cast it to a function with variadic parameters
like:
reinterpret_cast<id (*)(id, SEL, ...)>(objc_msgSend)(
m_pDialog, @selector(setDelegate:), m_pDelegate);
This does not work in arm64 code on macOS. (See
https://developer.apple.com/documentation/apple_silicon/addressing_architectural_differences_in_your_macos_code?language=objc
, the "Don't Redeclare a Function to Have Variable Parameters"
section.)
We could have replaced the ellipsis with the actual type of the first
real parameter in this call, or just "id" would have worked fine. But
it is much simpler to just do what we mean directly:
[m_pDialog setDelegate:m_pDelegate];
I need to look through the code for other places where we have used
objc_msgSend() in a similar fashion.
Change-Id: Ia93b2007ed8f263eaf99d604a3c88e857efbb421
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/107257
Tested-by: Jenkins
Reviewed-by: Tor Lillqvist <tml@collabora.com>
Diffstat (limited to 'fpicker')
-rw-r--r-- | fpicker/source/aqua/AquaFilePickerDelegate.hxx | 2 | ||||
-rw-r--r-- | fpicker/source/aqua/SalAquaFilePicker.mm | 8 |
2 files changed, 2 insertions, 8 deletions
diff --git a/fpicker/source/aqua/AquaFilePickerDelegate.hxx b/fpicker/source/aqua/AquaFilePickerDelegate.hxx index eb7e1ce402e6..fb158cd67633 100644 --- a/fpicker/source/aqua/AquaFilePickerDelegate.hxx +++ b/fpicker/source/aqua/AquaFilePickerDelegate.hxx @@ -27,7 +27,7 @@ class SalAquaFilePicker; class FilterHelper; -@interface AquaFilePickerDelegate : NSObject +@interface AquaFilePickerDelegate : NSObject <NSOpenSavePanelDelegate> { SalAquaFilePicker* filePicker; FilterHelper* filterHelper; diff --git a/fpicker/source/aqua/SalAquaFilePicker.mm b/fpicker/source/aqua/SalAquaFilePicker.mm index 9eca8c5c1a77..3426c9ed4265 100644 --- a/fpicker/source/aqua/SalAquaFilePicker.mm +++ b/fpicker/source/aqua/SalAquaFilePicker.mm @@ -154,13 +154,7 @@ sal_Int16 SAL_CALL SalAquaFilePicker::execute() //Set the delegate to be notified of certain events - // I don't know why, but with gcc 4.2.1, this line results in the warning: - // class 'AquaFilePickerDelegate' does not implement the 'NSOpenSavePanelDelegate' protocol - // So instead of: - // [m_pDialog setDelegate:m_pDelegate]; - // do: - reinterpret_cast<id (*)(id, SEL, ...)>(objc_msgSend)( - m_pDialog, @selector(setDelegate:), m_pDelegate); + [m_pDialog setDelegate:m_pDelegate]; int nStatus = runandwaitforresult(); |