Skip to content

Latest commit

 

History

History
76 lines (50 loc) · 3.47 KB

README-Palace.md

File metadata and controls

76 lines (50 loc) · 3.47 KB

Palace Build License

The Palace Project

This repository contains the client-side code for The Palace Project Palace application.

System Requirements

  • Install Xcode 14.2 in /Applications, open it and make sure to install additional components if it asks you.
  • Install Carthage if you haven't already. Using brew is recommended.

If you run this project with DRM support on a Mac computer with Apple Silicon, make sure to check [x] Open using Rosetta in Xcode.app application info. This is required to build with Adobe DRM support.

Building without Adobe DRM nor Private Repos

git clone git@github.com:ThePalaceProject/ios-core.git
cd ios-core

# one-time set-up
./scripts/setup-repo-nodrm.sh

# idempotent script to rebuild all dependencies
./scripts/build-3rd-party-dependencies.sh --no-private

Open Palace.xcodeproj and build the Palace-noDRM target.

At this point you may have seemingly random build errors especially if you are not using an intel chip but the following steps might help:

ln -s $(which carthage) /usr/local/bin/carthage Remove all files under ~/Library/Developer/Xcode/DerivedData/* ⇧⌘K Clean Build Folder

Building With Adobe DRM

Building the Application from Scratch

  1. Contact project lead and ensure you have access to all the required private repos.
  2. Then run:
git clone git@github.com:ThePalaceProject/ios-core.git
cd ios-core
./scripts/bootstrap-drm.sh
  1. Open Palace.xcodeproj and build the Palace target.

Building Dependencies Individually

Unless the DRM dependencies change (which is very seldom) you shouldn't need to run the bootstrap-drm.sh script more than once.

Other 3rd party dependencies are managed via Carthage and a few git submodules. To rebuild them you can use the following idempotent script:

cd ios-core
./scripts/build-3rd-party-dependencies.sh

The scripts directory contains a number of other scripts to build dependencies more granularly and also to build/archive/test the app from the command line. These scripts are the same used by our CI system. All these scripts must be run from the root of Palace ios-core repository, not from the scripts directory.

Branching and CI

develop is the main development branch.

Release branch names follow the convention: release/palace/<version>. For example, release/palace/1.0.0.

Feature branch names (for features whose development is a month or more): feature/<feature-name>, e.g. feature/my-new-screen.

Continuous integration is enabled on merge events on develop branch. Palace device builds are uploaded to ios-binaries.

Palace License

Copyright © 2021 LYRASIS

Licensed under the Apache License, Version 2.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.