Project

pandan

0.01
No commit activity in last 3 years
No release in over 3 years
CLI tool that outputs dependency information from a set of Xcode projects with targets thatdepend on each other, it does it by creating a (reverse) dependency graph and doing abreadth-first search.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

 Project Readme

Pandan

Build Status Gem Version

Pandanus amaryllifolius is a tropical plant in the Pandanus (screwpine) genus, which is commonly known as pandan leaves, and is used widely in South Asian and Southeast Asian cooking as a flavoring.
Wikipedia

pandan is a CLI tool that outputs dependency information from a set of Xcode projects with targets that depend on each other, it does it by creating a (reverse) dependency graph using the information in "Link Binary with Libraries" build phase and doing a breadth-first search.

Installation

pandan is distributed as a Ruby gem and can be installed using the following command:

$ gem install pandan

Motivation

At XING, CocoaPods helped us manage our Objective-C and Swift dependencies for a long time. But as our team grew, it was evident to us that CocoaPods was not the tool we needed anymore. We decided to migrate all our projects to a different setup that uses multiple Xcode projects, targets and xcconfig files under a single workspace. However, we were lacking a tool that would give us dependency information based one the settings already in place in Xcode.

Usage

Given the following project setup:

sample_setup

where additionally to this, SampleFrameworkD links against SampleFrameworkE:

$ pandan query SampleFrameworkB # will output:
SampleFrameworkC
SampleFrameworkE
SampleFrameworkD

You can generate a complete dependency graph of your workspace that is output as a PNG image. It's a good idea to exclude targets with names ending in "Tests" for a more tidy graph:

$ pandan dependency-graph --image --filter='^(?!.*Tests$).*$'

sample_dependencies

For a complete and up-to-date usage description, execute:

$ pandan --help