-
-
Notifications
You must be signed in to change notification settings - Fork 46.2k
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
Add Memory Allocator #12497
base: master
Are you sure you want to change the base?
Add Memory Allocator #12497
Conversation
7a303ee
to
94896dd
Compare
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.
Click here to look at the relevant links ⬇️
🔗 Relevant Links
Repository:
Python:
Automated review generated by algorithms-keeper. If there's any problem regarding this review, please open an issue about it.
algorithms-keeper
commands and options
algorithms-keeper actions can be triggered by commenting on this PR:
@algorithms-keeper review
to trigger the checks for only added pull request files@algorithms-keeper review-all
to trigger the checks for all the pull request files, including the modified files. As we cannot post review comments on lines not part of the diff, this command will post all the messages in one comment.NOTE: Commands are in beta and so this feature is restricted only to a member or owner of the organization.
only add or remove elements at the end. | ||
""" | ||
|
||
def __init__(self): |
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.
Please provide return type hint for the function: __init__
. If the function does not return a value, please provide the type hint as: def function() -> None:
def __init__(self): | ||
self.data = bytearray() | ||
|
||
def print(self, show_offset=False, bytes_per_row=4): |
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.
Please provide return type hint for the function: print
. If the function does not return a value, please provide the type hint as: def function() -> None:
Please provide type hint for the parameter: show_offset
Please provide type hint for the parameter: bytes_per_row
|
||
return previous_program_break | ||
|
||
def __len__(self): |
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.
Please provide return type hint for the function: __len__
. If the function does not return a value, please provide the type hint as: def function() -> None:
As there is no test file in this pull request nor any test function or class in the file other/memory_allocator.py
, please provide doctest for the function __len__
# unallocated memory for other processes. | ||
return len(self.data) | ||
|
||
def __getitem__(self, index): |
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.
Please provide return type hint for the function: __getitem__
. If the function does not return a value, please provide the type hint as: def function() -> None:
As there is no test file in this pull request nor any test function or class in the file other/memory_allocator.py
, please provide doctest for the function __getitem__
Please provide type hint for the parameter: index
# fault' signal emitted by the OS | ||
return self.data[index] | ||
|
||
def __setitem__(self, index, value: int): |
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.
Please provide return type hint for the function: __setitem__
. If the function does not return a value, please provide the type hint as: def function() -> None:
As there is no test file in this pull request nor any test function or class in the file other/memory_allocator.py
, please provide doctest for the function __setitem__
Please provide type hint for the parameter: index
0 4 b'....' | ||
""" | ||
|
||
def realloc_block(self, block, new_size): |
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.
Please provide return type hint for the function: realloc_block
. If the function does not return a value, please provide the type hint as: def function() -> None:
Please provide type hint for the parameter: block
Please provide type hint for the parameter: new_size
0 1 b'.' | ||
""" | ||
|
||
def optimize_after_free(self, block): |
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.
Please provide return type hint for the function: optimize_after_free
. If the function does not return a value, please provide the type hint as: def function() -> None:
Please provide type hint for the parameter: block
if block.is_last: | ||
self.shrink_heap() | ||
|
||
def shrink_heap(self): |
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.
Please provide return type hint for the function: shrink_heap
. If the function does not return a value, please provide the type hint as: def function() -> None:
self.linked_list_remove_last() | ||
self.heap.sbrk(-last.size) | ||
|
||
def linked_list_remove_last(self): |
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.
Please provide return type hint for the function: linked_list_remove_last
. If the function does not return a value, please provide the type hint as: def function() -> None:
https://en.wikipedia.org/wiki/Fragmentation_(computing)#External_fragmentation | ||
""" | ||
|
||
def find_fit_block(self, size): |
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.
Please provide return type hint for the function: find_fit_block
. If the function does not return a value, please provide the type hint as: def function() -> None:
Please provide type hint for the parameter: size
Hello reviewers, I hope that you find this addition interesting. The downside is that it requires a lot of setup to get to the enjoyable part (from MemoryAllocatorSplit to the end) Could you please confirm whether this algorithm is suitable for this project? so I can start applying the typing changes proposed by the bot (some of them are not trivial). I am willing to listen to your proposals. I am open to remove unnecessary parts if your consider it |
Describe your change:
Checklist: