The root directory is a typical multi-page app of Vite with Svelte JavaScript project.
The xcode directory is the root of the Xcode project where the Safari extension app is built.
pnpm installpnpm dev
pnpm buildcd ./xcodexcodebuildor build with Xcode App
The Xcode project contains two configurations, which have independent xcconfig configuration files, and can run on your local at the same time without conflicts.
-
Debug: No developer account is required, that isSign to Run Locallyby default, which will speed up the build during development. This is convenient for developers without an account, and contributors who only need to do simple local debugging. -
Release: A developer account is required, which means it can be used for distribution as well as running on real iOS/iPadOS devices. You will need to override your developer account information inxcconfigto complete the build.
All xcconfig files are in the ./xcode/xcconfig/ directory. Each .xcconfig file can be overridden by .dev.xcconfig in the same path, they will be ignored by git, so you can override any build settings locally.
For example, you can create an Userscripts-Release.dev.xcconfig file to override Userscripts-Release.xcconfig and fill in your own developer account information there:
Userscripts-Release.dev.xcconfig
DEVELOPMENT_TEAM = XXXXXXXXXX
Another example, if you want Debug builds to be also signed, so instead of enabling Allow Unsigned Extensions every time in Safari, you can create:
Userscripts-Debug.dev.xcconfig
CODE_SIGN_IDENTITY = Apple Development
DEVELOPMENT_TEAM = XXXXXXXXXX
Note that all existing .xcconfig files already include .dev.xcconfig files of the same name, so they will be applied automatically once you create them. You only need to fill in the setting items that need to be overridden or added.
Userscripts @ 2018-2023
