Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Xcode 8 - IB Designables - Failed to render and update auto layout status, The agent crashed

I recently upgraded to Xcode 8 and I am having issues with the Storyboard.

If I open the project and I don't have the Storyboard open, it will compile and run just fine. Once I open up the Storyboard, I get multiple errors about IB Designables as shown below.

enter image description here

These views are the only views that are using custom views from TextFieldEffects and BEMCheckbox that I imported using Cocoapods.

like image 417
Alan Avatar asked Sep 27 '16 18:09

Alan


17 Answers

You can try one of the following to figure out the cause:

  1. look for the IBDesignablesAgentCocoaTouch logs in this directory: ~/Library/Logs/DiagnosticReports and see the cause.

Note: for user with Catalina: look for IBDesignablesAgent-iOS_<DATE>-<MAC_NAME>.crash

  1. Go to the Editor -> Debug Selected View while selecting your @IBDesignable UIView in your storyboard, and see the stack trace.

  2. Delete Derive Data folder.

    Xcode Preference -> Location -> Derived Data
    /Users/YourMacName/Library/Developer/Xcode/DerivedData
    
  3. Clean your project Shift + Command + Alt + K.

  4. Build your project Command + B.

like image 161
Maria Avatar answered Oct 04 '22 09:10

Maria


I solved the problem by doing the following:

  1. Go to File > Workspace settings.
  2. Click the little right arrow beside "Derived data". This opens the Finder app at the location of the DerivedData folder.
  3. Go inside the DerivedData folder, and delete the folder corresponding to your project.
  4. Quit Xcode, and re-open it.
  5. Clean your project shiftcommandk.
  6. build your project commandb.
  7. Open your storyboard.
  8. Go to Editor > Refresh all views.

Updated

Sometimes just directly Go to Editor > Refresh all views worked. If Refresh all views is disabled, quit Xcode and try again.

like image 34
axumnemonic Avatar answered Oct 04 '22 09:10

axumnemonic


I just delete the view that is failed and press command+Z to undo deletion. It works for me.

If editing the failed view later, the error may occur again, do the above again.

like image 38
yancaico Avatar answered Oct 04 '22 09:10

yancaico


I faced this issue in CocoaPod 1.5.0. The solution is to reinstall pod again (pod install again) once this error showing or you may use CocoaPod 1.4.0 instead. It works fine in 1.4.0 (at least for me.)

update:

Add following script in Podfile help me solve the issue in 1.5.0

post_install do |installer|
  installer.pods_project.build_configurations.each do |config|
    config.build_settings.delete('CODE_SIGNING_ALLOWED')
    config.build_settings.delete('CODE_SIGNING_REQUIRED')
  end
end

reference: https://github.com/Skyscanner/SkyFloatingLabelTextField/issues/201#issuecomment-381915911

like image 34
Jerome Li Avatar answered Oct 04 '22 11:10

Jerome Li


Adding following code to my @IBDesignable class did the trick.

override init(frame: CGRect) {
    super.init(frame: frame)
}
like image 43
Mohammad Zaid Pathan Avatar answered Oct 04 '22 11:10

Mohammad Zaid Pathan


If you're using xib file for custom uiview. Try this:

Change from

Bundle.main.loadNibNamed("UserView", owner: self, options: nil)

To:

let bundle = Bundle(for: UserView.self) 
bundle.loadNibNamed("UserView", owner: self, options: nil)
like image 26
Hoàng Công Tùng Avatar answered Oct 04 '22 11:10

Hoàng Công Tùng


For anyone -like me- who can't find that IBDesignablesAgentCocoaTouch file or when trying to 'Debug Selected Views' from the Editor gets an error, here's another way to debug those "Failed to render" errors.

Open the 'Console' app, from the sidebar select your current Mac (it will probably be auto-selected by default) and then on the search bar search for "IBSceneUpdate" and hit enter.

This way, every time you get an Xcode error for an IBDesignable not being able to render, you will also get a new "IBSceneUpdate" entry with more details about the error.

That's at least how I was able to debug my IBDesignable errors!

Console app showing IBSceneUpdate errors

like image 41
Stelabouras Avatar answered Oct 04 '22 09:10

Stelabouras


Try to disable 'Use Trait Variations' (Identity and Type panel) for any xib file that you might have for custom views that are used in your storyboard.

like image 38
LatinCoder Avatar answered Oct 04 '22 11:10

LatinCoder


Correct answer provided by @Maria:

check crash report at ~/Library/Logs/DiagnosticReports

Alternative way:

  1. Open Spotlight

    Enter image description here

  2. Type console.app

    enter image description here

  3. Select Crash reports

    Enter image description here

  4. Check one for IBDesignablesAgent-iOS and review crash log

like image 23
hbk Avatar answered Oct 04 '22 10:10

hbk


My problem was solved by deleting folders (which is related to this project) from the derived data folder.

You can do this by:

  1. Clicking menu FileProject Setting

  2. Click the arrow sign deside /Users/.../Xcode/DerivedData.

  3. Click the DerivedData folder. You will see your project named folders. Delete those.

  4. Quit Xcode and then open your project.

  5. Clean the project by using this step: ProductClean.

  6. Then build the project: ProductBuild

These will resolve these problems.

like image 30
Mitu Vinci Avatar answered Oct 04 '22 11:10

Mitu Vinci


I tried clean and run the project won't solve this issue.

But Close and reopened the project did.

like image 33
Lal Krishna Avatar answered Oct 04 '22 10:10

Lal Krishna


Just open your storyboard -> Editor -> Refresh all views. This work for me.

like image 4
Anggara Siswanajaya Avatar answered Oct 04 '22 10:10

Anggara Siswanajaya


I had the same issue and came here to try and figure out what happened. I noticed the top rated answer and the answer itself didn't help me, as IBDesignable didn't exist in the log folder and I already attempted all other options there, however in the comments I noticed someone talking about a frame init.

I decided to try commenting out my IBDesignable extension for UIView and it instantly fixed the problem. So, to fix this, find the extension causing the issue and make sure to set up the required inits by creating an IBDesignable class and providing the required initializers as follows:

@IBDesignable class RoundedView: UIView {

override init(frame: CGRect) {
    super.init(frame: frame)
    sharedInit()
}

required init?(coder aDecoder: NSCoder) {
    super.init(coder: aDecoder)
    sharedInit()
}

override func prepareForInterfaceBuilder() {
    super.prepareForInterfaceBuilder()
    sharedInit()
}

func sharedInit() {
}
}

IMPORTANT: remember to add the new class to the item you are using the designable on.

like image 4
Nox Avatar answered Oct 04 '22 11:10

Nox


When I debugged this, I found out there are some classes which are modifying the UI. Typically marquelabel which is a subclass of UILabel or any other class subclassing UIView and drawing UI at run time and colliding with Autolayout engine. Try giving a fixed width or height for these custom views. If it doesn't solve your problem try the following solutions:

Solution 1: Uncomment #use_frameworks inside your pod file.

Solution 2: Try deleting derived data

  1. Close the Editor window of your Xcode and quit the simulator
  2. Go to Xcode PreferencesLocations
  3. Click the small grey arrow showing the derived data path
  4. Select your project
  5. Delete all the folders inside
  6. Quit Xcode and reopen
like image 3
Ashish Pisey Avatar answered Oct 04 '22 10:10

Ashish Pisey


In my @IBDesignable class crashed because I used the custom class for the color and forced unwrapped the colours propertied that's @IBDesignable class found nil while unwrap

So you need to find the IBDesignablesAgent-iOS_[Date]_[YourMac].crash on ~/Library/Logs/DiagnosticReports this location and you will get the reason of the crash with the respected file path.

Now you have to check the respected file.

like image 2
Tak Rahul Avatar answered Oct 04 '22 09:10

Tak Rahul


Faced same Error: Had customised UITextField and using interface builder, the error in console was -Use of unimplemented initializer 'init(frame:)' for class "CustomField"

Added the initialiser to fix the error

like image 1
Avinash Avatar answered Oct 04 '22 09:10

Avinash


I faced this problem after update to latest XCode version .After trying multiple solution described above ,i only quite Xcode and then shut down system and turn it on and that worked for me .

like image 1
Mehsam Saeed Avatar answered Oct 04 '22 11:10

Mehsam Saeed