;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-;; $Id: gtk.lisp,v 1.49 2006/02/06 19:16:17 espen Exp $
+;; $Id: gtk.lisp,v 1.61 2006/04/25 13:37:29 espen Exp $
(in-package "GTK")
(format nil "Gtk+ v~A.~A.~A" major minor micro))))
(defun clg-version ()
- "clg 0.91 version")
+ "clg 0.92.1")
;;;; Initalization
(defun clg-init (&optional display)
"Initializes the system and starts the event handling"
+ #+sbcl(when (and
+ (find-package "SWANK")
+ (eq (symbol-value (find-symbol "*COMMUNICATION-STYLE*" "SWANK")) :spawn))
+ (error "When running clg in Slime the communication style :spawn can not be used. See the README file and <http://common-lisp.net/project/slime/doc/html/slime_45.html> for more information."))
+
(unless (gdk:display-get-default)
(gdk:gdk-init)
(unless (gtk-init)
(setq *max-event-to-sec* 0)
(setq *max-event-to-usec* 1000))))
+#+sbcl
+(defun clg-init-with-threading (&optional display)
+ "Initializes the system and starts the event handling"
+ (unless (gdk:display-get-default)
+ (gdk:gdk-init)
+ (gdk:threads-set-lock-functions)
+ (unless (gtk-init)
+ (error "Initialization of GTK+ failed."))
+ (sb-thread:make-thread
+ #'(lambda ()
+ (gdk:display-open display)
+ (gdk:with-global-lock (main)))
+ :name "gtk event loop")))
+
+
+;;; Generic functions
+
+(defgeneric add-to-radio-group (item1 item2))
+(defgeneric activate-radio-widget (item))
+(defgeneric (setf tool-item-tip-text) (tip-text tool-item))
+(defgeneric (setf tool-item-tip-private) (tip-private tool-item))
+
+
;;; Misc
#+gtk2.6
(progn
- (def-callback-marshal %about-dialog-activate-link-func
- (nil (dialog about-dialog) (link (copy-of string))))
+ (define-callback-marshal %about-dialog-activate-link-callback nil
+ (about-dialog (link string)))
(defbinding about-dialog-set-email-hook (function) nil
- ((callback %about-dialog-activate-link-func) pointer)
+ (%about-dialog-activate-link-callback callback)
((register-callback-function function) unsigned-int)
- ((callback user-data-destroy-func) pointer))
+ (user-data-destroy-callback callback))
(defbinding about-dialog-set-url-hook (function) nil
- ((callback %about-dialog-activate-link-func) pointer)
+ (%about-dialog-activate-link-callback callback)
((register-callback-function function) unsigned-int)
- ((callback user-data-destroy-func) pointer)))
+ (user-data-destroy-callback callback)))
;;; Acccel group
(defbinding accel-map-save () nil
(filename pathname))
-(defcallback %accel-map-foreach-func
- (nil
- (callback-id unsigned-int) (accel-path (copy-of string))
- (key unsigned-int) (modifiers gdk:modifier-type) (changed boolean))
- (invoke-callback callback-id nil accel-path key modifiers changed))
+(define-callback-marshal %accel-map-foreach-callback nil
+ ((accel-path string) (key unsigned-int)
+ (modifiers gdk:modifier-type) (changed boolean)) :callback-id :first)
(defbinding %accel-map-foreach (callback-id) nil
(callback-id unsigned-int)
- (%accel-map-foreach-func callback))
+ (%accel-map-foreach-callback callback))
(defbinding %accel-map-foreach-unfiltered (callback-id) nil
(callback-id unsigned-int)
- (%accel-map-foreach-func callback))
+ (%accel-map-foreach-callback callback))
(defun accel-map-foreach (function &optional (filter-p t))
(with-callback-function (id function)
#+gtk2.6
(defbinding (dialog-set-alternative-button-order
- "gtk_dialog_set_alternative_button_order_from_array")
- (dialog new-order)
+ "gtk_dialog_set_alternative_button_order_from_array")
+ (dialog new-order) nil
(dialog dialog)
((length new-order) int)
((map 'vector #'(lambda (response)
;;; Entry Completion
-(def-callback-marshal %entry-completion-match-func
- (boolean entry-completion string (copy-of tree-iter)))
+(define-callback-marshal %entry-completion-match-callback boolean
+ (entry-completion string tree-iter))
(defbinding entry-completion-set-match-func (completion function) nil
(completion entry-completion)
- ((callback %entry-completion-match-func) pointer)
+ (%entry-completion-match-callback callback)
((register-callback-function function) unsigned-int)
- ((callback user-data-destroy-func) pointer))
+ (user-data-destroy-callback callback))
(defbinding entry-completion-complete () nil
(completion entry-completion))
(defbinding file-filter-add-pixbuf-formats () nil
(filter file-filter))
-(def-callback-marshal %file-filter-func (boolean file-filter-info))
+(define-callback-marshal %file-filter-callback boolean (file-filter-info))
(defbinding file-filter-add-custom (filter needed function) nil
(filter file-filter)
(needed file-filter-flags)
- ((callback %file-filter-func) pointer)
+ (%file-filter-callback callback)
((register-callback-function function) unsigned-int)
- ((callback user-data-destroy-func) pointer))
+ (user-data-destroy-callback callback))
(defbinding file-filter-get-needed () file-filter-flags
(filter file-filter))
;;; Message dialog
-(defmethod initialize-instance ((dialog message-dialog)
- &key (message-type :info) (buttons :close)
- flags text #+gtk 2.6 secondary-text
- transient-parent)
- (setf
- (slot-value dialog 'location)
- (%message-dialog-new transient-parent flags message-type buttons))
+(defmethod allocate-foreign ((dialog message-dialog) &key (message-type :info)
+ (buttons :close) flags transient-parent)
+ (%message-dialog-new transient-parent flags message-type buttons))
+
+
+(defmethod shared-initialize ((dialog message-dialog) names
+ &key text #+gtk 2.6 secondary-text)
+ (declare (ignore names))
(when text
(message-dialog-set-markup dialog text))
#+gtk2.6
(initial-add window #'window-add-accel-group
initargs :accel-group :accel-groups)))
+#-debug-ref-counting
+(defmethod print-object ((window window) stream)
+ (if (and
+ (proxy-valid-p window)
+ (slot-boundp window 'title)
+ (not (zerop (length (window-title window)))))
+ (print-unreadable-object (window stream :type t :identity nil)
+ (format stream "~S at 0x~X"
+ (window-title window) (sap-int (foreign-location window))))
+ (call-next-method)))
(defbinding window-set-wmclass () nil
(window window)
(window window)
(left int :out) (top int :out) (rigth int :out) (bottom int :out))
-(defbinding %window-get-icon-list () (glist gdk:pixbuf)
+(defbinding %window-get-icon-list () (glist (copy-of gdk:pixbuf))
(window window))
(defbinding window-get-position () nil
(width int)
(heigth int))
-(defbinding %window-get-icon-list () (glist (copy-of gdk:pixbuf))
- (window window))
-
;;; Window group
(top-attach unsigned-int)
(bottom-attach unsigned-int))
-(def-callback-marshal %menu-position-func (nil (menu menu) (x int) (y int) (push-in boolean)))
+(define-callback-marshal %menu-position-callback nil
+ (menu (x int) (y int) (push-in boolean)))
(defbinding %menu-popup () nil
(menu menu)
(parent-menu-shell (or null menu-shell))
(parent-menu-item (or null menu-item))
- (callback-func (or null pointer))
+ (callback (or null callback))
(callback-id unsigned-int)
(button unsigned-int)
(activate-time (unsigned 32)))
(with-callback-function (id callback)
(%menu-popup
menu parent-menu-shell parent-menu-item
- (callback %menu-position-func) id button activate-time))
+ %menu-position-callback id button activate-time))
(%menu-popup
menu parent-menu-shell parent-menu-item nil 0 button activate-time)))
(%menu-set-active menu (%menu-position menu child))
child)
-(defcallback %menu-detach-func (nil (widget widget) (menu menu))
+(define-callback %menu-detach-callback nil ((widget widget) (menu menu))
(funcall (object-data menu 'detach-func) widget menu))
-(defbinding %menu-attach-to-widget () nil
+(defbinding %menu-attach-to-widget (menu widget) nil
(menu menu)
(widget widget)
- ((callback %menu-detach-func) pointer))
+ (%menu-detach-callback callback))
(defun menu-attach-to-widget (menu widget function)
(setf (object-data menu 'detach-func) function)
(location pointer))
(defun stock-lookup (stock-id)
- (let ((location
- (allocate-memory (foreign-size (find-class 'stock-item)))))
- (unwind-protect
- (when (%stock-lookup stock-id location)
- (ensure-proxy-instance 'stock-item (%stock-item-copy location)))
- (deallocate-memory location))))
+ (with-allocated-memory (stock-item (foreign-size (find-class 'stock-item)))
+ (when (%stock-lookup stock-id stock-item)
+ (ensure-proxy-instance 'stock-item (%stock-item-copy stock-item)))))
+
+#+gtk2.8
+(progn
+ (define-callback-marshal %stock-translate-callback string ((path string)))
+
+ (defbinding (stock-set-translate-function "gtk_stock_set_translate_func")
+ (domain function) nil
+ (domain string)
+ (%stock-translate-callback callback)
+ ((register-callback-function function) unsigned-int)
+ (user-data-destroy-callback callback)))
+
;;; Tooltips
;;; Resource Files
-(defbinding rc-add-default-file (filename) nil
- ((namestring (truename filename)) string))
+(defbinding rc-get-style () style
+ (widget widget))
+
+(defbinding rc-get-style-by-paths (&key path class-path class) style
+ (path (or null string))
+ (class-path (or null string))
+ (class gtype))
-(defbinding rc-parse (filename) nil
- ((namestring (truename filename)) string))
+(defbinding rc-parse () nil
+ (filename pathname))
(defbinding rc-parse-string () nil
(rc-string string))
-(defbinding rc-reparse-all () nil)
+(defbinding %rc-reparse-all () boolean)
-(defbinding rc-get-style () style
- (widget widget))
+(defbinding %rc-reparse-all-for-settings () boolean
+ (settings settings)
+ (force-load-p boolean))
+
+(defun rc-reparse-all (&optional setting force-load-p)
+ (if setting
+ (%rc-reparse-all-for-settings setting force-load-p)
+ (%rc-reparse-all)))
+
+(defbinding rc-reset-styles () nil
+ (settings settings))
+
+(defbinding rc-add-default-file () nil
+ (filename pathname))
+
+(defbinding rc-get-default-files ()
+ (copy-of (null-terminated-vector (copy-of string))))
+
+(defbinding rc-get-module-dir () string)
+
+(defbinding rc-get-im-module-path () string)
+
+(defbinding rc-get-im-module-file () string)
+
+(defbinding rc-get-theme-dir () string)
+
+
+;;; Settings
+
+(defbinding (settings-get "gtk_settings_get_for_screen")
+ (&optional (screen (gdk:display-get-default-screen))) settings
+ (screen gdk:screen))
+
+
+;;; Plug and Socket
+
+(defbinding socket-add-id () nil
+ (socket socket)
+ (id gdk:native-window))
+
+(defbinding %plug-new () pointer
+ (id gdk:native-window))
+
+(defmethod allocate-foreign ((plug plug) &key id)
+ (%plug-new (or id 0)))