OBones wrote:
Mark Morgan Lloyd wrote:
Basically, what I was trying to do was this. In the main thread:

    fIpcPipe:= CreateNamedPipe(PChar(fIpcName), PIPE_ACCESS_INBOUND,
                        PIPE_TYPE_MESSAGE + PIPE_READMODE_MESSAGE,
                                1, 0, 0, 1000, NIL (* @sa *) );

That works. Fire up a background reader thread, and make sure that the main thread doesn't proceed...
So you are not creating the "read" pipe in the context of the thread that actually reads from it? I'm not sure that this is actually supported, maybe you should try to create it in the context of the reading thread.

I agree, but ever since threads were introduced (OS/2 v1 or perhaps even earlier) doctrine has had it that ownership (of memory, handles and so on) was by process while state (stack content and runability) was by thread.

Other points noted, in particular that my problem might be that I can't distribute certain types of activity over threads rather than (as I initially assumed) that things had to be distributed over multiple processes.

In any event, I can get away without having this working. If I do manage to hack it at some point I'll try to remember to report back.

--
Mark Morgan Lloyd
markMLl .AT. telemetry.co .DOT. uk

[Opinions above are the author's, not those of his employers or colleagues]
_______________________________________________
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
http://lists.freepascal.org/mailman/listinfo/fpc-pascal

Reply via email to