snarkvm_console_types_address/bitwise.rs
1// Copyright 2024 Aleo Network Foundation
2// This file is part of the snarkVM library.
3
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at:
7
8// http://www.apache.org/licenses/LICENSE-2.0
9
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15
16use super::*;
17
18impl<E: Environment> Equal for Address<E> {
19 type Output = Boolean<E>;
20
21 /// Returns `true` if `self` and `other` are equal.
22 fn is_equal(&self, other: &Self) -> Self::Output {
23 Boolean::new(self == other)
24 }
25
26 /// Returns `true` if `self` and `other` are *not* equal.
27 fn is_not_equal(&self, other: &Self) -> Self::Output {
28 Boolean::new(self != other)
29 }
30}
31
32impl<E: Environment> Compare for Address<E> {
33 type Output = Boolean<E>;
34
35 /// Returns `true` if `self` is less than `other`.
36 fn is_less_than(&self, other: &Self) -> Self::Output {
37 self.address.to_x_coordinate().is_less_than(&other.address.to_x_coordinate())
38 }
39
40 /// Returns `true` if `self` is greater than `other`.
41 fn is_greater_than(&self, other: &Self) -> Self::Output {
42 other.is_less_than(self)
43 }
44
45 /// Returns `true` if `self` is less than or equal to `other`.
46 fn is_less_than_or_equal(&self, other: &Self) -> Self::Output {
47 other.is_greater_than_or_equal(self)
48 }
49
50 /// Returns `true` if `self` is greater than or equal to `other`.
51 fn is_greater_than_or_equal(&self, other: &Self) -> Self::Output {
52 !self.is_less_than(other)
53 }
54}
55
56impl<E: Environment> Ternary for Address<E> {
57 type Boolean = Boolean<E>;
58 type Output = Self;
59
60 /// Returns `first` if `condition` is `true`, otherwise returns `second`.
61 fn ternary(condition: &Self::Boolean, first: &Self, second: &Self) -> Self::Output {
62 match **condition {
63 true => *first,
64 false => *second,
65 }
66 }
67}