A few weeks ago I announced the xcode 9.2 mode and was rather happy that we can take our time with the migration. Unfortunately, that wasn’t meant to be. Apple will require all new submissions to use xcode 9 within the next few months so it makes no sense to keep 7.3 as the default. This weekend we will flip the switch and builds will default to 9.2.
It’s earlier than we wanted to but it’s crucial that Codename One 4.0 will work well with xcode 9.2 otherwise developers won’t be able to use versioned build halfway through the 4.0 cycle.
As a reminder if you want to still use xcode 7.3 because you are concerned that this change broke something in your code just add the build hint:
ios.xcode_version=7.3
To test xcode 9.2 before the update this weekend just use the build hint:
ios.xcode_version=9.2
For the most part the change should be seamless at this time. I would suggest that you read the original article where I discuss the refined permissions that are now a part of xcode 9. If you run into issues please check that they happen in 9 and not in 7 and file issues immediately!
Multitasking Flag
To support multi-tasking in iPads where we can have a side by side view of the UI we need to use a xib launch file. Unfortunately we just couldn’t nail this correctly for all the use cases so we had to keep the existing screenshot code in place for now.
Regular iOS multitasking will still work as usual this refers only to the iPad split screen support |
If you are willing to compromise on some edge case odd behavior for the launch image in exchange for side by side view you can turn this on explicitly by using the ios.multitasking=true
build hint. Hopefully we’ll be able to refine the xib behavior and turn this on by default for 5.0.
Plugin Update & Release Delay
With the update of the libs this weekend we’ll add a strong nag to people who haven’t updated their plugins. We need to deploy the new update framework as it allows us to solve some problems in very elegant ways.
If you haven’t updated your IDE plugin please do so soon.
We are considering delaying the release that is planned for March 6th by a week or even two. This would give us more time to test these two big changes: update framework & the 9.2 migration.
6 Comments
Does that mean one could use Swift code, too?
Not directly.
The problem is ARC, Swift requires it but it collides with our GC.
You can use swift in a static library and invoke it from a native interface wrapper.
It would be nice to have an example on how to do this
Doing this is not intuitive and most of the sample would be in xcode so would step too deep out of the comfort zone. It won’t produce any benefit either in simplicity, maintainability or performance. If you have a large library of swift code you can use it this way but if you have a large library of swift code you probably know how to do it to begin with an don’t need our help…
I know your attitude but that does not help me further. I tried to use Codename One several years and paid for it – and eventually abandoned.
In an ideal situation I’d love to support Codename One by providing solutions for everyone but the world is not ideal and my situation is not either.
I have about four hours a week for Codename One and yet I can not accept that some things just do not work. Of course it would help if, in exceptional cases and only for me, I could make additions and corrections. Preventing that from happening prevents me from using Codename One – that’s how easy it is.
As I said before, I’m sorry about that. But there are some things we won’t do even for paying customers. Every cross platform tool has its limitations. You want our tool to be both easy and use the build servers. That’s not possible. It’s a Pandoras box that we won’t open.
That has nothing to do with Swift support which is a technical issue related to ARC.