2015-10-20 04:32:08 +00:00
|
|
|
#include <TestCommon.h>
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
trace("----------------------------------");
|
|
|
|
Worker p;
|
|
|
|
p.getStdout().write("<-- origBuffer -->");
|
|
|
|
|
|
|
|
auto c = p.child();
|
|
|
|
auto cb = c.newBuffer(FALSE);
|
|
|
|
cb.activate();
|
|
|
|
cb.write("<-- cb -->");
|
2015-10-20 07:38:38 +00:00
|
|
|
c.dumpConsoleHandles(TRUE);
|
2015-10-20 04:32:08 +00:00
|
|
|
|
|
|
|
// Proposed fix: the agent somehow decides it should attach to this
|
|
|
|
// particular child process. Does that fix the problem?
|
|
|
|
//
|
|
|
|
// No, because the child's new buffer was not marked inheritable. If it
|
|
|
|
// were inheritable, then the parent would "inherit" the handle during
|
|
|
|
// attach, and both processes would use the same refcount for
|
|
|
|
// `CloseHandle`.
|
|
|
|
p.detach();
|
|
|
|
p.attach(c);
|
2015-10-20 07:38:38 +00:00
|
|
|
p.dumpConsoleHandles(TRUE);
|
2015-10-20 04:32:08 +00:00
|
|
|
auto pb = p.openConout();
|
|
|
|
|
|
|
|
cb.close();
|
|
|
|
|
|
|
|
// Demonstrate that pb is an invalid handle.
|
|
|
|
pb.close();
|
|
|
|
|
|
|
|
Sleep(300000);
|
|
|
|
}
|