-;; Common Lisp bindings for GTK+ v2.0.x
-;; Copyright (C) 1999-2001 Espen S. Johnsen <espen@users.sourceforge.org>
+;; Common Lisp bindings for GTK+ v2.x
+;; Copyright 1999-2005 Espen S. Johnsen <espen@users.sf.net>
;;
-;; This library is free software; you can redistribute it and/or
-;; modify it under the terms of the GNU Lesser General Public
-;; License as published by the Free Software Foundation; either
-;; version 2 of the License, or (at your option) any later version.
+;; Permission is hereby granted, free of charge, to any person obtaining
+;; a copy of this software and associated documentation files (the
+;; "Software"), to deal in the Software without restriction, including
+;; without limitation the rights to use, copy, modify, merge, publish,
+;; distribute, sublicense, and/or sell copies of the Software, and to
+;; permit persons to whom the Software is furnished to do so, subject to
+;; the following conditions:
;;
-;; This library is distributed in the hope that it will be useful,
-;; but WITHOUT ANY WARRANTY; without even the implied warranty of
-;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-;; Lesser General Public License for more details.
+;; The above copyright notice and this permission notice shall be
+;; included in all copies or substantial portions of the Software.
;;
-;; You should have received a copy of the GNU Lesser General Public
-;; License along with this library; if not, write to the Free Software
-;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+;; EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+;; MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+;; IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+;; CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
+;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
+;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-;; $Id: gtktypes.lisp,v 1.35 2005-03-13 18:10:14 espen Exp $
+;; $Id: gtktypes.lisp,v 1.56 2007-07-09 12:50:21 espen Exp $
(in-package "GTK")
:accessor stock-item-translation-domain
:initarg :translation-domain
:type string))
- (:metaclass struct-class))
+ (:metaclass struct-class)
+ (:ref stock-item-copy)
+ (:unref stock-item-free))
-;; We don't really need to access any of these slots, but we need to
-;; specify the size of the struct somehow
-(defclass tree-iter (boxed)
+(defclass tree-iter (boxed)
((stamp :allocation :alien :type int)
(user-data :allocation :alien :type pointer)
(user-data2 :allocation :alien :type pointer)
(deftype position ()
'(or int (enum (:start 0) (:end -1) (:first 0) (:last -1))))
-(defmethod reader-function ((type (eql 'position)) &rest args)
- (declare (ignore type args))
+(define-type-method from-alien-form ((type position) form &key ref)
+ (declare (ignore type ref))
+ (from-alien-form 'int form))
+
+(define-type-method from-alien-function ((type position) &key ref)
+ (declare (ignore type ref))
+ (from-alien-function 'int))
+
+(define-type-method reader-function ((type position) &optional ref)
+ (declare (ignore type ref))
(reader-function 'int))
(define-types-by-introspection "Gtk"
("GtkWidget"
:slots
((child-properties
- :allocation :instance
+ :special t
:accessor widget-child-properties
:type container-child)
(window
((child :ignore t)
(children
:allocation :virtual
- :getter container-children
:setter (setf container-children)
- ;; The following doesn't work because gtk_container_get_children doesn't
- ;; increase the reference count of the children
-; :getter "gtk_container_get_children"
-; :reader container-children
-; :type (glist widget)
- )
+ :getter "gtk_container_get_children"
+ :reader container-children
+ :type (glist (copy-of widget)))
+ (internal-children ; for debugging
+ :allocation :virtual
+ :getter container-internal-children)
(child-type
:allocation :virtual
:getter "gtk_container_child_type"
:type boolean)
(icon-list
:allocation :virtual
- :getter "gtk_window_get_icon_list"
+ :getter %window-get-icon-list
:setter "gtk_window_set_icon_list"
:accessor window-icon-list
:initarg :icon-list
:accessor window-mnemonic-modifier
:initarg :mnemonic-modifier
:type gdk:modifier-type)
+ #?-(pkg-exists-p "gtk+-2.0" :atleast-version "2.10.0")
(transient-for
:allocation :virtual
:getter "gtk_window_get_transient_for"
(default-height :merge t :unbound -1)))
("GtkWindowGroup"
+ :dependencies (window)
:slots
((grabs
:allocation :alien
:initarg :submenu
:type widget)))
+ ("GtkMenuShell"
+ :slots
+ ((take-focus-p
+ :allocation :virtual
+ :getter "gtk_menu_shell_get_take_focus"
+ :setter "gtk_menu_shell_set_take_focus"
+ :accessor menu-shell-take-focus-p
+ :type boolean)))
+
("GtkColorSelectionDialog"
:slots
((colorsel
("GtkScrolledWindow"
:slots
- ((hscrollbar
- :allocation :alien
+ (#?-(pkg-exists-p "gtk+-2.0" :atleast-version "2.8.0")
+ (hscrollbar
+ :allocation :alien
:reader scrolled-window-hscrollbar
:type widget)
+ #?-(pkg-exists-p "gtk+-2.0" :atleast-version "2.8.0")
(vscrollbar
:allocation :alien
:reader scrolled-window-vscrollbar
+ :type widget)
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.8.0")
+ (hscrollbar
+ :allocation :virtual
+ :getter "gtk_scrolled_window_get_hscrollbar"
+ :reader scrolled-window-hscrollbar
+ :type widget)
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.8.0")
+ (vscrollbar
+ :allocation :virtual
+ :getter "gtk_scrolled_window_get_vscrollbar"
+ :reader scrolled-window-vscrollbar
:type widget)))
("GtkPaned"
:getter "gtk_menu_get_attach_widget"
:reader menu-attach-widget
:type widget)
- #-gtk2.6
+ #?-(pkg-exists-p "gtk+-2.0" :atleast-version "2.6.0")
(tearoff-state
:allocation :virtual
:getter "gtk_menu_get_tearoff_state"
:initarg :tearoff-state
:type boolean)))
- ("GtkToolbar"
+ ("GtkPlug"
:slots
- ((show-tooltips
+ ((id
:allocation :virtual
+ :getter "gtk_plug_get_id"
+ :reader plug-id
+ :type gdk:native-window)))
+
+ ("GtkSocket"
+ :slots
+ ((id
+ :allocation :virtual
+ :getter "gtk_socket_get_id"
+ :reader socket-id
+ :type gdk:native-window)))
+
+ ("GtkToolbar"
+ :slots
+ ((show-tooltips ;; this slot is equivalent to the property
+ :allocation :virtual ;; "tooltips" in Gtk+ 2.8
:getter "gtk_toolbar_get_tooltips"
:setter "gtk_toolbar_set_tooltips"
:accessor toolbar-show-tooltips-p
:getter "gtk_toolbar_get_tooltips_object"
:reader toolbar-tooltips
:type tooltips)
- (toolbar-style
+ (toolbar-style ; defined manually to get the accesssor name correct
:allocation :property
:pname "toolbar-style"
:initarg :toolbar-style
("GtkTable"
:slots
((column-spacing
- :allocation :virtual
- :getter "gtk_table_get_default_col_spacing"
- :setter "gtk_table_set_col_spacings"
+ :allocation :property :pname "column-spacing"
:initarg :column-spacing
:type unsigned-int)
(row-spacing
- :allocation :virtual
- :getter "gtk_table_get_default_row_spacing"
- :setter "gtk_table_set_row_spacings"
+ :allocation :property :pname "row-spacing"
:initarg :row-spacing
:type unsigned-int)))
:reader entry-layout
:type pango:layout)
(completion
+ :allocation :virtual
:getter "gtk_entry_get_completion"
:setter "gtk_entry_set_completion"
:initarg :completion
:accessor entry-completion
:type entry-completion)
(max-length :merge t :unbound 0)
- #+gtk2.6
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.6.0")
(width-chars :merge t :unbound -1)))
("GtkEntryCompletion"
:reader entry-completion-entry
:type entry)
(minimum-key-length :merge t :unbound -1)
- #+gtk2.6
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.6.0")
(text-column :merge t :unbound -1)))
("GtkRadioButton"
("GtkImage"
:slots
((file :ignore t)
- #+gtk2.6
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.6.0")
(pixel-size :merge t :unbound -1)))
("GtkLabel"
:type selection-mode)
(tree-view
:allocation :virtual
- :getter "gtk_tree_selection_get_mode"
- :reader tree-selection-mode
+ :getter "gtk_tree_selection_get_tree_view"
+ :reader tree-selection-tree-view
:type tree-view)))
("GtkComboBox"
:allocation :virtual
:getter "gtk_text_mark_get_name"
:reader text-mark-name
- :type string)
+ :type (copy-of string))
(visible
:allocation :virtual
:getter "gtk_text_mark_get_visible"
("GtkUIManagerItemType"
:type ui-manager-item-type)
- ("GtkToggle"
+ ("GtkAction"
:slots
((accelerator
- :allocation :virtual
- :getter action-accelerator)))
+ :allocation :user-data :initarg :accelerator
+ :reader action-accelerator)))
+ #?-(pkg-exists-p "gtk+-2.0" :atleast-version "2.10.0")
("GtkToggleAction"
:slots
((active
:allocation :virtual
:getter "gtk_toggle_action_get_active"
:setter "gtk_toggle_action_set_active"
- :initarg :active
+; :initarg :active ;; Handled by initialize-instance
:accessor toggle-action-active-p
:type boolean)))
:getter "gtk_radio_button_get_group"
:reader radio-action-group
:type (copy-of (gslist widget)))
- (%value
- :allocation :property :pname "value"
- :readable nil :type int)
+ (self
+ :allocation :property :pname "value" :type int
+ :documentation "A hack so we can use the alien function gtk_radio_action_get_current_value to retrieve the active radio action in a group.")
(value
- :allocation :virtual
- :getter radio-action-value)))
+ :allocation :user-data :initarg :value :accessor radio-action-value)
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.10.0")
+ ;; Use radio-action-get-current-value to get the current value of
+ ;; a radio action group
+ (current-value :ignore t)))
("GtkColorSelection"
:slots
:reader clipboard-display
:type gdk:display)))
- #+gtk2.6
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.6.0")
("GtkIconView"
:slots
- ((text-column :merge t :setter %icon-view-set-text-column)
- (markup-column :merge t :setter %icon-view-set-markup-column)
- (pixbuf-column :merge t :setter %icon-view-set-pixbuf-column)))
+ ((text-column
+ :allocation :virtual
+ :getter %icon-view-get-text-column
+ :setter %icon-view-set-text-column
+ :boundp %icon-view-text-column-boundp
+ :initarg :text-column
+ :accessor icon-view-text-column)
+ (markup-column
+ :allocation :virtual
+ :getter %icon-view-get-markup-column
+ :setter %icon-view-set-tmarkup-column
+ :boundp %icon-view-markup-column-boundp
+ :initarg :markup-column
+ :accessor icon-view-markup-column)
+ (pixbuf-column
+ :allocation :virtual
+ :getter %icon-view-get-pixbuf-column
+ :setter %icon-view-set-pixbuf-column
+ :boundp %icon-view-pixbuf-column-boundp
+ :initarg :pixbuf-column
+ :accessor icon-view-pixbuf-column)))
+
+ #?(pkg-exists-p "gtk+-2.0" :atleast-version "2.10.0")
+ ("GtkAssistant"
+ :slots
+ ((current-page
+ :allocation :virtual
+ :getter "gtk_assistant_get_current_page"
+ :setter "gtk_assistant_set_current_page"
+ :accessor assistant-current-page
+ :type int)
+ (num-pages
+ :allocation :virtual
+ :getter "gtk_assistant_get_n_page"
+ :reader assistant-current-page
+ :type int)))
+
;; Not needed
("GtkFundamentalType" :ignore t)
:getter "gtk_text_iter_get_visible_line_offset"
:setter "gtk_text_iter_set_visible_line_offset"
:accessor text-iter-visible-line-offset
- :type int)
- ;; Workaround to get correct size
- (dummy14
- :allocation :alien :offset #.(* 13 (size-of 'pointer))
- :type pointer))
- (:metaclass boxed-class
- ;; I am pretty sure this was working in older versons on CMUCL
-; :size #.(* 14 (size-of 'pointer))
- ))
+ :type int))
+ (:metaclass boxed-class)
+ (:size #.(* 14 (size-of 'pointer))))
(defclass tooltips-data (struct)
:initarg :mime-type
:type string))
(:metaclass struct-class))
+
+
+(defclass accel-key (struct)
+ ((key
+ :allocation :alien
+ :type unsigned-int)
+ (modifiers
+ :allocation :alien
+ :type gdk:modifier-type)
+ (flags
+ :allocation :alien
+ :type (unsigned 16)))
+ (:metaclass struct-class))
+
+(defclass accel-group-entry (struct)
+ ((key
+ :allocation :alien
+ :setter nil
+ :type (inlined accel-key))
+ (gclosure
+ :allocation :alien
+ :type gclosure)
+ (accel_path_quark
+ :allocation :alien
+ :type quark))
+ (:metaclass struct-class))
+
+#?(pkg-exists-p "gtk+-2.0" :atleast-version "2.8.0")
+(define-enum-type drop-position
+ :no-drop :drop-into :drop-left :drop-right :drop-above :drop-below)
+
+
+(defclass target-entry (struct)
+ ((target
+ :allocation :alien
+ :accessor target-entry-target
+ :initarg :target
+ :type string)
+ (flags
+ :allocation :alien
+ :accessor target-entry-flags
+ :initarg :flags
+ :type target-flags)
+ (id
+ :allocation :alien
+ :accessor target-entry-id
+ :initarg :id
+ :type unsigned-int))
+ (:metaclass struct-class))
+
+
+(defclass selection-data (boxed)
+ ((selection
+ :allocation :alien :type gdk:atom
+ :reader selection-data-selection)
+ (target
+ :allocation :alien :type gdk:atom
+ :reader selection-data-target)
+ (type
+ :allocation :alien :type gdk:atom
+ :reader selection-data-type)
+ (format
+ :allocation :alien :type int
+ :reader selection-data-format)
+ (data
+ :allocation :alien :type pointer
+ :reader selection-data-data)
+ (length
+ :allocation :alien :type int
+ :reader selection-data-length)
+ (display
+ :allocation :alien :type gdk:display
+ :reader selection-data-display))
+ (:metaclass boxed-class))
+
+
+#?-(pkg-exists-p "gtk+-2.0" :atleast-version "2.10.0")
+(defclass target-list (proxy)
+ ()
+ (:metaclass proxy-class)
+ (:ref target-list-ref)
+ (:unref target-list-unref))
+
+#?(pkg-exists-p "gtk+-2.0" :atleast-version "2.10.0")
+(defclass target-list (boxed)
+ ()
+ (:metaclass boxed-class))