Comments (7)
Using an Atomic.t
value for the uid counter doesn't seem egregious.
from eio.
I think either that or a with_context function, which replaces the internal hmap for the duration of the function (much like Cancel.sub) would be good.
Oh, yeah, that's a better idea!
Do you want to make a PR? Using hmap would probably be fine. If not, I expect I'll get around to it myself at some point.
from eio.
Yes, I agree. It probably just needs an hmap in the fiber_context
, alongside the thread ID:
Lines 25 to 30 in 48c14c9
The main concern I have is about modular reasoning - ideally two components shouldn't be able to interact without first being introduced. e.g. in
let x = ref 0 in
let y = Foo.make x in
let z = Bar.make () in
we should be able to assume that z
does not have access to x
. However, if Foo.make
can put x
in a fiber-local variable then this doesn't hold.
I see a couple of reasonable approaches:
- Put this API in the
Private
module, so people know the usual rules don't apply, or - Only allow setting fiber-local variables at fiber-creation time, which I think might solve it (needs more thought).
from eio.
Only allow setting fiber-local variables at fiber-creation time
I think either that or a with_context
function, which replaces the internal hmap for the duration of the function (much like Cancel.sub
) would be good. I guess the two are largely equivalent and can be used to implement the other!
from eio.
Using hmap would probably be fine.
I guess one thing worth mentioning here is that creating keys won't be domain/thread safe (as it just uses a non-atomic reference cell). I assume that's fine, as long as it's documented?
from eio.
Yes, for now. Might be worth checking if @dbuenzli is interested in making hmap multicore safe.
from eio.
Added in #256
from eio.
Related Issues (20)
- Problematic `assert()` in `Eio.File.pread` HOT 1
- Add Condition to `Eio.Std` HOT 3
- Creating a process group in `Fork_action` (?) HOT 1
- Add a systhread pool of workers for eio_posix HOT 1
- README discussion of `type 'a env` convention is out of date HOT 2
- Restore "available" metadata on eio_windows
- Keep writes within IOV_MAX HOT 1
- Compilation failure HOT 7
- api questions and some migration feedback HOT 7
- Full tracing support
- `_os_unfair_lock_corruption_abort` after fork on MacOS HOT 15
- `getsockname` missing? HOT 3
- Switches should be domain-safe
- Eio_unix: Allocation warning from sched.ml breaks cram tests HOT 2
- Unix.Unix_error(Unix.EPERM, "io_uring_queue_init", "") failures in Docker HOT 5
- Occasional deadlocks with systhreads
- Multiple message in TCP communication with flow HOT 3
- Explanation of "connect-in-progress" HOT 3
- Net.listen hangs if the port is already in use HOT 2
- Extending eio from the outside HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from eio.