Post

Replies

Boosts

Views

Activity

Reply to Swift -- how to init a member variable which is a class reference
I'm on the latest beta (3), and it happens with earlier versions too. There are a few example on StackOverflow of people having the same issue. I worked around it by removing the code from my init of A, and calling it explicitly from the init of B (and other places that need to make an A). The issue is that I don't want that code to execute twice, but the compiler seems to want to force me to initialize it in the declaration in B (without access to the argument I need) and then again in the init of B. By making the init of A lightweight, I don't care anymore... but now need a secondary step to ensure it is properly initialized.
Jul ’20
Reply to SwiftUI navigation problem
I have seen this problem several times as well. Usually when clicking on a NavigationLink it goes to the page, and then comes immediately back again. Sometimes twice! A couple of times I had figured out that there was a problem in the view I was navigating to, but with the case I'm seeing today it just seems to happen spontaneously sometimes, but going straight back into the link again works fine.
Aug ’20
Reply to Tracking down the source of mutation causing view updates
Just as an FYI to any readers... my "solution" to this problem was to provide a function on my object (i.e. an instance of a class) which owns the state data (i.e. an instance of a struct). The struct provides 2 functions, a non-mutating one which gets cached data via a key, and a second which is marked mutating. The second one checks the cache and returns the cached data (without modifying state), but if it is not in the cache it computes it and adds it to the cache (thereby modifying state). Only the owning object ever calls these two functions, and it does so from the method it exposes, first trying the non-mutating method and only calling the mutating method if the requested data was not in the cache. This is ugly and inefficient (multiple mutex locks are required), but appears to be forced upon me by the language / framework design. I would like to have a better solution. struct D { 		func get_cached(key: Int) -> ValueType { ... } 		mutating func create_cached(key: Int) -> ValueType { ... }		 // always causes a SwiftUI update } class A { 		var data : D 		func get_value(key: Int) { 				if let value = data.get_cached(key) { 						return value 				} 				else { 						return data.create_cached(key) 				} }
Aug ’20
Reply to Xcode13 beta4, The UI coordinates of the interface have been shifted
Did you ever get any resolution on this? My application (on both iPad and macOS) began exhibiting this sort of severe shifting in both dimensions and it started around a year ago. This has made the app nigh unusable, but I haven't had the time to look into the problem It seems to be affecting many kinds of controls in both windows and model dialogs. Any hints about the source of the problem and potential fix would be greatly appreciated.
Jul ’22