<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Hacker News: marcprux</title><link>https://news.ycombinator.com/user?id=marcprux</link><description>Hacker News RSS</description><docs>https://hnrss.org/</docs><generator>hnrss v2.1.1</generator><lastBuildDate>Wed, 15 Apr 2026 06:17:24 +0000</lastBuildDate><atom:link href="https://hnrss.org/user?id=marcprux" rel="self" type="application/rss+xml"></atom:link><item><title><![CDATA[New comment by marcprux in "Android Developer Verification"]]></title><description><![CDATA[
<p>Perhaps. And yet … 98% opposition from 4K respondents? I'd be very surprised to see any other poll that tilts the other way, regardless of sampling bias.</p>
]]></description><pubDate>Tue, 31 Mar 2026 01:50:22 +0000</pubDate><link>https://news.ycombinator.com/item?id=47581855</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=47581855</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47581855</guid></item><item><title><![CDATA[New comment by marcprux in "Android Developer Verification"]]></title><description><![CDATA[
<p>I am part of the team running keepandroidopen.org and corralling the signatures for the open letter opposing this program. We've been trying to get Google to reverse course on this program ever since it was announced.<p>As it stands, Android Developer Verification (ADV) is a death sentence for F-Droid, Obtainium, and other competitors to the Google Play Store, both commercial and non-commercial. We are disappointed that they are still trying to steamroll this through in the face of overwhelming public opposition.<p>There are numerous reasons to object to the program, but a few of the top ones are:<p>1. You own your computer, and you should be the sole decision-maker for what software you can install on it.<p>2. "Malware" means whatever Google says it means, and their terms and conditions change daily; today malware is banking scams, tomorrow it is … ad-blocking? VPNs? Their decisions are un-reviewable and opaque, and they have obvious commercial incentives to block certain kinds of (otherwise-legal) software.<p>3. Centralizing global developer registrations through a US corporation makes it subject to the rules (and whims) of the current regime. Citizens of sanctioned countries or members of sanctioned entities (like the International Criminal Court) will be legally barred from registering, blocking them from creating and distributing software _anywhere_ in the world (not just the US).<p>4. Scenarios that Google claims ADV will protect against — such as high-pressure phone calls manipulating vulnerable users into installing scam apps — have _already_ been addressed by incremental improvements to Android security over the years, such as "Enhanced Fraud Protection" introduced in Android 13 (and expanded in Android 15). Android has incrementally improved its security features over its near 20 years of existence. There is no evidence that anything has suddenly changed to justify such a disproportionate and extreme lockdown.<p>5. Being required to <i>pay</i> Google for the privilege of uploading your government identification so that you might be permitted to contribute to the Android software ecosystem is such an abominable insult to the developers that helped build the platform. It deserves all the utter contempt that has been heaped upon it thus far, and begs regulatory scrutiny from those few countries that still have the courage to stand up to these bullies.<p>We emphatically recommend against developers signing up for this program or endorsing it in any way.</p>
]]></description><pubDate>Tue, 31 Mar 2026 01:25:44 +0000</pubDate><link>https://news.ycombinator.com/item?id=47581707</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=47581707</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47581707</guid></item><item><title><![CDATA[New comment by marcprux in "Android Developer Verification"]]></title><description><![CDATA[
<p>> What % of Android users actually want this? Do they know or care?<p>2%, according to the keepandroidopen.org poll[^1]<p>[^1] <a href="https://techhub.social/@keepandroidopen/116251892296272830" rel="nofollow">https://techhub.social/@keepandroidopen/116251892296272830</a></p>
]]></description><pubDate>Tue, 31 Mar 2026 00:35:48 +0000</pubDate><link>https://news.ycombinator.com/item?id=47581420</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=47581420</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47581420</guid></item><item><title><![CDATA[New comment by marcprux in "Swift 6.3"]]></title><description><![CDATA[
<p>And also Android[1]!<p>[1] <a href="https://swiftpackageindex.com/search?query=platform%3Aandroid" rel="nofollow">https://swiftpackageindex.com/search?query=platform%3Aandroi...</a></p>
]]></description><pubDate>Thu, 26 Mar 2026 17:16:06 +0000</pubDate><link>https://news.ycombinator.com/item?id=47533085</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=47533085</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47533085</guid></item><item><title><![CDATA[New comment by marcprux in "Swift 6.3"]]></title><description><![CDATA[
<p>> There are still challenges with basics like compression<p>FWIW, there is an active discussion on this very topic: <a href="https://forums.swift.org/t/proposal-compression-library/85413" rel="nofollow">https://forums.swift.org/t/proposal-compression-library/8541...</a></p>
]]></description><pubDate>Thu, 26 Mar 2026 17:15:03 +0000</pubDate><link>https://news.ycombinator.com/item?id=47533072</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=47533072</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47533072</guid></item><item><title><![CDATA[New comment by marcprux in "Open Letter to Google on Mandatory Developer Registration for App Distribution"]]></title><description><![CDATA[
<p>I am the author of the letter and the coordinator of the signatories. We aren't saying "nuh uh, everything's fine as it is." Rather, we are pointing out that Android has progressively been enhanced over the years to make it more secure and to address emerging new threat models.<p>For example, the "Restricted Settings"¹ feature (introduced in Android 13 and expanded in Android 14) addresses the specific scam technique of coaching someone over the phone to allow the installation of a downloaded APK. "Enhanced Confirmation Mode"², introduced in Android 15, adds furthers protection against potentially malicious apps modifying system settings. These were all designed and rolled out with specified threat models in mind, and all evidence points to them working fairly well.<p>For Google to suddenly abandon these iterative security improvements and unilaterally decide to lock-down Android wholesale is a jarring disconnect from their work to date. Malware has always been with us, and always will be: both inside the Play Store and outside it. Google has presented no evidence to indicate that something has suddenly changed to justify this extreme measure. That's what we mean by "Existing Measures Are Sufficient".<p>[^1]: <a href="https://support.google.com/android/answer/12623953" rel="nofollow">https://support.google.com/android/answer/12623953</a><p>[^2]: <a href="https://android.googlesource.com/platform/prebuilts/fullsdk/sources/+/refs/heads/androidx-xr-arcore-release/android-35/android/app/ecm/EnhancedConfirmationManager.java" rel="nofollow">https://android.googlesource.com/platform/prebuilts/fullsdk/...</a></p>
]]></description><pubDate>Tue, 24 Feb 2026 19:06:56 +0000</pubDate><link>https://news.ycombinator.com/item?id=47141217</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=47141217</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47141217</guid></item><item><title><![CDATA[Ask HN: How to combat Android malware without mandatory developer verification?]]></title><description><![CDATA[
<p>In August 2025, Google announced that starting in late 2026, they are going to lock down Android to require that all app developers register centrally with Google or else their apps will be blocked from being installed on Android certified devices, regardless of how the app is distributed (competing app stores, direct download, etc). This measure is allegedly to combat malware and slow the ability of repeat offenders to simply re-build and re-sign apps that have been blocked by Google Play Protect.<p>There is a lot of opposition to this effort (e.g., keepandroidopen.org, which I organize) along with widespread distrust of the claimed motives for the program. And yet there is indeed a problem with the proliferation of malware in some regions (Southeast Asia being most frequently cited in reporting).<p>Recent advances like "Restricted Settings" in Android 14 and "Enhanced Confirmation Mode" in Android 15 have enacted technical barriers that address many of the most common scam/phishing/malware tactics. What additional technical measures could be implemented that would help protect vulnerable Android users against being victimized? Is a program of increasing awareness about personal security a viable solution? Or is the only solution to lock down the Android platform to require developer registration and verification before an app can be distributed?</p>
<hr>
<p>Comments URL: <a href="https://news.ycombinator.com/item?id=47019921">https://news.ycombinator.com/item?id=47019921</a></p>
<p>Points: 5</p>
<p># Comments: 0</p>
]]></description><pubDate>Sun, 15 Feb 2026 00:35:20 +0000</pubDate><link>https://news.ycombinator.com/item?id=47019921</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=47019921</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47019921</guid></item><item><title><![CDATA[Fear and Loathing in the App Stores]]></title><description><![CDATA[
<p>Article URL: <a href="https://appfair.org/blog/fear-and-loathing-in-the-app-stores/">https://appfair.org/blog/fear-and-loathing-in-the-app-stores/</a></p>
<p>Comments URL: <a href="https://news.ycombinator.com/item?id=46914953">https://news.ycombinator.com/item?id=46914953</a></p>
<p>Points: 1</p>
<p># Comments: 0</p>
]]></description><pubDate>Fri, 06 Feb 2026 16:33:02 +0000</pubDate><link>https://appfair.org/blog/fear-and-loathing-in-the-app-stores/</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46914953</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46914953</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>It really isn't. Did you see their latest time estimate (<a href="https://youtu.be/W4olXg91iX8?t=538" rel="nofollow">https://youtu.be/W4olXg91iX8?t=538</a>)? Late 2026 just to get the widget sets broken out into separate packages? And only <i>then</i> can they start considering modernizing them and trying to mimic the latest UI?<p>Flutter can't even get animations to look and feel right for iOS 18 and below (read through this thread and every other HN/Reddit thread that mentions Flutter vs. native components). Do you really think they'll ever get Liquid Glass looking and feeling convincing, let alone performing acceptably?<p>Read over the 100+ comments in the GH issue I posted. You see actual Flutter contributors — not people who merely vibe-coded a Potemkin L.G. demo and declared victory — saying that it is effectively impossible.</p>
]]></description><pubDate>Thu, 22 Jan 2026 18:26:33 +0000</pubDate><link>https://news.ycombinator.com/item?id=46723203</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46723203</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46723203</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>See my response below on the KMP question: the comparison with CMP mostly applies to Flutter as well.<p>> near-native mobile apps (the difference is almost negligible)<p>Not as of the advent of Liquid Glass on iOS (and, to a lesser extent, Material Expressive on Android). Flutter isn't going to be implementing these new interface conventions[1], and so the UI for these apps are stuck on the last generation and are already starting to feel outdated.<p>Flutter's grim outlook has resulted in a surge of interest in Skip, and it was one of the drivers for us to open up the platform and catch the wave. If you love Dart, or if your apps don't need to look native (e.g., games or very bespoke interfaces), then Flutter might continue to be acceptable. But everyone else is starting to look elsewhere, especially in cases where their business depends on their apps feeling premium and native.<p>[1] <a href="https://github.com/flutter/flutter/issues/170310" rel="nofollow">https://github.com/flutter/flutter/issues/170310</a></p>
]]></description><pubDate>Wed, 21 Jan 2026 20:08:38 +0000</pubDate><link>https://news.ycombinator.com/item?id=46710870</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46710870</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46710870</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>No, you can configure it to just build and launch for iOS or Android separately. But we do recommend iterating on both in parallel for most of the UI work, just to make sure that everything stays in sync.<p>For framework/library development, you can of course build and test separately for each platform.</p>
]]></description><pubDate>Wed, 21 Jan 2026 19:56:26 +0000</pubDate><link>https://news.ycombinator.com/item?id=46710715</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46710715</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46710715</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>This is indeed a dilemma, but note that copyleft licenses like GPL or MPL do give you considerably more protection than a pushover license like MIT/BSD. I wrote about this last year at <a href="https://appfair.org/blog/gpl-and-the-app-stores" rel="nofollow">https://appfair.org/blog/gpl-and-the-app-stores</a>.</p>
]]></description><pubDate>Wed, 21 Jan 2026 19:50:48 +0000</pubDate><link>https://news.ycombinator.com/item?id=46710651</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46710651</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46710651</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>Good question. I'll try to answer as objectively as possible, despite my bias towards Skip's approach.<p>Kotlin Multiplatform (KMP) enables you to target different platforms with your Kotlin. In the context of mobile apps, it allows you to compile your Kotlin to a native framework for iOS, so you can reuse your business logic. On iOS, the Kotlin is running in its own little garbage-collected runtime, but it sets up a bridge to Objective-C and Swift, so the iOS developers can communicate with it from their apps (the interface of which will typically be written separately for each platform). It is neat technology, and Skip integrates with it[1]. We were on their Talking Kotlin podcast in 2024 talking about it[2].<p>When targeting just the shared business logic and not the UI, Skip is, in some ways, the inverse of KMP: whereas they let you share Kotlin logic between the iOS and Android app, Skip lets you share the Swift logic. Skip operates in two different modes[3]: Skip Lite and Skip Fuse. Skip Lite is the original version of Skip, and transpiles your Swift into Kotlin. Skip Fuse is a later iteration and resulted from the formation of the Swift Android workgroup[4], of which we are founding members. In both modes, you can share your Skip business logic layer between multiple apps, and this is a popular application of Skip (e.g., see this talk at NSSpain[5]).<p>So that's the story for shared logic. Now onto the user interface part:<p>While I mentioned that Skip _can_ be used just for sharing business logic, it really shines when you build your whole app with it. You write your app in conventional SwiftUI, and Skip will translate it into the equivalent Jetpack Compose (which is now Android's official recommended way to build apps). Launching your app from Xcode will bring up both your iOS app in the simulator, and the equivalent Android app in the emulator. It is designed to be a single vertically-integrated app creation solution, and enables a single team (or a single developer) to iterate on both platforms at the same time, without any of the coordination overhead of building two separate apps for the two platforms.<p>KMP itself doesn't have an equivalent, but it does have a sibling project "Compose Multiplatform" (CMP), which is built on top of KMP and sort of does the opposite: it lets you write your app in Kotlin and Jetpack Compose and run it on iOS. But the way that it achieves this is different from Skip's approach: it doesn't use native controls on iOS, but instead paints pixels on the screen that mimic the native iOS UI (à la Flutter). The results are predictable: an uncanny valley UI that doesn't feel _quite_ right, and that struggles to keep up with the platform conventions. Notably, like Flutter, they won't be able to support Liquid Glass in any convincing form, and so apps built with it are going to be stuck on outdated iOS UI conventions. In short: CMP is native on Android but alien on iOS, whereas Skip is native on both platforms.<p>That's our take on the difference between the two. In fairness to KMP, they do have some distinct advantages in terms of reach: whereas Skip is squarely focused on just mobile platforms, KMP can target desktops and the web as well. If that is a priority for you, or you already have a lot of Kotlin experience or are invested in the ecosystem, then KMP might be a good fit for your needs. But if you like Swift and SwiftUI, and are happy working with the Apple developer tools, then you should give Skip a try. It really is magic.<p>[1]: <a href="https://skip.dev/blog/skip-and-kotlin-multiplatform/" rel="nofollow">https://skip.dev/blog/skip-and-kotlin-multiplatform/</a><p>[2]: <a href="https://talkingkotlin.com/going-from-swift-to-kotlin-with-skip/" rel="nofollow">https://talkingkotlin.com/going-from-swift-to-kotlin-with-sk...</a><p>[3]: <a href="https://skip.dev/docs/modes/" rel="nofollow">https://skip.dev/docs/modes/</a><p>[4]: <a href="https://www.swift.org/android-workgroup/" rel="nofollow">https://www.swift.org/android-workgroup/</a><p>[5]: <a href="https://www.youtube.com/watch?v=EIGl6GOo210" rel="nofollow">https://www.youtube.com/watch?v=EIGl6GOo210</a></p>
]]></description><pubDate>Wed, 21 Jan 2026 19:41:36 +0000</pubDate><link>https://news.ycombinator.com/item?id=46710519</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46710519</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46710519</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>Yes, as I just responded there, Skip uses the native toolkits and conventions on both platforms: SwiftUI on iOS and Jetpack Compose on Android. So you automatically get the platforms' built-in accessibility support.<p>You can see a sample snippet at <a href="https://skip.dev/docs/components/accessibility/" rel="nofollow">https://skip.dev/docs/components/accessibility/</a></p>
]]></description><pubDate>Wed, 21 Jan 2026 19:04:36 +0000</pubDate><link>https://news.ycombinator.com/item?id=46709993</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46709993</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46709993</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>Yes, the unique benefit of Skip is that you are using the real native toolkits on <i>both</i> platforms. So you get both SwiftUI's accessibility support via VoiceOver, as well as Jetpack Compose's support via TalkBack.</p>
]]></description><pubDate>Wed, 21 Jan 2026 19:01:39 +0000</pubDate><link>https://news.ycombinator.com/item?id=46709954</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46709954</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46709954</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>Thanks! It has been a long time coming.<p>As we mentioned in the post, developer tools really need to be freely obtainable in order to gain mass adoption. In that sense, it was an easy strategic decision. And we felt that the time was right, given that Skip's benefits are being thrust to the foreground in light of recent developments.</p>
]]></description><pubDate>Wed, 21 Jan 2026 18:14:35 +0000</pubDate><link>https://news.ycombinator.com/item?id=46709321</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46709321</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46709321</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>Well, you're running both the iOS development tools (Xcode, iOS Simulator), plus the Android development tools (Gradle, Android emulator, and maybe Android Studio too). These add up.<p>16GB might be possible, though.<p>(Skip itself doesn't take much memory. If you run it headlessly as a SwiftPM plugin, you wouldn't need nearly that much.)</p>
]]></description><pubDate>Wed, 21 Jan 2026 18:10:42 +0000</pubDate><link>https://news.ycombinator.com/item?id=46709262</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46709262</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46709262</guid></item><item><title><![CDATA[New comment by marcprux in "Skip is now free and open source"]]></title><description><![CDATA[
<p>The Xcode build plugin in the /skip repo uses the binary created by /skipstone (which is the repository that was just opened).<p>Thanks for pointing out that the /skip repo itself doesn't have a license. We'll fix that asap!</p>
]]></description><pubDate>Wed, 21 Jan 2026 16:59:51 +0000</pubDate><link>https://news.ycombinator.com/item?id=46708302</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=46708302</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46708302</guid></item><item><title><![CDATA[New comment by marcprux in "Homebrew no longer allows bypassing Gatekeeper for unsigned/unnotarized software"]]></title><description><![CDATA[
<p>You can make your own tap (which is just a GitHub repo) and manually clear the quarantine flag in a postflight step. E.g., see <a href="https://github.com/alacritty/alacritty/issues/8749" rel="nofollow">https://github.com/alacritty/alacritty/issues/8749</a><p>Users will need to `brew install myorg/mytap/appname` instead of just `brew install appname`, but I think that's the only real option at this point.</p>
]]></description><pubDate>Fri, 14 Nov 2025 00:29:18 +0000</pubDate><link>https://news.ycombinator.com/item?id=45922494</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=45922494</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=45922494</guid></item><item><title><![CDATA[New comment by marcprux in "A theoretical way to circumvent Android developer verification"]]></title><description><![CDATA[
<p>This is a neat hack, and I don't want to diminish the effort. But I fear that any such loader apk would be marked as malware by Google and nuked by Play Protect Services.<p>And as others mention, using adb (or Shizuku) might also be a workaround for tech-savvy users (for the time being). We list some other potential temporary workarounds at <a href="https://keepandroidopen.org" rel="nofollow">https://keepandroidopen.org</a>. But none of it is viable for the other 99%.<p>There's really no solution to the dilemma other than stopping Google from implementing it altogether. And for that, we need regulatory action — which means we need to advocate and educate consumers and lawmakers about the threat that this poses.</p>
]]></description><pubDate>Sun, 02 Nov 2025 17:30:04 +0000</pubDate><link>https://news.ycombinator.com/item?id=45791926</link><dc:creator>marcprux</dc:creator><comments>https://news.ycombinator.com/item?id=45791926</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=45791926</guid></item></channel></rss>