Comments (7)
Note at the moment I'm using this little helper method to work around this:
# This method changes the environmental variables of the process to
# that of this environment, yields, and then resets them. This allows
# us to change the environment temporarily.
def with_env_changes
stashed = {}
begin
@env.each do |key, value|
stashed[key] = ENV[key]
ENV[key] = value
end
yield
ensure
stashed.each do |key, value|
ENV[key] = stashed[key]
end
end
end
Then using it like so:
process = ChildProcess.build("blah", "blah")
with_env_changes do
process.start
end
And this gets around the issue since all platforms I believe inherit environmental variables. However, it seems hacky and isn't threadsafe and pushes a lot of that logic down to the client, whereas environmental variables are a first class argument in any exec
type API, so I think it should be in ChildProcess
as well. :)
from childprocess.
I agree. I'll see what I can do.
from childprocess.
Does that look ok to you?
Right now the child process will inherit the parent's environment when you call #start, which I think makes sense. One could argue that we should store a copy of the parent environment when ChildProces.build is called instead. Thoughts?
from childprocess.
Looks very good! I see you properly got the edge-cases that Java and Windows have of SETTING the environment instead of setting overrides for the current environment, which is the only thing I knew to look for in this change.
As for when to set the environment, I think start
is the right place. All "fork-like" APIs do the actual environment copy on fork, so I think doing it on "start" for childprocess makes sense.
Thank you!
When will there be a gem push? :)
from childprocess.
Pushed!
from childprocess.
Thank you for the quick turnaround on this. Be proud you have the best subprocess library for Ruby hands down.
from childprocess.
Thanks :)
from childprocess.
Related Issues (20)
- Redirect to IO.pipe on Windows causes inability to start a process HOT 6
- Security Question: Is there a reason childprocess is released as an unsigned gem? HOT 2
- FFI is a required pre-requisite HOT 4
- Pipe i/o example in documentation is incorrect HOT 2
- Erro ao rodar o comando rspec -fd HOT 1
- childprocess kills detached windows process on exit HOT 4
- FFI is a required pre-requisite for Windows or posix_spawn support in the ChildProcess gem. HOT 1
- A backend based on Process.spawn HOT 12
- Ruby 3.0 support HOT 10
- code hanging attempting to @thread.join HOT 1
- Should work for the M1 chip, but needs to be mapped or smth
- `host_cpu` changes between Ruby 2.7.2 and 2.7.3 HOT 2
- FFI installes but rake test get error HOT 4
- cannot load such file -- ffi (LoadError) HOT 2
- Use with StringIO HOT 1
- posix_spawn is not yet supported on aarch64-linux (aarch64-linux), HOT 2
- posix_spawn is not yet supported on sparc-solaris (sparc-solaris2.11) HOT 1
- I happen to be having this error after even having all both ruby, gem, and even chocolatey handy HOT 2
- Test suite is going to be broken with Ruby 3.3 HOT 1
- differences between macos and linux HOT 3
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 childprocess.