Getting Started
Basic Actions
Shortcutslang tries to be familiar to read and write. To write an action, put the action name with no spaces and a list of arguments in order.
ActionName "Action" "Arguments"
For example, the text action is named Text and has one field, the text inside it.
Text "This is my text"
Image
data:image/s3,"s3://crabby-images/9ca6b/9ca6b4830ff16292f45bb6c195ad630870b72698" alt=""
Actions shown | Text |
Try making shortcuts
You can convert ScPL to .shortcut on the tryit page. Copy the .shortcut file to your phone through airdrop or iCloud files and open it in Shortcuts.
Argument Labels
More complex actions have multiple fields
GetFile "iCloud Drive" true false
Image
data:image/s3,"s3://crabby-images/f25d8/f25d8bb483702c2dd111f1b2cf4f5277436fa3a1" alt=""
For these actions, you can put labels to know which field is which.
GetFile service="iCloud Drive" showdocumentpicker=true selectmultiple=false
Image
data:image/s3,"s3://crabby-images/f25d8/f25d8bb483702c2dd111f1b2cf4f5277436fa3a1" alt=""
Actions shown | GetFile |
Block Actions
Other actions have blocks, like the if action and choose from menu action
Text "hello"
If "Equals" "hello"
ShowAlert title="Alert!" message="It equals hello"
Otherwise
ShowAlert title="Alert!" message="It does not equal hello"
End If
Image
data:image/s3,"s3://crabby-images/65e61/65e6164ba162cebf03cfeefa9a2284dd106544b3" alt=""
Actions shown | If | ShowAlert | Text |
Variables
Variables are marked with type:
varname. For example, a named variable called Input
would be v:Input
. There are 3 variable types, v
for named variable, mv
for magic variable, and s
for special variables. To use a variable with spaces in the name, surround the name with quotes like v:"Repeat Index"
Using Variables
Variables can be used directly as a field value to an action or they can be put within strings or barlists (more info below).
Text mv:MyMagicVariable
Text "Backslash parenthesis are used to put a variable inside text, like \(v:ThisVariable)."
Image
data:image/s3,"s3://crabby-images/3877d/3877db0d3080c019d6e2d3b880f9d3039709d6f1" alt=""
Text
| The same is used for \(v:Variables) in barlists.
Image
data:image/s3,"s3://crabby-images/29c2e/29c2e60cb2873ef8cef545200581beefde648ebb" alt=""
Actions shown | Text |
Setting Variables
Named variables are set just like how they are in shortcuts, using the SetVariable action. For example,
Text "My text"
SetVariable "MyVariable"
# now you can use it
ShowResult "My text is \(v:MyVariable)"
Image
data:image/s3,"s3://crabby-images/99994/99994f33544aa7e6e7171eaaf14e8e277e8b1521" alt=""
Magic variables are magical and don’t require an action to set. Instead you use the ->
arrow set syntax to say that the action is magical.
Text "My text" -> mv:Magic
# now you can use it
ShowResult "Magic! \(mv:Magic)"
Image
data:image/s3,"s3://crabby-images/72b9b/72b9b4b1cdadaa810f60b1448178d7dccc693568" alt=""
You cannot set special variables, they are special.
Actions shown | Text | ShowResult |
ScPL Comments
ScPL comments can be put in your code like shortcuts comments but they do not output any actions.
# this is a comment
// this is also a comment
-- this is also a comment
Image
This shortcut has no actionsField Types
Shortcuts has many different field types, for each field type there are many ways you can write them in shortcutslang
Text Field
Many actions have text fields of different sizes. The Text action has a multiline text field, and the Save file action has a single line text field to enter a destination path.
Text fields can be used with strings and multiline text fields can also be made with barlists
Text "This is a text field with a string"
Text
| This is a multiline text field using a barlist.
| This is the second line
| This is a variable: \(v:MyVariable)
Image
data:image/s3,"s3://crabby-images/a2897/a28976d8fc8e4bffaf075762870e22c32f71fda0" alt=""
Some text fields do not allow variables, such as the Comment action.
Comment
| This text field does not allow variables
Image
data:image/s3,"s3://crabby-images/46487/464877c1166006a89b4652937a7919f8388c6748" alt=""
Comment
| \(v:Variable) # Not Allowed
Image
This shortcut fails to convertActions shown | Text | Comment |
Enum (Select) Field
An Enum Field has a list of options to choose from, such as the Condition field in if or the operator field in calculate.
Calculate "+" 1
Image
data:image/s3,"s3://crabby-images/365bd/365bd09db5f252754628597a13f3c225eb322075" alt=""
If you enter a value that is not allowed, shortcutslang will throw an error. Unlike action names, enum fields are case and space sensitive and must be exact.
Some enum fields allow variables, and some do not.
Calculate v:Operand 3
Image
data:image/s3,"s3://crabby-images/bfabd/bfabdacfe629f1ca24e753836931c48478b9189e" alt=""
Actions shown | Calculate |
If an enum field does not allow variables, it will error when you try to use a variable.
Enum fields cannot have mixed text and variables, so "\(v:Not) Equals"
is never allowed.
Number Field
Number fields accept a number.
Number 16
Number 29.5
Number -924
Number .8
Number -.2
Image
data:image/s3,"s3://crabby-images/82a14/82a14c676adbba745f170222d0d1df5ec6dc3130" alt=""
Similar to Enum fields, Number fields cannot have mixed text and variables.
Number v:MyVariable
Image
data:image/s3,"s3://crabby-images/3546a/3546ad979cdcf44e5af11839680980df836f374d" alt=""
Number "-\(v:MyVariable)" # Not Allowed
Image
This shortcut fails to convertActions shown | Number |
Stepper Number Fields
Stepper number fields are like number fields but can only have positive integer numbers (no decimals)
Repeat 5
ShowResult "Hi"
End Repeat
Image
data:image/s3,"s3://crabby-images/82278/82278ff5dac05fd205ad552742270651ed079929" alt=""
Repeat 5.5 # Not allowed
ShowResult "Hi"
End Repeat
Image
This shortcut fails to convertActions shown | Repeat |
Slider Number Fields
Slider number fields are like number fields but can only have numbers from 0 to 1
SetBrightness 0.5
Image
data:image/s3,"s3://crabby-images/2a2bc/2a2bc79babfb8c1d4391bcd1f05c6ef963630621" alt=""
SetBrightness 1.1 # Not Allowed
Image
This shortcut fails to convertActions shown | SetBrightness |
Variable Picker Fields
Variable picker fields can have a variable.
GetVariable v:MyVariable
Image
data:image/s3,"s3://crabby-images/bab91/bab911e50281d0ea7010cd92f75f04586d42bd2c" alt=""
GetVariable "MyVariable" # Not Allowed
Image
This shortcut fails to convertActions shown | getvariable |
Switch (or Expanding or Boolean) Fields
Switch fields can have a true or false value. True is on and false is off.
SetWifi true
SetAirplaneMode false
Image
data:image/s3,"s3://crabby-images/b4c74/b4c74326440a49f3f9fb5ce34a341b65bb3d17cf" alt=""
SetWifi yes # Not Allowed, must be true or false
SetAirplaneMode no # Not Allowed, must be true or false
Image
This shortcut fails to convertSome switch fields allow variables
SetWifi v:Wifi
Image
data:image/s3,"s3://crabby-images/2324d/2324dd840a36bd54fb4a612d19d7b87f1b8c38d0" alt=""
Actions shown | SetWifi | List |
Dictionary Field
Dictionary fields are written like JSON
Dictionary{
"key": "value",
"variable": v:myVariable,
"list": ["item 1", "item 2"],
"dictionary": {"key": "value"}
}
Image
data:image/s3,"s3://crabby-images/c1e68/c1e689e68d79d57086bda21e0c6babff853dc2f5" alt=""
Quotes and commas are not required and =
can be used instead of :
if wanted
Dictionary{
key = value
variable = v:myVariable
list = ["item 1", "item 2"]
dictionary = {key = value}
}
Image
data:image/s3,"s3://crabby-images/c1e68/c1e689e68d79d57086bda21e0c6babff853dc2f5" alt=""
Actions shown | Dictionary |
List Field
Lists can be made using json-like []
syntax.
ChooseFromMenu "Pick an item" ["item 1", "item 2"]
case 1
case 2
end menu
Image
data:image/s3,"s3://crabby-images/25da7/25da7e2378bc731177364082cac40c4fc45200a7" alt=""
Similar to dictionaries, lists do not require commas and can span over multiple lines
ChooseFromMenu "Pick an item" [
"item 1"
"item 2"
]
case First
case Second
end menu
Image
data:image/s3,"s3://crabby-images/25da7/25da7e2378bc731177364082cac40c4fc45200a7" alt=""
Lists can also be made using barlists.
List
| My First Item
| My Second Item
Image
data:image/s3,"s3://crabby-images/f60a2/f60a29bfd2a9f77786dc7e0421cf1afacb9663a5" alt=""
Actions shown | ChooseFromMenu | List |
Variable Field
(Different from Variable Picker Fields)
Variable fields is the field used in SetVariable to enter a variable name. They can be made using strings or v: variables.
SetVariable "MyNamedVariable"
SetVariable v:MyNamedVariable
Image
data:image/s3,"s3://crabby-images/67cc9/67cc9d39f6a9211d849f1dba3c978badd47e5a78" alt=""
Filter Field
Filter fields
FilterFiles :filter{name is "filename"}
Actions shown | Filter Files |
Other Fields
There are other fields, most are very similar to similar fields like the Storage Service Picker is very similar to the Enum field.
Advanced Features
Shortcutslang has some more advanced features to make working on large shortcuts easier
Actions inside actions
You can put an action inside of a text field or any other field that accepts variable
Text "My number is \(Number -2.5)"
Image
data:image/s3,"s3://crabby-images/cb84f/cb84fcc54c590a2b48640dac8d0fa8b8947eb6fa" alt=""
This code is equivalent to
Number -2.5 -> mv:InsideParenthesis
Text "My number is \(mv:InsideParenthesis)"
Image
data:image/s3,"s3://crabby-images/1f8de/1f8de0464981a41eb136768c6af57a83aa6640e8" alt=""
None of these magic variables actually get a name, they just directly reference the action.
You can even use actions inside other actions this without disrupting the action input
Text "Hello"
If Equals (Text "Goodbye")
ShowResult "If the action input was disrupted, this would run"
Otherwise
QuickLook
End If
Image
data:image/s3,"s3://crabby-images/8e88e/8e88e4d3d4b9bb04cf89f70428169bf87a9b7f43" alt=""
is equivalent to writing out
Text "Hello" -> mv:OriginalInput
Text "Goodbye" -> mv:ArgumentValue
GetVariable mv:OriginalInput
If Equals mv:ArgumentValue
ShowResult "If the action input was disrupted, this would run"
Otherwise
QuickLook # Shows "Hello"
End If
Image
data:image/s3,"s3://crabby-images/c49b9/c49b99fe76474e286f349858c95c64aa353698ce" alt=""
Actions shown | Text | GetVariable | If | QuickLook | Number |
InputArg
Sometimes you want to disrupt the input, you can use an InputArg
Text "Some text"
QuickLook ^(Text "Different text")
Image
data:image/s3,"s3://crabby-images/3ba26/3ba26f09ca7d862bdde10ab15f9328274e5652ea" alt=""
is the same as
Text "Some text"
Text "Different text"
QuickLook
Image
data:image/s3,"s3://crabby-images/3ba26/3ba26f09ca7d862bdde10ab15f9328274e5652ea" alt=""
Actions shown | Text | QuickLook |
Variable Aggrandizements
When you tap a variable in Shortcuts, a menu pops up containing different actions. Those are called Aggrandizements.
GetVariable v:MyVariable{as:Dictionary,key:myKey}
GetVariable v:MyContact{as:Contact,get:Notes}
Image
data:image/s3,"s3://crabby-images/2c52e/2c52e5862c99e16ac8b3d637c351e86a8f11572d" alt=""
Currently, 3 aggrandizements are supported:
- as/coerce
- key/forKey
- get/getProperty (partial)
The key: aggrandizement is used very often in conjunction with the as: Dictionary aggrandizement. Instead of writing that out every time, there is a shortcut for it
GetVariable v:MyDictionary:myKey
Image
data:image/s3,"s3://crabby-images/6475d/6475deee17e15693e739fcc475e16f406399648c" alt=""
is the same as
GetVariable v:MyDictionary{as:Dictionary,key:myKey}
Image
data:image/s3,"s3://crabby-images/6475d/6475deee17e15693e739fcc475e16f406399648c" alt=""
Actions Shown | GetVariable |
Setting Variables
->
can be used to set more than just magic variables, it can also automatically make SetVariable actions.
Text "My Text" -> v:MyNamedVariable
Image
data:image/s3,"s3://crabby-images/6a105/6a105dafe07b3addd84a0f629880e00b78d06f51" alt=""
is equivalent to writing
Text "My Text"
SetVariable v:MyNamedVariable
Image
data:image/s3,"s3://crabby-images/6a105/6a105dafe07b3addd84a0f629880e00b78d06f51" alt=""
If you prefer, you can set variables before an action instead of after
mv:WowMagic = Text "My Text"
Image
data:image/s3,"s3://crabby-images/4f2a6/4f2a608c6eb1d0249fafc75310d3ad0f683af7b3" alt=""
is exactly the same as using an arrow, except it’s in the format mv:variable = action
Text "My Text" -> mv:WowMagic
Image
data:image/s3,"s3://crabby-images/4f2a6/4f2a608c6eb1d0249fafc75310d3ad0f683af7b3" alt=""
Actions Shown | Text | GetVariable |
ArgLists
Actions can usually only take up one line of text, unless you use a barlist. If you have many different arguments, it can be helpful to have actions span multiple lines. You can use an arglist for this.
getfile a{
service="iCloud Drive"
showdocumentpicker=false
filepath="/myfile.txt"
errorifnotfound=false
}
Image
data:image/s3,"s3://crabby-images/02280/0228038e1deffb3152b9fbfd1b07f482d2e3bc9f" alt=""
Actions shown | GetFile |
Special Variables
Shortcuts has 5 special variables, 2 of which seem to have no reason for existing.
- Ask When Run
s:AskWhenRun
(prompts the user to enter the field themselves) - Shortcut Input
s:ShortcutInput
(the input to the shortcut) - Action Input
s:ActionInput
(the input to the action) - Current Date
s:CurrentDate
(the current date) - Clipboard
s:Clipboard
(the contents of the clipboard)
Image
data:image/s3,"s3://crabby-images/6b25d/6b25d9f8d8b3bebeb60ea550fc0141a8f6ee9e83" alt=""
Macros and Parser Variables
The @set macro
Parser variables are variables that only exist in your scpl file. When the shortcut is generated, they are replaced with their value.
Set a parser variable with @set
, use a parser variable with @:variable
@set varname "value"
text "value is \(@:varname)"
Image
data:image/s3,"s3://crabby-images/16169/16169a0d6eebf3392183beb4e534ec26821a05e9" alt=""
Parser variables inherit the properties of their values.
@set number 0.5
@set list [1, 2, 3]
number @:number
list @:list
Image
data:image/s3,"s3://crabby-images/5b9b6/5b9b611cea953aa420694b040dfb0a0c443754f9" alt=""
Parser variables can contain actions
@set myaction (text "hi")
@:myaction
Image
data:image/s3,"s3://crabby-images/4e72b/4e72ba391f77894745d45047fef74d67007a3a36" alt=""
Parser variables can contain lists of actions
@set EscapeText @{
replacetext "\\" "\\\\"
replacetext (Text "\n") " "
replacetext ";" "\\;"
}
Text ";Hi there!\n\\"
@:EscapeText
Image
data:image/s3,"s3://crabby-images/bd393/bd3934919870605624fec8b84603988f06157220" alt=""
Parser variables can take input as a dictionary of parser variables to set
@set test (Text @:value)
@:test{value:"Hi!"}
Image
data:image/s3,"s3://crabby-images/ad695/ad6951294a44ed7fa8264c77d0f1597fbd6754f1" alt=""
Use cases
In shortcuts, you can make functions by checking different inputs. To run these functions, normally it would take lots of code.
runShortcut v:ThisShortcut false ^(Dictionary{ action: Escape, text: "<the text>" })
You can define a macro/parser variable to insert that for you
setVariable v:ThisShortcut ^(text "Shortcut Name")
@set Escape (runShortcut v:ThisShortcut false ^(Dictionary{ action: Escape, text: @:text }))
AskForInput "Text to escape" -> mv:InputtedText
@:Escape{text: mv:InputtedText}
Image
data:image/s3,"s3://crabby-images/10dbf/10dbff2ed4316d4d8ceb4d3f613316cfe7918f55" alt=""
The @foreach macro
Foreach will repeat an action multiple times
@foreach ["Item 1", "Item 2", "Item 3", "Item 4"] @{
Text @:repeatitem
}
Image
data:image/s3,"s3://crabby-images/637b5/637b5034b6053881d784efb97e954131e3162d24" alt=""
The @if
macro
The @if
macro allows you to do things if a boolean is true
@if true @{
text "True Condition"
} @{
text "False Condition"
}
The @elseif
macro
The @elseif
macro is a shorthand for chaining else ifs.
if Equals WifiOn
SetWifi true
@elseif Equals WifiOff
SetWifi false
@elseif Equals BluetoothOn
SetBluetooth true
else
SetBluetooth false
End
Image
data:image/s3,"s3://crabby-images/b1d6d/b1d6d0a00be4b0b2511de9abc4d77958ef00ddf1" alt=""
The @error
macro
The @error
macro throws an error.
@error "There is a problem."
Image
Code does not compile, there is an errorThe @def
macro
The @def
macro allows you to define your own macros.
@def @printtext ["arg1", "arg2"] @{
ShowResult "Arg1 is \(@:arg1) and Arg2 is \(@:arg2)"
}
@PrintText arg1="Value1" arg2="Value2"
Image
data:image/s3,"s3://crabby-images/b66bd/b66bd96cd51e96cefbc480b2a54ba269554b2542" alt=""