Log in
releases

Announcing Tuist 0.10 and its new 'up' command

Learn more about the newest version of Tuist which comes with a powerful and useful feature, a new 'tuist up' command.

I'm pleased to tell you more about the new release of Tuist, 0.10.0, which we have just released. If you work with Xcode-based projects, you might have realized that most of them require you to run a few commands in your system to set it up before start working on the project. Those commands usually install project dependencies, tools like Homebrew, Carthage, Swiftlint... The commands are usually documented in the project README file, and in some cases, automated into a a sort of bootstrap script.

There are several drawbacks with that so common approach:

  • ✅ Those scripts are rarely tested, which means that they can break without you noticing it. It's usually your team next hire the one that stumbles upon the issue and has to fix it.
  • 📚If you have several projects, you end up with duplicated bootstrap logic all over the place.
  • 📦 Moreover, if you jump between projects, you'll find different conventions on how to configure the environment depending on the project.

If you are already using Tuist or plan to use it, we'll make it easier for you. The new version of Tuist comes with a new command tuist up which allows projects define how the environment should be configure in order for the project to work. Handy, isn't it? Let me give you an example.

Let's say that your project depends on swiftlint being available in the system, which can be installed with Homebrew. Traditionally, you'd find something like this in the project README:

1. Clone the repository. 2. Install Homebrew if you don't have it installed. 3. Install swiftlint with `brew install swiftlint`. 4. A Bunch of other steps.

With Tuist we simplify and standardize the process. All you need to know is that there's a command, tuist up that ensures your environment is properly configured to work on the project:

tuist init tuist up tuist generate

In order for Tuist to know what needs to be configured in the environment, projects can now specify a list of up commands:

let project = Project(name: "Downloads", up: [ .homebrew(packages: ["swiftlint"]), .custom(name: "My Tool", meet: "./install-mytool.sh", isMet: "test mytool") ])

There are some predefined commands, like the homebrew's that you can see in the example above, and you can also define custom ones, where you just need to define how the environment gets configured, and how to verify that the environment is properly configured. Although the list of predefined commands is limited, we plan to add more in the future after we validate the feature and get some ideas from you.

Besides adding up, which is an important milestone for Tuist, this version also comes with some minor improvements:

One of Tuist goals is to make convenient the inconvenient and establish good conventions and practices to let developers focus on building their apps. Up is a remarkable step towards that goal and we can't be more excited to have it out there for you to try it out in your projects. I'd like to give credits to my colleagues at Shopify, who came up with the idea of the up command for one of our company-wide internal tools. They are a huge source of inspiration, not only for the up command but for how to design and build tools for developers.

As always, don't hesitate to share your thoughts, feedback, critics and anything that comes to your mind.

Until the next release 👋

You might also like

Shall the Xcode plane land?
Xcode becomes more powerful yet more unreliable as capabilities are added and projects grow. We explore the challenges of scaling development in Xcode and share some thoughts on how Apple could improve the developer experience.
Tuist 0.12.0 supports defining multiple sources and resources
Following users's feedback, we have released a new version of Tuist, 0.12.0 that supports defining multiple sources and resources. Moreover, we added a new product type for those of you that would like to opt for static linking, and added generation of schemes with all the targets that are part of the project. This version also drops support for defining the manifests as a JSON file because Swift will pave our way to a better maintainability and reusability.
Tuist 1.9.0 - Speedy Gonzales
In this blog post we announce the latest version of Tuist, 1.9.0, which introduces significant improvements in the performance of the project generation.

Supercharge your app development

Get started

We use cookies

This site uses cookies. By continuing to use our site, you agree to use of cookies.