4

GNU Emacs をdbus 経由でZeitgeistと統合するための elisp ファイルを作成しています。emacs の dbus に関する適切なドキュメントがなく、高度な elisp の経験が不足しているため、メソッドで次のエラーが発生しますzeitgeist-send

間違った型の引数: D-Bus、(zeitgeist-event-timestamp)

:stringすべての引数の前に配置して問題を修正しようとしましたが、エラーが発生しました:

間違った型の引数: stringp、(zeitgeist-event-timestamp)

(zeitgeist-event-timestamp) の値が文字列であることは確かなので、これは意味がありません。

必要に応じて、zeitgeist の dbus ドキュメントはこちらにあります。その形式はasaasay.

コードは次のとおりです。

(require 'dbus)
(defun zeitgeist-call (method &rest args)
  "Call the zeitgeist method METHOD with ARGS over dbus"
  (apply 'dbus-call-method 
    :session                            ; use the session (not system) bus
    "org.gnome.zeitgeist.Engine"        ; service name
    "/org/gnome/zeitgeist/log/activity" ; path name
    "org.gnome.zeitgeist.Log"           ; interface name
    method args))

(defun zeitgeist-event-timestamp ()
  "Get the timestamp in zeitgeist format."
  (let* ((now-time (current-time))
         (hi       (car now-time))
         (lo       (car (cdr now-time)))
         (msecs    (car (cdr (cdr now-time))))) ; This is *micro*seconds. 

    (number-to-string (+ (/ msecs 1000)
       (* (+ lo (* hi 65536))     1000))))) ; Convert system time to milliseconds.

(defun zeitgeist-event-interpretation (event)
  "Get the Event Interpretation of EVENT."
  (case event
    ('zeitgeist-open-event
       "http://zeitgeist-project.com/ontologies/2010/01/27/zg#AccessEvent")
    ('zeitgeist-close-event
       "http://zeitgeist-project.com/schema/1.0/core#CloseEvent")
    ('zeitgeist-create-event
       "http://zeitgeist-project.com/schema/1.0/core#CreateEvent")
    ('zeitgeist-modify-event
       "http://zeitgeist-project.com/schema/1.0/core#ModifyEvent")
    (otherwise nil)))

(defun zeitgeist-send (event fileurl filemime)
  "Send zeitgeist an event EVENT using the list FILEINFO."
  (let ((event-interpretation (zeitgeist-event-interpretation event)))
    (if (eq nil event-interpretation)
      (message "YOU FAIL")
      (zeitgeist-call "InsertEvents"
        '(""
        (zeitgeist-event-timestamp)
        event-interpretation
        "http://zeitgeist-project.com/schema/1.0/core#UserActivity"
        "app://emacs.desktop")
        '((fileurl
        "http://www.semanticdesktop.org/ontologies/2007/03/22/nfo/#Document"
        "http://www.semanticdesktop.org/ontologies/nfo/#FileDataObject"
        fileurl
        filemime
        (file-name-sans-versions fileurl)
        "")) ; Some black magic later
        '(:array)))))

(defun zeitgeist-open-file ()
  "Tell zeitgeist we openned a file!"
  (if (eq nil (buffer-file-name))
    (message "You are not on a file.")
    (zeitgeist-send 'zeitgeist-open-event buffer-file-name "text/plain")))

(zeitgeist-open-file)

助けてくれてありがとう!パトリック・ニージエルスキ

4

1 に答える 1

4

メーリングリストで質問したところ、(list ...) の代わりに (quote ...) を使っていたため、変数や関数が評価されていないことがわかりました。ばかげた LISP の間違いです。

また、誰かが興味を持っている場合は、このパッチを Zeitgeist プロジェクトに送信します。

乾杯、パトリック

于 2010-07-02T20:15:18.523 に答える