-
Notifications
You must be signed in to change notification settings - Fork 85
Expand file tree
/
Copy pathMulNoParentheses.sol
More file actions
92 lines (81 loc) · 1.67 KB
/
MulNoParentheses.sol
File metadata and controls
92 lines (81 loc) · 1.67 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
// SPDX-License-Identifier: MIT
pragma solidity 0.8.29;
contract MulNoParentheses {
function mulAdd(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b + c;
}
function mulSub(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b - c;
}
function mulMul(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b * c;
}
function mulDiv(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b / c;
}
function mulMod(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b % c;
}
function mulExp(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b ** c;
}
function mulShiftL(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b << c;
}
function mulShiftR(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b >> c;
}
function mulBitAnd(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b & c;
}
function mulBitOr(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b | c;
}
function mulBitXor(uint256 a, uint256 b, uint256 c)
public
pure
returns (uint256)
{
return a * b ^ c;
}
}