Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Balancer Composable stable pool strategy #1839
Balancer Composable stable pool strategy #1839
Changes from 106 commits
21d28ff
ca4b9c7
bd17a59
e218397
e40539a
fddfc96
4d61080
c941766
4e2a0ac
a163e8f
6322507
5150986
fa5838b
74f1403
10b6fdc
807e8c4
8f16b4e
1c782a5
faa7eb5
c6b45c3
c77a296
75329db
ea68019
5607b5d
012a83d
b120330
39a7b3f
346d949
fbafb80
430fbad
3ec984c
ecceeb1
eb11498
a25a661
b9dd480
3af8527
3767bb2
3cdbdba
c69369e
8a26a4e
afb2d67
3ae0892
b321712
34608a7
a323447
7d8c3fa
d4eef49
4d36852
d206ce4
b127355
6ad405c
04b3010
852afa4
abf482f
d159fbe
e09a9b9
daeab91
a2f8fcd
cf4122a
fcc08f7
5a338d6
d2c0039
70b4481
71332e5
900e6d0
38a7e86
3fd8f23
88bfd30
b7e0dc3
a0cb919
0f02fad
e95315a
3019b49
6b5a2b4
09684fd
d8d6aa5
1ad9e71
64a1ada
535534d
932a198
730e7e7
de35628
8bfb9b9
95b1520
9bcac23
3db3802
e188604
4aaa34b
16c38bf
c26743d
a1afaf3
8c87320
c21d6f4
c87d2d1
9504702
852f362
352a315
175dc26
1f58b97
ebbf77c
be15ba6
d925894
d5f7e7e
fc2976d
50aa75f
4f10493
b5502a0
c64a329
f4ecf97
b93e1be
fd5c36b
1eeb8a1
4075c4a
f0cb237
d99a8ea
5f09a8d
933009b
ab58728
5e18318
7f05e62
bcb746c
423be2a
292db7a
4ac3998
ea1c8ef
b4afff5
5705849
e0005ec
b2313d5
5b6066c
0d45ea7
bcaae0e
4d8a33a
a6d6e4f
b13454b
e2934e4
2777a80
a251071
2074f55
1320ef5
815c310
33a71ce
7729d17
ddbfb4c
fde6b01
0ec02f1
8db6593
a6f3285
c25642a
dce9bbc
25df2e6
635f4a9
2e00076
bbc2160
47b9c0b
8fb75ec
6dbb9cd
d388725
63fb7fa
a3b3197
8b94037
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
Check warning on line 84 in contracts/contracts/proxies/InitializeGovernedUpgradeabilityProxy.sol
Codecov / codecov/patch
contracts/contracts/proxies/InitializeGovernedUpgradeabilityProxy.sol#L84
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see you are using
++i
to save a little bit of gas, this addition could be performed using uncheck.It's also possible to add uncheck to the following
++i
on line 116 and 131There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That is a great point thanks. I have just read up on this how; Solidity (after 0.8.0) doesn't need to perform overflow checks in situations where no overflow is guaranteed. And looping through arrays definitely is one of those situations.
The unchecked does provide some gas savings with a little minor impact on code readability. In this case I would rather not make the change, since first loop is done only on initialisation. And the other 2 are done on join/exit pools. We are running those operations relatively rarely - and are paying for the gas ourselves.
If these optimisations would be part of
checkBalance
function ( that gets called in Vault's allocate/rebase that are called in most of mints & redeems) then I'd gladly trade the readability impact for the gas savings.And thanks I will keep the
unchecked
in mind for future optimization opportunities.