-
-
Notifications
You must be signed in to change notification settings - Fork 5.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
improved function partial application design
This replaces `Fix` (xref #54653) with `fix`. The usage is similar: use `fix(i)(f, x)` instead of `Fix{i}(f, x)`. Benefits: * Improved type safety: creating an invalid type such as `Fix{:some_symbol}` or `Fix{-7}` is not possible. * The design should be friendlier to future extensions. E.g., suppose that publicly-facing functionality for fixing a keyword (instead of positional) argument was desired, it could be achieved by adding a new method to `fix` taking a `Symbol`, instead of adding new public names. Lots of changes are shared with PR #56425, if one of them gets merged the other will be greatly simplified.
- Loading branch information
Showing
11 changed files
with
354 additions
and
72 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,7 +14,7 @@ public | |
AsyncCondition, | ||
CodeUnits, | ||
Event, | ||
Fix, | ||
fix, | ||
Fix1, | ||
Fix2, | ||
Generator, | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,167 @@ | ||
# This file is a part of Julia. License is MIT: https://julialang.org/license | ||
|
||
# Adapted from the TypeDomainNaturalNumbers.jl package. | ||
module _TypeDomainNumbers | ||
module Zeros | ||
export Zero | ||
struct Zero end | ||
end | ||
|
||
module PositiveIntegers | ||
module RecursiveStep | ||
using ...Zeros | ||
export recursive_step | ||
function recursive_step(@nospecialize t::Type) | ||
Union{Zero, t} | ||
end | ||
end | ||
module UpperBounds | ||
using ..RecursiveStep | ||
abstract type A end | ||
abstract type B{P <: recursive_step(A)} <: A end | ||
abstract type C{P <: recursive_step(B)} <: B{P} end | ||
abstract type D{P <: recursive_step(C)} <: C{P} end | ||
end | ||
using .RecursiveStep | ||
const PositiveIntegerUpperBound = UpperBounds.A | ||
const PositiveIntegerUpperBoundTighter = UpperBounds.D | ||
export | ||
natural_successor, natural_predecessor, | ||
NonnegativeInteger, NonnegativeIntegerUpperBound, | ||
PositiveInteger, PositiveIntegerUpperBound | ||
struct PositiveInteger{ | ||
Predecessor <: recursive_step(PositiveIntegerUpperBoundTighter), | ||
} <: PositiveIntegerUpperBoundTighter{Predecessor} | ||
predecessor::Predecessor | ||
global const NonnegativeInteger = recursive_step(PositiveInteger) | ||
global const NonnegativeIntegerUpperBound = recursive_step(PositiveIntegerUpperBound) | ||
global function natural_successor(p::P) where {P <: NonnegativeInteger} | ||
new{P}(p) | ||
end | ||
end | ||
function natural_predecessor(@nospecialize o::PositiveInteger) | ||
getfield(o, :predecessor) # avoid specializing `getproperty` for each number | ||
end | ||
end | ||
|
||
module IntegersGreaterThanOne | ||
using ..PositiveIntegers | ||
export | ||
IntegerGreaterThanOne, IntegerGreaterThanOneUpperBound, | ||
natural_predecessor_predecessor | ||
const IntegerGreaterThanOne = let t = PositiveInteger | ||
t{P} where {P <: t} | ||
end | ||
const IntegerGreaterThanOneUpperBound = let t = PositiveIntegerUpperBound | ||
PositiveIntegers.UpperBounds.B{P} where {P <: t} | ||
end | ||
function natural_predecessor_predecessor(@nospecialize x::IntegerGreaterThanOne) | ||
natural_predecessor(natural_predecessor(x)) | ||
end | ||
end | ||
|
||
module Constants | ||
using ..Zeros, ..PositiveIntegers | ||
export n0, n1 | ||
const n0 = Zero() | ||
const n1 = natural_successor(n0) | ||
end | ||
|
||
module Utils | ||
using ..PositiveIntegers, ..IntegersGreaterThanOne, ..Constants | ||
using Base: @_foldable_meta | ||
function subtracted_nonnegative((@nospecialize l::NonnegativeInteger), @nospecialize r::NonnegativeInteger) | ||
@_foldable_meta | ||
if r isa PositiveIntegerUpperBound | ||
let a = natural_predecessor(l), b = natural_predecessor(r) | ||
subtracted_nonnegative(a, b) | ||
end | ||
else | ||
l | ||
end | ||
end | ||
function abs_decrement(n::Int) | ||
@_foldable_meta | ||
if signbit(n) | ||
n + true | ||
else | ||
n - true | ||
end | ||
end | ||
function to_int(@nospecialize o::NonnegativeInteger) | ||
@_foldable_meta | ||
if o isa PositiveIntegerUpperBound | ||
let p = natural_predecessor(o), t = to_int(p) | ||
t + true | ||
end | ||
else | ||
0 | ||
end | ||
end | ||
function from_abs_int(n::Int) | ||
@_foldable_meta | ||
ret = n0 | ||
while !iszero(n) | ||
n = abs_decrement(n) | ||
ret = natural_successor(ret) | ||
end | ||
ret | ||
end | ||
end | ||
|
||
module Overloads | ||
using ..PositiveIntegers, ..Utils | ||
function (::Type{Int})(@nospecialize o::NonnegativeInteger) | ||
Utils.to_int(o) | ||
end | ||
function Base.show((@nospecialize io::Base.IO), @nospecialize n::NonnegativeInteger) | ||
i = Int(n) | ||
Base.show(io, i) | ||
end | ||
end | ||
end | ||
|
||
module _TypeDomainNumberTupleUtils | ||
using | ||
.._TypeDomainNumbers.PositiveIntegers, .._TypeDomainNumbers.IntegersGreaterThanOne, | ||
.._TypeDomainNumbers.Constants, .._TypeDomainNumbers.Utils, .._TupleTypeByLength | ||
using Base: @_total_meta, @_foldable_meta, front, tail | ||
export tuple_type_domain_length, split_tuple, skip_from_front, skip_from_tail | ||
function tuple_type_domain_length(@nospecialize tup::Tuple) | ||
@_total_meta | ||
if tup isa Tuple1OrMore | ||
let t = tail(tup), rec = tuple_type_domain_length(t) | ||
natural_successor(rec) | ||
end | ||
else | ||
n0 | ||
end | ||
end | ||
function skip_from_front((@nospecialize tup::Tuple), @nospecialize skip_count::NonnegativeInteger) | ||
@_foldable_meta | ||
if skip_count isa PositiveIntegerUpperBound | ||
let cm1 = natural_predecessor(skip_count), t = tail(tup) | ||
@inline skip_from_front(t, cm1) | ||
end | ||
else | ||
tup | ||
end | ||
end | ||
function skip_from_tail((@nospecialize tup::Tuple), @nospecialize skip_count::NonnegativeInteger) | ||
@_foldable_meta | ||
if skip_count isa PositiveIntegerUpperBound | ||
let cm1 = natural_predecessor(skip_count), t = front(tup) | ||
@inline skip_from_tail(t, cm1) | ||
end | ||
else | ||
tup | ||
end | ||
end | ||
function split_tuple((@nospecialize tup::Tuple), @nospecialize len_l::NonnegativeInteger) | ||
len = tuple_type_domain_length(tup) | ||
len_r = Utils.subtracted_nonnegative(len, len_l) | ||
tup_l = skip_from_tail(tup, len_r) | ||
tup_r = skip_from_front(tup, len_l) | ||
(tup_l, tup_r) | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -285,7 +285,7 @@ Base.:(|>) | |
Base.:(∘) | ||
Base.ComposedFunction | ||
Base.splat | ||
Base.Fix | ||
Base.fix | ||
Base.Fix1 | ||
Base.Fix2 | ||
``` | ||
|
Oops, something went wrong.