ios-swift
SKILL.md
ios-swift
Purpose
This skill equips the AI to assist with Swift-based iOS development, focusing on UIKit and SwiftUI fundamentals, concurrency patterns, and Xcode project management for efficient app building.
When to Use
- When generating code for iOS UI components, such as creating views in UIKit or SwiftUI.
- For handling asynchronous operations in iOS apps, like network requests or timers.
- When structuring or modifying Xcode projects, including targets and schemes for multi-app configurations.
- In debugging scenarios involving Swift errors or Xcode build issues.
Key Capabilities
- Generate UIKit code for basic views: e.g., creating a UIViewController subclass with lifecycle methods.
- Build SwiftUI interfaces: e.g., defining structs that conform to the View protocol for declarative layouts.
- Implement Swift concurrency: using async/await for tasks like API calls, ensuring thread safety.
- Manage Xcode structures: defining targets for app extensions, schemes for build configurations, and handling project files like .xcodeproj.
Usage Patterns
- Start by importing necessary frameworks: always begin Swift files with
import UIKitorimport SwiftUI. - For concurrency, wrap blocking operations in async functions: define a function as
func fetchData() async -> Data { ... }and call it viaTask { await fetchData() }. - When working with Xcode, reference project files directly: use paths like
./MyApp.xcodeprojand specify targets in commands. - Integrate patterns sequentially: first set up a project structure, then add UI elements, and finally handle concurrency to avoid deadlocks.
Common Commands/API
- Xcode CLI: Use
xcodebuild -workspace MyWorkspace.xcworkspace -scheme MyScheme -configuration Debug buildto compile a project; add-sdk iphonesimulatorfor simulator testing. - SwiftUI API: Create a basic view with
struct MyView: View { var body: some View { Text("Hello").padding() } }; render it in an app entry point. - UIKit API: Initialize a view controller like
let vc = UIViewController(); vc.view.backgroundColor = .white; present(vc, animated: true). - Code snippet for concurrency:
func loadImage() async throws -> UIImage { let data = try await URLSession.shared.data(from: URL(string: "https://example.com/image")!) return UIImage(data: data.0) ?? UIImage() } - Config formats: Edit Xcode schemes via the GUI or .pbxproj files; for example, add a build setting in the scheme editor like "GCC_PREPROCESSOR_DEFINITIONS = DEBUG=1".
Integration Notes
- Require Xcode installation; check for it via
xcode-select -pand set $XCODE_PATH environment variable if custom (e.g., export XCODE_PATH=/Applications/Xcode.app). - For Apple services like App Store Connect, use $APPLE_API_KEY for authentication in scripts: e.g., pass it to tools via
altool --upload-app -f myapp.ipa -u user@email.com -p $APPLE_API_KEY. - Integrate with other tools: Use Swift Package Manager by adding dependencies in Package.swift, like
.package(url: "https://github.com/apple/swift-algorithms", from: "1.0.0"). - For testing, link to iOS simulators: Specify device in commands like
xcodebuild test -scheme MyScheme -destination 'platform=iOS Simulator,name=iPhone 14'.
Error Handling
- In Swift, use try-catch for throwable errors:
do { let data = try await fetchData() } catch let error { print("Error: \(error.localizedDescription)") }to handle async failures. - For Xcode builds, parse output from
xcodebuildfor common errors: e.g., if "Code Sign error: No matching provisioning profile found", ensure profiles are set viaxcodebuild -exportArchive -archivePath build/MyApp.xcarchive -exportPath output -exportOptionsPlist ExportOptions.plist. - Check concurrency errors: Use
Taskwith cancellation, likelet task = Task { try await function() }; task.cancel()to avoid leaks. - Debug UI issues: In UIKit, override
viewDidLoadto log errors; in SwiftUI, use.onAppear { print("View appeared") }to trace lifecycle problems.
Concrete Usage Examples
- Create a simple SwiftUI view for an iOS app: First, generate a new Swift file with
struct ContentView: View { var body: some View { VStack { Text("Welcome").font(.title) Button("Tap") { print("Tapped") } } } }; then integrate it into an Xcode project by adding it to the main App struct and building withxcodebuild -scheme MyApp build. - Set up a new target in an existing Xcode project: Use the Xcode GUI to add a target (e.g., App Extension), or script it by editing .xcodeproj/project.pbxproj to add a new PBXNativeTarget entry; then build specifically for that target with
xcodebuild -target MyExtensionTarget -configuration Release.
Graph Relationships
- Related to cluster: mobile (e.g., shares iOS ecosystem knowledge).
- Links to: mobile-android (for cross-platform mobile development), general-swift (for broader Swift language features), ios-testing (for XCTest integration).
Weekly Installs
4
Repository
alphaonedev/ope…aw-graphFirst Seen
7 days ago
Security Audits
Installed on
openclaw4
gemini-cli4
github-copilot4
codex4
kimi-cli4
cursor4