1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
|
#!/bin/sh
# -*- coding: utf-8 -*-
exec ruby -x "$0" "$@"
#!ruby
=begin rdoc
= mikutter - the moest twitter client
Copyright (C) 2009-2016 Toshiaki Asai
This software is released under the MIT License.
http://opensource.org/licenses/mit-license.php
=end
mikutter_directory = File.expand_path(File.dirname(__FILE__))
if !ENV['DISABLE_BUNDLER_SETUP'] || ['', '0'].include?(ENV['DISABLE_BUNDLER_SETUP'].to_s)
begin
ENV['BUNDLE_GEMFILE'] = File.expand_path(File.join(File.dirname($0), "Gemfile"))
require 'bundler/setup'
rescue LoadError, SystemExit
# bundlerがないか、依存関係の解決に失敗した場合
# System の gem を使ってみる
end
end
ENV['LIBOVERLAY_SCROLLBAR'] = '0'
require 'benchmark'
require 'webrick'
require 'thread'
require 'fileutils'
require File.expand_path(File.join(mikutter_directory, 'core/boot/option'))
Mopt.parse exec_command: true
require File.expand_path(File.join(mikutter_directory, 'core/utils'))
miquire :boot, 'check_config_permission', 'mainloop', 'delayer'
miquire :core, 'service', 'environment'
Dir.chdir(Environment::CONFROOT)
miquire :boot, 'load_plugin'
notice "fire boot event"
Plugin.call(:boot, Post.primary_service)
# イベントの待受を開始する。
# _profile_ がtrueなら、プロファイリングした結果を一時ディレクトリに保存する
def boot!(profile)
begin
Mainloop.before_mainloop
if profile
require 'ruby-prof'
begin
notice 'start profiling'
RubyProf.start
Mainloop.mainloop
ensure
result = RubyProf.stop
printer = RubyProf::CallTreePrinter.new(result)
path = File.join(Environment::TMPDIR, 'profile', Time.new.strftime('%Y-%m-%d-%H%M%S'))
FileUtils.mkdir_p(path)
notice "profile: writing to #{path}"
printer.print(path: path)
notice "profile: done."
end
else
Mainloop.mainloop end
rescue => exception
into_debug_mode(exception)
notice "catch exception `#{exception.class}'"
raise exception
rescue Exception => exception
notice "catch exception `#{exception.class}'"
exception = Mainloop.exception_filter(exception)
notice "=> `#{exception.class}'"
raise exception end
exception = Mainloop.exception_filter(nil)
if exception
notice "raise mainloop exception `#{exception.class}'"
raise exception end
notice "boot! exited normally." end
def error_handling!(exception)
notice "catch #{exception.class}"
File.open(File.expand_path(File.join(Environment::TMPDIR, 'crashed_exception')), 'w'){ |io| Marshal.dump(exception, io) }
raise exception end
begin
errfile = File.join(File.expand_path(Environment::TMPDIR), 'mikutter_dump')
File.rename(errfile, File.expand_path(File.join(Environment::TMPDIR, 'mikutter_error'))) if File.exist?(errfile)
if not Mopt.debug
$stderr = File.open(errfile, 'w')
def $stderr.write(string)
super(string)
self.fsync rescue nil end end
boot!(Mopt.profile)
if(Delayer.exception)
raise Delayer.exception end
rescue Interrupt, SystemExit, SignalException => exception
notice "catch #{exception.class}"
if Delayer.exception
error_handling! Delayer.exception
else
File.delete(errfile) if File.exist?(errfile)
raise exception end
rescue Exception => exception
error_handling! exception end
notice "mainloop exited normally."
|