111 lines
3.3 KiB
CoffeeScript
111 lines
3.3 KiB
CoffeeScript
fs = require 'fs'
|
|
path = require 'path'
|
|
module = require 'module'
|
|
util = require 'util'
|
|
|
|
# We modified the original process.argv to let node.js load the atom.js,
|
|
# we need to restore it here.
|
|
process.argv.splice 1, 1
|
|
|
|
# Add browser/api/lib to require's search paths,
|
|
# which contains javascript part of Atom's built-in libraries.
|
|
homeDir =
|
|
if process.platform is 'win32'
|
|
process.env.USERPROFILE
|
|
else
|
|
process.env.HOME
|
|
|
|
syspath = []
|
|
|
|
if homeDir
|
|
syspath.push(path.resolve(homeDir, '.node_modules'))
|
|
syspath.push(path.resolve(homeDir, '.node_libraries'))
|
|
|
|
# Remove system paths from module lookups as it may contain modules not
|
|
# shipped with the app or compiled with wrong v8 headers.
|
|
syspath.map (path) ->
|
|
index = module.globalPaths.indexOf path
|
|
if index > -1
|
|
module.globalPaths.splice(index,1)
|
|
|
|
globalPaths = module.globalPaths
|
|
globalPaths.push path.resolve(__dirname, '..', 'api', 'lib')
|
|
|
|
# Import common settings.
|
|
require path.resolve(__dirname, '..', '..', 'common', 'lib', 'init')
|
|
|
|
if process.platform is 'win32'
|
|
# Redirect node's console to use our own implementations, since node can not
|
|
# handle console output when running as GUI program.
|
|
print = (args...) ->
|
|
process.log util.format(args...)
|
|
console.log = console.error = console.warn = print
|
|
process.stdout.write = process.stderr.write = print
|
|
|
|
# Always returns EOF for stdin stream.
|
|
Readable = require('stream').Readable
|
|
stdin = new Readable
|
|
stdin.push null
|
|
process.__defineGetter__ 'stdin', -> stdin
|
|
|
|
# Don't quit on fatal error.
|
|
process.on 'uncaughtException', (error) ->
|
|
# Do nothing if the user has a custom uncaught exception handler.
|
|
if process.listeners('uncaughtException').length > 1
|
|
return
|
|
|
|
# Show error in GUI.
|
|
stack = error.stack ? "#{error.name}: #{error.message}"
|
|
message = "Uncaught Exception:\n#{stack}"
|
|
require('dialog').showErrorBox 'A JavaScript error occured in the browser process', message
|
|
|
|
# Emit 'exit' event on quit.
|
|
app = require 'app'
|
|
app.on 'quit', ->
|
|
process.emit 'exit'
|
|
|
|
# Load the RPC server.
|
|
require './rpc-server'
|
|
|
|
# Load the guest view manager.
|
|
require './guest-view-manager'
|
|
require './guest-window-manager'
|
|
|
|
# Now we try to load app's package.json.
|
|
packageJson = null
|
|
|
|
searchPaths = [ 'app', 'app.asar', 'default_app' ]
|
|
for packagePath in searchPaths
|
|
try
|
|
packagePath = path.join process.resourcesPath, packagePath
|
|
packageJson = JSON.parse(fs.readFileSync(path.join(packagePath, 'package.json')))
|
|
break
|
|
catch e
|
|
continue
|
|
|
|
throw new Error("Unable to find a valid app") unless packageJson?
|
|
|
|
# Set application's version.
|
|
app.setVersion packageJson.version if packageJson.version?
|
|
|
|
# Set application's name.
|
|
if packageJson.productName?
|
|
app.setName packageJson.productName
|
|
else if packageJson.name?
|
|
app.setName packageJson.name
|
|
|
|
# Set application's desktop name.
|
|
if packageJson.desktopName?
|
|
app.setDesktopName packageJson.desktopName
|
|
else
|
|
app.setDesktopName "#{app.getName()}.desktop"
|
|
|
|
# Set the user path according to application's name.
|
|
app.setPath 'userData', path.join(app.getPath('appData'), app.getName())
|
|
app.setPath 'userCache', path.join(app.getPath('cache'), app.getName())
|
|
|
|
# Load the chrome extension support.
|
|
require './chrome-extension'
|
|
|
|
# Finally load app's main.js and transfer control to C++.
|
|
module._load path.join(packagePath, packageJson.main), module, true
|