1 /* 2 * Copyright (c) 2017-2019 sel-project 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a copy 5 * of this software and associated documentation files (the "Software"), to deal 6 * in the Software without restriction, including without limitation the rights 7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 8 * copies of the Software, and to permit persons to whom the Software is 9 * furnished to do so, subject to the following conditions: 10 * 11 * The above copyright notice and this permission notice shall be included in all 12 * copies or substantial portions of the Software. 13 * 14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 20 * SOFTWARE. 21 * 22 */ 23 module loader.default_; 24 25 import core.thread : Thread, dur; 26 27 import std.concurrency : LinkTerminated; 28 import std.conv : to; 29 import std.file : write, exists, mkdirRecurse; 30 import std.path : dirSeparator; 31 import std..string : indexOf, lastIndexOf, replace; 32 33 import selery.config : Config; 34 import selery.crash : logCrash; 35 import selery.hub.hncom : LiteNode; 36 import selery.hub.plugin.plugin : HubPluginOf; 37 import selery.hub.server : HubServer; 38 import selery.node.handler : TidAddress; 39 import selery.node.plugin.plugin : NodePluginOf; 40 import selery.node.server : NodeServer; 41 42 import config : ConfigType; 43 import pluginloader; 44 import starter; 45 46 void main(string[] args) { 47 48 start(ConfigType.default_, args, (Config config){ 49 50 new Thread({ new shared HubServer(true, config, loadPlugins!(HubPluginOf, "hub")(config), args); }).start(); 51 52 while(!LiteNode.ready) Thread.sleep(dur!"msecs"(1)); //TODO add a limit in case of failure 53 54 try { 55 56 new shared NodeServer(new TidAddress(cast()LiteNode.tid), config, loadPlugins!(NodePluginOf, "node")(config), args); 57 58 } catch(LinkTerminated) { 59 60 } catch(Throwable e) { 61 62 logCrash("node", config.lang, e); 63 64 } finally { 65 66 import core.stdc.stdlib : exit; 67 exit(1); 68 69 } 70 71 }); 72 73 } 74