Skip to content

Commit

Permalink
Fix SemiRegular.
Browse files Browse the repository at this point in the history
Fixes #1620.

Another pass to loosen some constraints now that SemiRegular refines
Copyable is warranted.
  • Loading branch information
dabrahams committed Nov 24, 2024
1 parent 02a00f3 commit 71dbad5
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 7 deletions.
2 changes: 1 addition & 1 deletion StandardLibrary/Sources/Array.hylo
Original file line number Diff line number Diff line change
Expand Up @@ -207,7 +207,7 @@ public type Array<Element: SemiRegular>: SemiRegular {

}

public conformance Array: Equatable {
public conformance Array: Equatable where Element: Equatable {

/// Returns `true` iff `other` has an equivalent value.
public fun infix== (_ other: Self) -> Bool {
Expand Down
4 changes: 2 additions & 2 deletions StandardLibrary/Sources/Core/Regular.hylo
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@
///
/// - Move is value-preserving.
/// - Destruction has no side-effects.
public trait SemiRegular: Deinitializable, Movable, Equatable {}
public trait SemiRegular: Copyable, Deinitializable {}

/// Regular types (roughly per Stepanov).
///
/// Copies have equal value.
public trait Regular: SemiRegular, Copyable {}
public trait Regular: SemiRegular, Equatable {}
13 changes: 9 additions & 4 deletions Tests/HyloTests/TestCases/TypeChecking/AbstractType.hylo
Original file line number Diff line number Diff line change
@@ -1,14 +1,19 @@
//- typeCheck expecting: .success

trait P: SemiRegular {
type T: SemiRegular
type U: SemiRegular
// Our SemiRegular when this test was written wasn't the genuine
// SemiRegular but was being depended on by this test, so rephrasing
// it here.
trait LegacySemiRegular: Deinitializable, Movable, Equatable {}

trait P: LegacySemiRegular {
type T: LegacySemiRegular
type U: LegacySemiRegular

fun t(_ x: T)
fun u(_ x: U)
}

trait Q: SemiRegular {
trait Q: LegacySemiRegular {
type V: P
property v: V { let }
}
Expand Down

0 comments on commit 71dbad5

Please sign in to comment.