Understand and Create Custom OptionSet in Swift

Milan Panchal
3 min readJan 31, 2021

--

Swift — OptionSet Type

In this article, we will learn what is OptionSet in Swift and how to create your own custom OptionSet.

What is OptionSet?

  • In Swift, OptionSet is a protocol to represent bitset types, where individual bits represent members of a set.
  • OptionSet is similar to enum, but they are designed to work as a set so we can use multiple values at the same time.
  • As OptionSet confirms to SetAlgebra protocol, we can use methods like intersection, union, contains, isDisjoint and several other methods that you might have used on Set.

As a matter of fact, Swift’s OptionSet protocol is the bridged version of Objective-C's NS_OPTIONS enum.

According to the documentation, there are over 300 types in Apple SDKs that conform to OptionSet

For example, to parse JSON string using JSONSerialization we can provide .prettyPrinted and .sortedKeys as options for the final JSON.

Parse JSON string using JSONSerialization with options

Creating a custom OptionSet type:

Creating our own custom OptionSet is very straightforward. To do this,

  1. Declare a new struct that conforms to the OptionSet protocol.
  2. Define rawValue instance property which must be of a type that conforms to the FixedWidthInteger protocol — it’s normally, Int or UInt8.
  3. Next, create static instances of your struct for all options, where each option should have unique raw value that’s a power of two (1, 2, 4, 8, and so forth) — It’s common to use bit-shifting (<<) operator to avoid mistakes.
  4. Add one or more of those instances as new statics.

To demonstrate this, let’s create a UserAccess struct that defines different level of access of the users like read, write, modify, etc.

All those options need unique raw values, so we’re going to use left bit shifting — 1 << 0, 1 << 1, and so on to avoid mistakes. We can also specify named aliases for specific combinations of values.

Here’s how it looks in Swift:

NOTE: In the above example, we have used UInt8 which uses 8 bits for its storage. Hence we can define max 8 unique options. You may use UInt16 in case you have more options.

Using an OptionSet type:

  • To create an instance of an option set, assign one of the type’s static members to your variable.
  • To create an instance of multiple option set, assign an array literal with multiple static members of the type’s.
  • To create an empty instance, assign an empty array literal ([]) to your variable.

Summary:

For now, we have learned what is OptionSet and how to create our own OptionSet. We saw that we can use OptionSet for storing a finite list of options as a single value instead of an array.

References:

Questions?

Please feel free to comment below, if you have any questions.

If you like this article, feel free to share it with your friends and leave me a comment. Also, click on the 👏 clap button below to show how much you like the article.

Thanks for reading! 👨🏼‍💻

You can find me on:

Twitter | LinkedIn | GitHub | Medium | HackerRank | LeetCode | Stack Overflow

Free

Distraction-free reading. No ads.

Organize your knowledge with lists and highlights.

Tell your story. Find your audience.

Membership

Read member-only stories

Support writers you read most

Earn money for your writing

Listen to audio narrations

Read offline with the Medium app

--

--

Milan Panchal
Milan Panchal

Written by Milan Panchal

iOS Team Lead ǁ Swift ǁ Objective-C ǁ Lifelong Learner ǁ Blogger — Join Medium from the following link: https://medium.com/@milanpanchal24/membership

No responses yet

What are your thoughts?