Ошибка неверного типа в методе dbus (GNU Emacs) - PullRequest
4 голосов
/ 01 июля 2010

Я пишу файл elisp для интеграции GNU Emacs с Zeitgeist через dbus.Из-за отсутствия хорошей документации по dbus в emacs и моего отсутствия опыта работы с продвинутым elisp, у меня возникает следующая ошибка в моем методе zeitgeist-send:

Аргумент неверного типа: D-Шина, (zeitgeist-event-timestamp)

Я попытался исправить проблему, поместив :string перед всеми аргументами, но это дало мне ошибку:

Аргумент неверного типа: stringp, (zeitgeist-event-timestamp)

Это не имеет смысла, так как я уверен, что значение (zeitgeist-event-timestamp) является строкой.

Если вам нужно, документация по dbus для Zeitgeist здесь здесь .Формат для него 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)

Спасибо за любую помощь!Патрик Недзельски

1 Ответ

4 голосов
/ 03 июля 2010

Я спросил в списке рассылки и обнаружил, что, поскольку я использовал (цитата ...) вместо (список ...), переменные и функции не оценивались.Глупая ошибка LISP.

Также, если кому-то будет интересно, я отправлю этот патч в проект Zeitgeist.

...