| 
									
										
										
										
											2014-11-03 22:18:03 +08:00
										 |  |  | process = global.process | 
					
						
							| 
									
										
										
										
											2015-01-31 23:31:14 -08:00
										 |  |  | fs      = require 'fs' | 
					
						
							| 
									
										
										
										
											2014-11-03 22:18:03 +08:00
										 |  |  | path    = require 'path' | 
					
						
							|  |  |  | timers  = require 'timers' | 
					
						
							|  |  |  | Module  = require 'module' | 
					
						
							| 
									
										
										
										
											2014-01-13 13:57:08 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-30 10:06:10 +08:00
										 |  |  | process.atomBinding = (name) -> | 
					
						
							|  |  |  |   try | 
					
						
							|  |  |  |     process.binding "atom_#{process.type}_#{name}" | 
					
						
							|  |  |  |   catch e | 
					
						
							| 
									
										
										
										
											2014-09-30 21:35:22 +08:00
										 |  |  |     process.binding "atom_common_#{name}" if /No such module/.test e.message | 
					
						
							| 
									
										
										
										
											2014-06-28 22:33:00 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-13 13:57:08 +08:00
										 |  |  | # Add common/api/lib to module search paths.
 | 
					
						
							|  |  |  | globalPaths = Module.globalPaths | 
					
						
							| 
									
										
										
										
											2015-02-13 12:55:06 +08:00
										 |  |  | globalPaths.push path.resolve(__dirname, '..', 'api', 'lib') | 
					
						
							| 
									
										
										
										
											2014-01-13 13:57:08 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | # setImmediate and process.nextTick makes use of uv_check and uv_prepare to
 | 
					
						
							|  |  |  | # run the callbacks, however since we only run uv loop on requests, the
 | 
					
						
							|  |  |  | # callbacks wouldn't be called until something else activated the uv loop,
 | 
					
						
							|  |  |  | # which would delay the callbacks for arbitrary long time. So we should
 | 
					
						
							|  |  |  | # initiatively activate the uv loop once setImmediate and process.nextTick is
 | 
					
						
							|  |  |  | # called.
 | 
					
						
							|  |  |  | wrapWithActivateUvLoop = (func) -> | 
					
						
							|  |  |  |   -> | 
					
						
							|  |  |  |     process.activateUvLoop() | 
					
						
							|  |  |  |     func.apply this, arguments | 
					
						
							|  |  |  | process.nextTick = wrapWithActivateUvLoop process.nextTick | 
					
						
							|  |  |  | global.setImmediate = wrapWithActivateUvLoop timers.setImmediate | 
					
						
							|  |  |  | global.clearImmediate = timers.clearImmediate | 
					
						
							| 
									
										
										
										
											2014-08-07 10:37:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | # setTimeout needs to update the polling timeout of the event loop, when called
 | 
					
						
							|  |  |  | # under Chromium's event loop the node's event loop won't get a chance to update
 | 
					
						
							|  |  |  | # the timeout, so we have to force the node's event loop to recalculate the
 | 
					
						
							|  |  |  | # timeout in browser process.
 | 
					
						
							|  |  |  | if process.type is 'browser' | 
					
						
							|  |  |  |   global.setTimeout = wrapWithActivateUvLoop timers.setTimeout | 
					
						
							| 
									
										
										
										
											2014-08-07 14:23:28 +08:00
										 |  |  |   global.setInterval = wrapWithActivateUvLoop timers.setInterval |