antos-frontend/src/core/core.coffee

91 lines
3.2 KiB
CoffeeScript
Raw Normal View History

#define the OS object
self = this
self.OS or=
2017-08-27 23:40:02 +02:00
API: {}
GUI: {}
APP: {}
setting:
user: {}
applications: {}
appearance: {}
courrier:
observable: riot.observable()
2017-08-26 16:50:13 +02:00
quota: 0
listeners: new Object
on: (e, f, a) ->
_courrier.listeners[a.pid] = [] unless _courrier.listeners[a.pid]
_courrier.listeners[a.pid].push { e: e, f: f }
_courrier.observable.on e, f
trigger: (e, d) -> _courrier.observable.trigger e, d
2017-08-27 23:40:02 +02:00
osfail: (m, e, s) ->
_courrier.ostrigger "fail", { m: m, e: e, s: s }
oserror: (m, e, s) ->
_courrier.ostrigger "error", { m: m, e: e, s: s }
ostrigger: (e, d) ->
_courrier.trigger e, { id: 0, data: d, name: "OS" }
unregister: (app) ->
return unless _courrier.listeners[app.pid] and _courrier.listeners[app.pid].length > 0
_courrier.observable.off i.e, i.f for i in _courrier.listeners[app.pid]
delete _courrier.listeners[app.pid]
_courrier.listeners[app.pid] = []
2017-08-26 16:50:13 +02:00
getMID: () ->
_courrier.quota += 1
_courrier.quota
2017-08-24 01:53:13 +02:00
register: (name, x) ->
2017-08-27 23:40:02 +02:00
if x.type is 3 then self.OS.GUI.dialog[name] = x else _OS.APP[name] = x
PM:
pidalloc: 0
2017-08-27 23:40:02 +02:00
processes: {}
createProcess: (app, cls, args) ->
#if it is single ton
# and a process is existing
# just return it
if cls.singleton and _PM.processes[app] and _PM.processes[app].length == 1
_PM.processes[app][0].show()
else
_PM.processes[app] = [] if not _PM.processes[app]
2017-08-27 23:40:02 +02:00
obj = new cls(args)
obj.birth = (new Date).getTime()
_PM.pidalloc++
obj.pid = _PM.pidalloc
_PM.processes[app].push obj
if cls.type is 1 then _GUI.dock obj, cls.meta else _GUI.attachservice obj
if cls.type is 2
_courrier.trigger "srvroutineready", app
appByPid: (pid) ->
app = undefined
find = (l) ->
return a for a in l when a.pid is pid
for k, v of _PM.processes
app = find v
break if app
app
kill: (app) ->
2017-08-27 23:40:02 +02:00
return if not app.name or not _PM.processes[app.name]
i = _PM.processes[app.name].indexOf app
if i >= 0
2017-08-27 23:40:02 +02:00
if _OS.APP[app.name].type == 1 then _GUI.undock app else _GUI.detachservice app
_courrier.unregister app
delete _PM.processes[app.name][i]
_PM.processes[app.name].splice i, 1
2017-08-27 23:40:02 +02:00
killAll: (app) ->
return unless _PM.processes[app]
tmp = []
tmp.push a for a in _PM.processes[app]
a.quit() for a in tmp
boot: ->
2017-08-27 23:40:02 +02:00
#first login
_API.handler.auth (d) ->
# in case someone call it more than once :)
if d.error
# show login screen
_GUI.login()
else
# startX :)
_GUI.startAntOS d.result