Leasing permissions
β οΈ DADA DOESN'T REALLY EXIST. β οΈ
See the About page for more information. Also, you have to pretend that all the code examples are editable and runnable, with live IDE tooltips and so forth. =)
So far in the tutorial, we've worked exclusively with the two owned permissions, my
and our
. Owned permissions have the property that they are independent from all other variables. When you have owned permission to an object, nobody can take that away from you. (In the case of our
, you might only have read permission, but that read permission cannot be revoked.)
Sometimes, though, we want to give people temporary access to an object that we own, without giving up control. In Dada, this is called a lease, and it works in a very similar way to how an "at will" lease works in "real life". If one variable a
owns an object, it can lease out that object to another variable b
temporarily. b
can use the object up until a
wants it back.
The permissions tableβ
Leased permissions complete the "permissions table" that we saw earlier:
Unique | Shared | |
---|---|---|
Owned | my | our |
Leased | β leased β | shleased |
We'll start by talking about unique leases, written lease
, and then cover shared leases, which we call a shlease
(pronounced, um, "sh-lease", kind of like the German "schliese"notreal).
Unique leasesβ
In this example, the line leased l = p
declares a variable l
that has a unique lease to the object stored in p
:
class Point(our x, our y)
my p = Point(22, 44)
leased l = p
l.x += 1
print(l.x).await # Prints `23`
print(p.x).await # Prints `23`
As you can see, a unique lease can be used just like the original object. Modifications to the leased object like l.x += 1
affect the original object too, so when we print p.x
we see 23
.
If you position your cursor right after leased l = p
, you will see the following diagram, which shows that both p
and l
store the same object. The my
arrow from p
has been "dashed" to indicate that, while p
retains ownership, the object is currently leased to another variable:
βββββ
β β βββββββββ
β p ββmyβββββββββββββββΊβ Point β
β β β βββββ β
β l ββleasedβββββββββββΊβ x: 22 β
β β β y: 44 β
βββββ βββββββββ
What makes unique leases unique?β
Unique leases are called unique because, so long as the lease has not been canceled, it grants unique access to the object, meaning that no other variable besides l
can access the object in any way -- even reads. This is why its ok to write to the object through l
, even though "friends don't let friends mutate shared data". In other words, even though two variables have access to the same object (p
and l
), only one of them has access to the object at any given time.
Terminating a unique leaseβ
A unique lease can be terminated in two ways:
- The leased variable
l
goes out of scope. - The owner (or lessor) variable
p
is used again. Becausel
had a unique lease, oncep
starts using the object, that implies the unique lease is canceled -- otherwise it wouldn't be unique, would it?
You can see this second case by positioning your cursor after the print(p).await
line in our original example. You will see that the l
variable no longer has a value, and the p
line is no longer 'dashed':
class Point(our x, our y)
my p = Point(22, 44)
leased l = p
l.x += 1
print(l.x).await # Prints `23`
print(p.x).await # Prints `23`
# β²
# βββββββββββββββ
# You see
#
# βββββ
# β β βββββββββ
# β p ββmyβββββββββββββββΊβ Point β
# β β β βββββ β
# β l β β x: 23 β
# β β β y: 44 β
# βββββ βββββββββ
What do you think will happen if we try to use l
again? Try it and find out!
The lease
keywordβ
In addition to assigning to a leased
variable, we can explicitly create a lease with the lease
keyword. This is particularly useful when combined with any
permissions. In this example, any l = p.lease
is equivalent to the leased l = p
that we saw earlier:
class Point(our x, our y)
my p = Point(22, 44)
any l = p.lease
l.x += 1
Giving a leased value
You may be wondering what happens when you give
a leased value. As always, giving a value means creating a second value with the same permissions -- but to explain exactly how giving works on a leased value, we have to introduce one more concept, the sublease. That's covered in the next section.
- No, "shlease" is not a real word.^[wasnot]β©