Commit Graph

5838 Commits

Author SHA1 Message Date
unknown
6450e5b2c3 Set some window properties upon creation 2025-06-10 13:17:36 -07:00
Josh Tynjala
3802d51e5c templates: use mobile-web-app-capable in index.html template instead of apple-mobile-web-app-capable
Similar fix to openfl/openfl@8aadc573b7
2025-06-04 13:41:08 -07:00
Josh Tynjala
f4d2965426 Merge branch 'develop' into 8.3.0-Dev 2025-06-04 11:36:03 -07:00
Josh Tynjala
c1f79fbfba actions: use ubuntu-22.04 because GitHub removed ubuntu-20.04 2025-05-05 10:19:03 -07:00
Josh Tynjala
09b6d151ad FileDialog: uses SINGLE_THREADED ThreadPool on all Windows targets to prevent application hang (closes #1946) (references #1849)
Previously, it seemed that only Windows HashLink would hang when opening a FileDialog, but I was able to reproduce #1946 on Windows CPP too. Not sure why I couldn't before because I don't see any obvious changes to FileDialog or ThreadPool that would cause it to happen now, but not when it was affecting HashLink previously.

Does not seem to affect other operating systems.

We might consider going back to BackgroundWorker instead, which we used in Lime 8.1 and older.
2025-05-05 09:47:25 -07:00
Josh Tynjala
bc8f9df60f zlib 1.2.13
Upgrading required to compile with latest Xcode and macOS SDK
2025-04-14 15:28:26 -07:00
Josh Tynjala
97466c6360 png 1.6.46
Upgrading required to compile with latest Xcode and macOS SDK
2025-04-14 15:28:01 -07:00
Josh Tynjala
241edd9d10 efsw 1.4.1
Upgrading required to compile with latest Xcode and macOS SDK
2025-04-14 15:27:24 -07:00
Chris Speciale
aadf0789b1 [ci] use the latest haxelib version 2025-04-10 11:49:27 -04:00
Chris Speciale
236e143a8e [fix] Extract values before locking to avoid deadlock with GC
Attempts to fix reported freezes/crashes related to possible gc contention related to: https://github.com/openfl/lime/issues/1943
2025-04-10 11:20:12 -04:00
Chris Speciale
b10d845ca0 Create MAINTAINERS.md 2025-04-02 10:55:52 -04:00
Barış Yıldırım
12d3ee5916 curl encoding support added 2025-03-21 10:56:23 -04:00
Josh Tynjala
a9f72d65d9 XCodeHelper: if project.xml contains <config:ios device="ipad"/>, default to ipad simulator instead of iphone simulator 2025-03-18 11:10:25 -07:00
Josh Tynjala
9d10e10f5f XCodeHelper: improve selection of default iPhone and iPad simulator
Falls back to any ipad- or iphone- simulator, if necessary
2025-03-18 11:10:25 -07:00
Josh Tynjala
6e869172b1 IOSHelper: use xcrun simctl boot deviceID to ensure that correct device is running
If the simulator was already running with a different device, it might not start the selected device
2025-03-18 11:10:25 -07:00
Josh Tynjala
c6cd26f699 AIRHelper: allow customization of the AIR simulator's screensize and screenDPI 2025-03-18 09:32:01 -07:00
Chris Speciale
63d6deeec3 Merge pull request #1929 from tobil4sk/ci-stable-android-ndk
[ci] Run against stable android ndk
2025-03-16 14:21:29 -04:00
Tobiasz Laskowski
60d10e16fe [ci] Avoid duplicate android artifact upload 2025-03-15 23:21:07 +00:00
Tobiasz Laskowski
cf5c66d889 [ci] Run against stable android ndk 2025-03-15 23:08:11 +00:00
Chris Speciale
844222e99d Merge branch 'develop' into 8.3.0-Dev 2025-03-14 06:53:14 -04:00
Chris Speciale
6f5bc336f3 Merge branch 'develop' into 8.3.0-Dev 2025-03-14 06:47:14 -04:00
Chris Speciale
49a08c6920 Merge pull request #1927 from tobil4sk/android-openal-c++11
Apply -std=c++11 to openal-soft build on android
2025-03-14 06:38:13 -04:00
Tobiasz Laskowski
52072d1f21 Apply -std=c++11 to openal-soft build on android
openal-soft assumes that aligned_alloc is available with c++17. Newer
android ndks set c++17 by default, however they do not expose
aligned_alloc without setting min sdk version to 28.

We can avoid this issue by forcing openal to be compiled with c++11.

Also note, we have HXCPP_CPP11 defined, however, hxcpp ignores this for
the android toolchain.  This means we must set it explicitly

See:
f5e0eef34d/common/almalloc.cpp (L15)
2025-03-14 10:04:25 +00:00
Chris Speciale
1dd2acf479 Merge branch 'develop' into 8.3.0-Dev 2025-03-14 05:30:43 -04:00
Chris Speciale
20c9bec3bc Update Build.xml
Hxcpp doesn't respect HXCPP_CPP11 for android. We can avoid this issue just by adding -std=c++11 here. This resolves a conflict with openal soft 1.20.1 for android builds. This works because the library assumes c++17 and invokes a function that isn't available in android sdk below 28.
2025-03-14 05:29:18 -04:00
Chris Speciale
e41dc949fe Revert "Merge pull request #1924 from tobil4sk/update-openal-1.21.1"
This reverts commit 3f0179657b, reversing
changes made to 80aaaaef9f.
2025-03-14 05:16:24 -04:00
Chris Speciale
ee1d56e864 Android: Revert to sdk 21 as default minimumSdkVersion
Minimum SDK 28 is no longer required to build android after updating openal to 1.21.1. See: https://github.com/openfl/lime/pull/1924

Closes https://github.com/openfl/lime/issues/1923
2025-03-14 01:45:05 -04:00
Chris Speciale
3f0179657b Merge pull request #1924 from tobil4sk/update-openal-1.21.1
Update openal soft to 1.21.1
2025-03-14 01:39:16 -04:00
Tobiasz Laskowski
755781fdf2 Fix mac -stdlib=libstdc++ compilation error
clang: warning: include path for libstdc++ headers not found; pass '-stdlib=libc++' on the command line to use the libc++ standard library instead [-Wstdlibcxx-not-found]
2025-03-13 21:15:45 +00:00
Tobiasz Laskowski
a13b3c37bb Avoid hxcpp overriding openal_soft's c++14 2025-03-13 21:15:34 +00:00
Tobiasz Laskowski
ea2bbd0be3 Update OpenAL Soft to 1.21.1 2025-03-13 21:15:18 +00:00
Chris Speciale
80aaaaef9f Android: Set hard minimum sdk ver for rebuild
Avoids expectations of rebuilding clean which could lead to some confusing situations otherwise.
2025-03-13 08:56:59 -04:00
Chris Speciale
855996e122 Remove PLATFORM from Build.xml
We shouldn't need it anymore following this commit: 46aab0c80e
2025-03-13 05:59:14 -04:00
Chris Speciale
46aab0c80e Android: Allow minimumSDKVersion to be set dynamically
This change moves away from purely hard coding the minimum sdk version for android and also correctly sets the PLATFORM_NUMBER define. The gcc toolchain is no longer compatible in lime 8.3.x+ so, we shouldn't have to worry about the PLATFORM define at all.

It might be wise to enforce a baseline minimum version and complain if users try to use something lower than the default.
2025-03-13 02:24:30 -04:00
Chris Speciale
8d21626297 set PLATFORM to android 28 2025-03-12 18:55:09 -04:00
Chris Speciale
ed8354a86a Update the API level for Android to 28 2025-03-12 18:45:42 -04:00
Chris Speciale
37c9155608 Set minSdkVersion to 28
Should resolve part of the issues related here: https://github.com/openfl/lime/issues/1923#issuecomment-2719250849
2025-03-12 18:26:56 -04:00
Chris Speciale
63b9a88e34 Merge pull request #1921 from tobil4sk/fix/get_glyphs_infinite_loop
Fix Font.getGlyphs returning zeros and looping
2025-03-11 01:34:41 -04:00
Tobiasz Laskowski
23b90dff3f Fix loop in GetGlyphIndices with invalid input
If the text is invalid, then readNextChar returns -1 and does not
progress to the next character. This previously meant that we got stuck
and looped indefinitely.
2025-03-11 01:23:29 +00:00
Tobiasz Laskowski
f495b777ab Remove old comment for hl GetGlyphIndices
The array size is already determined by the first loop
2025-03-11 01:19:58 +00:00
Tobiasz Laskowski
6283017adb Fix GetGlyphIndices returning array of 0 on hl
Previously, the first for loop would reach the end of the characters, so
no further characters were read in the second loop. This meant that the
array remained filled with 0 values.
2025-03-11 01:19:43 +00:00
Josh Tynjala
5488eee50c IOSHelper: comment about how the Platform == 'iOS' filter used by xcrun devicectl includes iPadOS, so there's no need to check for that one separately 2025-03-10 14:58:58 -07:00
Tobiasz Laskowski
70e55b1fa5 Fix rebuild warning about unknown option on msvc
cl : Command line warning D9002 : ignoring unknown option '-std=c11'
2025-03-10 14:20:55 -07:00
Josh Tynjala
6f2f88ca74 IOSHelper: if no iOS device is connected, look for one that is available (paired) and wired (closes #1918)
Consolidate fallback to ios-deploy when Xcode version < 16 and when xcrun devicectl doesn't find any devices
2025-03-10 14:17:20 -07:00
Josh Tynjala
99209da430 IOSHelper: if xcrun devicectl list devices fails, try to fall back to ios-deploy
Devices running iOS 16 and older don't support xcrun devicectl, but they should still work with ios-deploy.
2025-03-10 11:07:15 -07:00
Chris Speciale
4104e9fbd5 Merge pull request #1916 from tobil4sk/fix/hb-add-utf8
Fix utf8 conversions in hb_buffer_add_utf8
2025-03-10 07:04:56 -04:00
Chris Speciale
adf2cf1056 Merge pull request #1917 from tobil4sk/feature/hb-buffer-add-string
Add hb_buffer_add_hxstring
2025-03-10 07:04:40 -04:00
Tobiasz Laskowski
ca770337cb Add hb_buffer_add_hxstring
To properly handle encoding conversions, we need to do it in native
code. This new function performs this role.

This is useful for hxcpp which may have either ascii or utf16 encoding,
but this can only be checked via the native api and it is not possible
on the haxe side.
2025-03-10 02:37:52 +00:00
Tobiasz Laskowski
0ca7c392e0 Fix length for hl_hb_buffer_add_utf8
This function wants the utf8 length, but text->length does not give
this. We can instead use -1 to tell harfbuzz to treat it as null-
terminating, which is the case with all hashlink strings anyway.
2025-03-10 01:45:37 +00:00
Tobiasz Laskowski
504df5e0d0 Add missing utf8 conversion for hb_buffer_add_utf8
A HxString is not guaranteed to be utf8 on hxcpp, so we need to use
hxs_utf8 to convert it otherwise it incorrectly displays any utf16
encoded string.

Unfortunately, hxs_utf8 doesn't give us the length of the utf8 string.
The best thing we can do is to tell harfbuzz it is null terminated. This
isn't perfect because technically hxcpp strings are allowed to contain
NULL, but it's better than all utf16 strings being broken.
2025-03-10 01:17:41 +00:00