X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=lib%2Fsup.rb;h=fafd43035ae85acaaf399a1219c393f1bc044e04;hb=ca3a52cf864ebdb486b474bc3a734922cf904f2e;hp=ea912f875bbc522c605cc0324a39cce74a788915;hpb=947d4eb09337fe0ee20f0f71c083080fdd807859;p=sup diff --git a/lib/sup.rb b/lib/sup.rb index ea912f8..fafd430 100644 --- a/lib/sup.rb +++ b/lib/sup.rb @@ -3,6 +3,7 @@ require 'yaml' require 'zlib' require 'thread' require 'fileutils' +require 'curses' class Object ## this is for debugging purposes because i keep calling #id on the @@ -12,8 +13,26 @@ class Object end end +class Module + def yaml_properties *props + props = props.map { |p| p.to_s } + vars = props.map { |p| "@#{p}" } + klass = self + path = klass.name.gsub(/::/, "/") + + klass.instance_eval do + define_method(:to_yaml_properties) { vars } + define_method(:to_yaml_type) { "!#{Redwood::YAML_DOMAIN},#{Redwood::YAML_DATE}/#{path}" } + end + + YAML.add_domain_type("#{Redwood::YAML_DOMAIN},#{Redwood::YAML_DATE}", path) do |type, val| + klass.new(*props.map { |p| val[p] }) + end + end +end + module Redwood - VERSION = "0.0.8" + VERSION = "0.1" BASE_DIR = ENV["SUP_BASE"] || File.join(ENV["HOME"], ".sup") CONFIG_FN = File.join(BASE_DIR, "config.yaml") @@ -23,10 +42,23 @@ module Redwood CONTACT_FN = File.join(BASE_DIR, "contacts.txt") DRAFT_DIR = File.join(BASE_DIR, "drafts") SENT_FN = File.join(BASE_DIR, "sent.mbox") + LOCK_FN = File.join(BASE_DIR, "lock") + SUICIDE_FN = File.join(BASE_DIR, "please-kill-yourself") + HOOK_DIR = File.join(BASE_DIR, "hooks") YAML_DOMAIN = "masanjin.net" YAML_DATE = "2006-10-01" +## determine encoding and character set +## probably a better way to do this + $ctype = ENV["LC_CTYPE"] || ENV["LANG"] || "en-US.utf-8" + $encoding = + if $ctype =~ /\.(.*)?/ + $1 + else + "utf-8" + end + ## record exceptions thrown in threads nicely $exception = nil def reporting_thread @@ -50,23 +82,12 @@ module Redwood module_function :reporting_thread ## one-stop shop for yamliciousness - def register_yaml klass, props - vars = props.map { |p| "@#{p}" } - path = klass.name.gsub(/::/, "/") - - klass.instance_eval do - define_method(:to_yaml_properties) { vars } - define_method(:to_yaml_type) { "!#{YAML_DOMAIN},#{YAML_DATE}/#{path}" } - end - - YAML.add_domain_type("#{YAML_DOMAIN},#{YAML_DATE}", path) do |type, val| - klass.new(*props.map { |p| val[p] }) - end - end - - def save_yaml_obj object, fn, compress=false - if compress - Zlib::GzipWriter.open(fn) { |f| f.puts object.to_yaml } + def save_yaml_obj object, fn, safe=false + if safe + safe_fn = "#{File.dirname fn}/safe_#{File.basename fn}" + mode = File.stat(fn) if File.exists? fn + File.open(safe_fn, "w", mode) { |f| f.puts object.to_yaml } + FileUtils.mv safe_fn, fn else File.open(fn, "w") { |f| f.puts object.to_yaml } end @@ -91,13 +112,15 @@ module Redwood Redwood::DraftManager.new Redwood::DRAFT_DIR Redwood::UpdateManager.new Redwood::PollManager.new + Redwood::SuicideManager.new Redwood::SUICIDE_FN + Redwood::CryptoManager.new end def finish - Redwood::LabelManager.save - Redwood::ContactManager.save - Redwood::PersonManager.save - Redwood::BufferManager.deinstantiate! + Redwood::LabelManager.save if Redwood::LabelManager.instantiated? + Redwood::ContactManager.save if Redwood::ContactManager.instantiated? + Redwood::PersonManager.save if Redwood::PersonManager.instantiated? + Redwood::BufferManager.deinstantiate! if Redwood::BufferManager.instantiated? end ## not really a good place for this, so I'll just dump it here. @@ -142,25 +165,41 @@ EOM end end - module_function :register_yaml, :save_yaml_obj, :load_yaml_obj, :start, :finish, :report_broken_sources + module_function :save_yaml_obj, :load_yaml_obj, :start, :finish, + :report_broken_sources end ## set up default configuration file if File.exists? Redwood::CONFIG_FN $config = Redwood::load_yaml_obj Redwood::CONFIG_FN else + require 'etc' + require 'socket' + name = Etc.getpwnam(ENV["USER"]).gecos.split(/,/).first + email = ENV["USER"] + "@" + + begin + Socket.gethostbyname(Socket.gethostname).first + rescue SocketError + Socket.gethostname + end + $config = { :accounts => { :default => { - :name => "Sup Rocks", - :email => "sup-rocks@reading-my-emails", + :name => name, + :email => email, :alternates => [], :sendmail => "/usr/sbin/sendmail -oem -ti", :signature => File.join(ENV["HOME"], ".signature") } }, - :editor => ENV["EDITOR"] || "/usr/bin/vi", + :editor => ENV["EDITOR"] || "/usr/bin/vim -f -c 'setlocal spell spelllang=en_us' -c 'set filetype=mail'", :thread_by_subject => false, + :edit_signature => false, + :ask_for_cc => true, + :ask_for_bcc => false, + :confirm_no_attachments => true, + :confirm_top_posting => true, } begin FileUtils.mkdir_p Redwood::BASE_DIR @@ -171,7 +210,16 @@ else end require "sup/util" +require "sup/hook" + +## we have to initialize this guy first, because other classes must +## reference it in order to register hooks, and they do that at parse +## time. +Redwood::HookManager.new Redwood::HOOK_DIR + require "sup/update" +require "sup/suicide" +require "sup/message-chunks" require "sup/message" require "sup/source" require "sup/mbox" @@ -191,6 +239,7 @@ require "sup/contact" require "sup/tagger" require "sup/draft" require "sup/poll" +require "sup/crypto" require "sup/modes/scroll-mode" require "sup/modes/text-mode" require "sup/modes/line-cursor-mode" @@ -211,6 +260,8 @@ require "sup/modes/inbox-mode" require "sup/modes/buffer-list-mode" require "sup/modes/log-mode" require "sup/modes/poll-mode" +require "sup/modes/file-browser-mode" +require "sup/modes/completion-mode" require "sup/logger" require "sup/sent"