mirror of
https://github.com/ksherlock/TwoTerm.git
synced 2025-01-20 11:33:44 +00:00
dispatch_io_create() is supposed to be the correct way to read from a stream. However, it doesn't seem to work and I believe it's due to poll() not working with pseudo terminals in OS X.
Leaving the code in just for fun. Underlying issue - when the pty closes, the block doesn't always get notified so the fd doesn't close until the window closes.
This commit is contained in:
parent
a6408fc242
commit
38dad13969
@ -226,7 +226,33 @@
|
|||||||
dispatch_resume(_wait_source);
|
dispatch_resume(_wait_source);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
dispatch_io_t io = dispatch_io_create(DISPATCH_IO_STREAM, fd, queue, ^(int error){
|
||||||
|
close(fd);
|
||||||
|
NSLog(@"dispatch_io_create: %d", error);
|
||||||
|
});
|
||||||
|
|
||||||
|
dispatch_io_read(io, 0, SIZE_MAX, queue, ^(bool done, dispatch_data_t data, int error){
|
||||||
|
if (error) {
|
||||||
|
NSLog(@"dispatch_io_read: %d", error);
|
||||||
|
dispatch_io_close(io, DISPATCH_IO_STOP);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
dispatch_data_apply(data, ^(dispatch_data_t, size_t, const void *buffer, size_t size){
|
||||||
|
[_emulatorView processData: (uint8_t *)buffer size: size];
|
||||||
|
return true;
|
||||||
|
} );
|
||||||
|
|
||||||
|
if (done) {
|
||||||
|
NSLog(@"closing fd");
|
||||||
|
dispatch_io_close(io, DISPATCH_IO_STOP);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
#else
|
||||||
_read_source = dispatch_source_create(DISPATCH_SOURCE_TYPE_READ,
|
_read_source = dispatch_source_create(DISPATCH_SOURCE_TYPE_READ,
|
||||||
fd, 0, queue);
|
fd, 0, queue);
|
||||||
if (_read_source)
|
if (_read_source)
|
||||||
@ -245,6 +271,7 @@
|
|||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
actual = read(fd, buffer, estimated);
|
actual = read(fd, buffer, estimated);
|
||||||
|
//fprintf(stderr, "read: %ld\n", actual);
|
||||||
if (actual < 0) {
|
if (actual < 0) {
|
||||||
if (errno == EINTR) continue;
|
if (errno == EINTR) continue;
|
||||||
|
|
||||||
@ -266,7 +293,6 @@
|
|||||||
if (buffer != sbuffer) free(buffer);
|
if (buffer != sbuffer) free(buffer);
|
||||||
|
|
||||||
if (actual == 0) {
|
if (actual == 0) {
|
||||||
NSLog(@"closing fd");
|
|
||||||
dispatch_source_cancel(_read_source);
|
dispatch_source_cancel(_read_source);
|
||||||
dispatch_release(_read_source);
|
dispatch_release(_read_source);
|
||||||
_read_source = nullptr;
|
_read_source = nullptr;
|
||||||
@ -276,6 +302,7 @@
|
|||||||
|
|
||||||
|
|
||||||
dispatch_source_set_cancel_handler(_read_source, ^{
|
dispatch_source_set_cancel_handler(_read_source, ^{
|
||||||
|
NSLog(@"closing fd");
|
||||||
_fd = -1;
|
_fd = -1;
|
||||||
[_emulatorView setFd: -1];
|
[_emulatorView setFd: -1];
|
||||||
close(fd);
|
close(fd);
|
||||||
@ -283,6 +310,7 @@
|
|||||||
|
|
||||||
dispatch_resume(_read_source);
|
dispatch_resume(_read_source);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#pragma mark -
|
#pragma mark -
|
||||||
|
Loading…
x
Reference in New Issue
Block a user