diff options
| author | Jokler <jokler.contact@gmail.com> | 2018-02-10 21:00:51 +0100 |
|---|---|---|
| committer | Jokler <jokler.contact@gmail.com> | 2018-02-12 16:08:47 +0100 |
| commit | ddf42bc0292b0befe2b2f47f3284d9ffeaf6f4b4 (patch) | |
| tree | 5ecd538e3a09799d0dfe623e50eaa938453bb249 /bin/main.rs | |
| parent | 2b7c31a05684511918afbe1954fc3a6e282d13f3 (diff) | |
| download | frippy-ddf42bc0292b0befe2b2f47f3284d9ffeaf6f4b4.tar.gz frippy-ddf42bc0292b0befe2b2f47f3284d9ffeaf6f4b4.zip | |
Move main file into the src directory
Diffstat (limited to 'bin/main.rs')
| -rw-r--r-- | bin/main.rs | 113 |
1 files changed, 0 insertions, 113 deletions
diff --git a/bin/main.rs b/bin/main.rs deleted file mode 100644 index 21e27dc..0000000 --- a/bin/main.rs +++ /dev/null @@ -1,113 +0,0 @@ -extern crate frippy; -extern crate time; -extern crate irc; -extern crate glob; - -#[macro_use] -extern crate log; - -use log::{Record, Level, LevelFilter, Metadata}; - -use irc::client::reactor::IrcReactor; -use glob::glob; - -use frippy::plugins; -use frippy::Config; - -struct Logger; - -impl log::Log for Logger { - fn enabled(&self, metadata: &Metadata) -> bool { - metadata.target().contains("frippy") - } - - fn log(&self, record: &Record) { - if self.enabled(record.metadata()) { - if record.metadata().level() >= Level::Debug { - println!("[{}]({}) {} -> {}", - time::now().rfc822(), - record.level(), - record.target(), - record.args()); - } else { - println!("[{}]({}) {}", - time::now().rfc822(), - record.level(), - record.args()); - } - } - } - - fn flush(&self) {} -} - -static LOGGER: Logger = Logger; - -fn main() { - - log::set_max_level(if cfg!(debug_assertions) { - LevelFilter::Debug - } else { - LevelFilter::Info - }); - - log::set_logger(&LOGGER).unwrap(); - - // Load all toml files in the configs directory - let mut configs = Vec::new(); - for toml in glob("configs/*.toml").unwrap() { - match toml { - Ok(path) => { - info!("Loading {}", path.to_str().unwrap()); - match Config::load(path) { - Ok(v) => configs.push(v), - Err(e) => error!("Incorrect config file {}", e), - } - } - Err(e) => error!("Failed to read path {}", e), - } - } - - // Without configs the bot would just idle - if configs.is_empty() { - error!("No config file found"); - return; - } - - // Create an event loop to run the connections on. - let mut reactor = IrcReactor::new().unwrap(); - - // Open a connection and add work for each config - for config in configs { - - let mut disabled_plugins = None; - if let &Some(ref options) = &config.options { - if let Some(disabled) = options.get("disabled_plugins") { - disabled_plugins = Some(disabled - .split(",") - .map(|p| p.trim()) - .collect::<Vec<_>>()); - } - } - - let mut bot = frippy::Bot::new(); - bot.add_plugin(plugins::Help::new()); - bot.add_plugin(plugins::Url::new(1024)); - bot.add_plugin(plugins::Emoji::new()); - bot.add_plugin(plugins::Currency::new()); - bot.add_plugin(plugins::KeepNick::new()); - - if let Some(disabled_plugins) = disabled_plugins { - for name in disabled_plugins { - if let None = bot.remove_plugin(name) { - error!("{:?} was not found - could not disable", name); - } - } - } - - bot.connect(&mut reactor, &config).expect("Failed to connect"); - } - - // Run the bots until they throw an error - an error could be loss of connection - reactor.run().unwrap(); -} |
