mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 10:18:11 +00:00
Deallocate PTY's when they close.
This required a fair bit of plumbing. The CharacterDevice::close() virtual will now be closed by ~FileDescriptor(), allowing device implementations to do custom cleanup at that point. One big problem remains: if the master PTY is closed before the slave PTY, we go into crashy land.
This commit is contained in:
parent
027d26cd5d
commit
b4e478aa50
19 changed files with 104 additions and 12 deletions
|
@ -97,7 +97,10 @@ int main(int, char**)
|
|||
perror("read(ptm)");
|
||||
continue;
|
||||
}
|
||||
assert(nread != 0);
|
||||
if (nread == 0) {
|
||||
dbgprintf("Terminal: EOF on master pty, closing.\n");
|
||||
break;
|
||||
}
|
||||
for (ssize_t i = 0; i < nread; ++i)
|
||||
terminal.on_char(buffer[i]);
|
||||
terminal.update();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue