| 
									
										
										
										
											2014-01-13 13:57:08 +08:00
										 |  |  | path   = require 'path' | 
					
						
							|  |  |  | timers = require 'timers' | 
					
						
							|  |  |  | Module = require 'module' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-30 10:06:10 +08:00
										 |  |  | process.atomBinding = (name) -> | 
					
						
							|  |  |  |   try | 
					
						
							|  |  |  |     process.binding "atom_#{process.type}_#{name}" | 
					
						
							|  |  |  |   catch e | 
					
						
							|  |  |  |     process.binding "atom_common_#{name}" if e.message is 'No such module' | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							| 
									
										
										
										
											2014-03-16 13:24:25 +08:00
										 |  |  | globalPaths.push path.join(process.resourcesPath, 'atom', 'common', '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 | 
					
						
							| 
									
										
										
										
											2014-09-24 15:06:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Add support for asar packages.
 | 
					
						
							|  |  |  | require './asar' |