summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
* Updated Hebrew translationorigin/gtk-3-22Yosef Or Boczko2017-11-261-395/+491
|
* Updated Lithuanian translationAurimas Černius2017-11-252-635/+653
|
* Fix a nefarious typoРуслан Ижбулатов2017-11-251-1/+1
|
* GDK W32: Ensure that selection request is processedРуслан Ижбулатов2017-11-252-3/+9
| | | | | | | | | | | | | | | To do that, run the message loop for one second or until the side-effect of running the selection request handler is achieved (as opposed to running it until the event is no longer queued). The disavantage of this method is that if the event handling is somehow missed (due to a variety of reasons - after all, it's not a straight path from an event being queued to property_change() being called), this will loop for one second. Since we do process events during that time, this will not hang the application, but might still restrict some of the functionality. https://bugzilla.gnome.org/show_bug.cgi?id=786509
* GDK W32: Refuse to release mouse grab while in DnD modeРуслан Ижбулатов2017-11-251-0/+17
| | | | | | | | | | | | Handle WM_CANCELMODE and do nothing in response to it when DnD is active. Otherwise pass it to DefWindowProc, which will call ReleaseCapture() on our behalf. This prevents us from losing mouse capture when alt-tabbing during DnD (this includes the feature of Windows Explorer where dragging stuff over a window button in the taskbar causes that window to receive focus, i.e. keyboardless alt-tabbing). https://bugzilla.gnome.org/show_bug.cgi?id=786509
* GDK W32: Update layered windows on opacity changesРуслан Ижбулатов2017-11-251-68/+118
| | | | | | | | | | Without this patch layered windows are only updated when they are moved by the user or then their contents changes. This patch adds opacity changes to the list of things that make GDK update a window. Without this windows that don't redraw and are not moved by the used (DnD drag indicator windows, for example) don't change their opacity. https://bugzilla.gnome.org/show_bug.cgi?id=786509
* W32: Massive W32 DnD fixРуслан Ижбулатов2017-11-2515-1403/+4014
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Massive changes to OLE2 DnD protocol, which was completely broken before: * Keep GdkDragContext and OLE2 objects separate (don't ref/unref them together, don't necessarily create them together). * Keep IDataObject formats in the object itself, not in a global variable. * Fix getdata() to look up the request target in its format list, not in the global hash table * Create target GdkDragContext on each drag_enter, destroy it on drag_leave, whereas IDropTarget is created when a window becomes a drag destination and is re-used indefinitely. * Query the source IDataObject for its supported types, cache them in the target (!) context. This is how GTK+ works, honestly. * Remember current_src_object when we initiate a drag, to be able to detect later on that the data object is ours and use a shortcut when querying targets * Make sure GDK_DRAG_MOTION is only sent when something changes * Support GTK drag cursors * Ensure that exotic GTK clipboard formats are registered (but try to avoid registering formats that can't be used between applications). * Don't enumerate internal formats * Ensure that DnD indicator window can't accept drags or receive any kind of input (use WS_EX_TRANSPARENT). * Remove unneeded indentation in _gdk_win32_dnd_do_dragdrop() * Fix indentation in gdk_win32_drag_context_drop_finish() * Remove obsolete comments in _gdk_win32_window_register_dnd() * Check for DnD in progress when processing WM_KILLFOCUS, don't emit a grab break event in such cases (this allows alt-tabbing while DnD is in progress, though there may be lingering issues with focus after dropping...) * Support Shell ID List -> text/uri-list conversion, now it's possible to drop files (dragged from Explorer) on GTK+ applications * Explicitly use RegisterClipboardFormatA() when we know that the string is not in unicode. Otherwise explicitly use RegisterClipboardFormatW() with a UTF8->UTF16 converted string * Fix _gdk_win32_display_get_selection_owner() to correctly bail when selection owner HWND is NULL (looking up GdkWindow for NULL HWND always succeeds and returns the root window - not the intended effect) * More logging * Send DROP_FINISHED event after DnD loop ends * Send STATUS event on feedback * Move GetKeyboardState() and related code into _gdk_win32_window_drag_begin(), so that it's closer to the point where last_pt and start_pt are set * Use & 0x80 to check for the key being pressed. Windows will set low-order bit to 1 for all mouse buttons to indicate that they are toggled, so simply checking for the value not being 0 is not enough anymore. This is probably a new thing in modern W32 that didn't exist before (OLE2 DnD code is old). * Fixed (hopefully) and simplified HiDPI parts of the code. Also adds managed DnD implementation for W32 GDK backend (for both OLE2 and LOCAL protocols). Mostly a copy of the X11 backend code, but there are some minor differences: * doesn't use drag_window field in GdkDragContext, uses the one in GdkWin32DragContext exclusively * subtracts hotspot offset from the window coordinates when showing the dragback animation * tries to consistently support scaling and caches the scale in the context * Some keynav code is removed (places where grabbing/ungrabbing should happen is marked with TODOs), and the rest is probably inert. Also significantly changes the way selection (and clipboard) is handled (as MSDN rightly notes, the handling for DnD and Clipboard formats is virtually the same, so it makes sense to handle both with the same code): * Don't spam GDK_OWNER_CHANGE, send them only when owner actually changes * Open clipboard when our process becomes the clipboard owner (we are doing it anyway, to empty the clipboard and *become* the owner), and then don't close it until a scheduled selection request event (with TARGETS target) is received. Process that event by announcing all of our supported formats (by that time add_targets() should have been called up the stack, thus the formats are known; just in case, add_targets() will also schedule a selection request, if one isn't scheduled already, so that late-coming formats can still be announced). * Allow clipboard opening for selection_convert() to be delayed if it fails initially. * The last two points above should fix all the bugs about GTK+ rising too much ruckus over OpenClipboard() failures, as owner change *is allowed* to fail (though not all callers currently handle that case), and selection_convert() is asynchronous to begin with. Still, this is somewhat risky, as there's a possibility that the code will work in unexpected ways and the clipboard will remain open. There's now logging to track the clipboard being opened and closed, and a number of failsafes that try to ensure that it isn't kept open for no reason. * Added copious notes on the way clipboard works on X11, Windows and GDK-W32, also removed old comments in DnD implementation, replaced some of them with the new ones * A lot of crufty module-global variables are stuffed into a singleton object, GdkWin32Selection. It's technically possible to make it a sub-object of the Display object (the way Wayland backend does), but since Display object on W32 is a singleton anyway... why bother? * Fixed the send_change_events() a bit (was slightly broken in one of the previous iterations) * Ensure that there's no confusion between selection conversion (an artifact term from X11) and selection transmutation (changing the data to be W32-compatible) * Put all the transmutation code and format-target-matching code into gdkselection-win32.c, now this code isn't spread across multiple files. * Consequently, moved some code away from gdkproperty-win32.c and gdkdnd-win32.c * Extensive format transmutation checks for OLE2 DnD and clipboard. We now keep track of which format mappings are for transmutations, and which aren't (for example, when formats are passed as-is, or when a registered name is just an alias) * Put transmutation code into separate functions * Ensure that drop target keeps a format->target map for supported formats, this is useful when selection_convert() is called, as it only receives a single target and no hints on the format from which the data should be transmuted into this target. * Add clear_targets() on W32, to de called by GTK * Use g_set_object() instead of g_ref_object() where it is allowed. * Fix indentation (and convert tabs to spaces), remove unused variables https://bugzilla.gnome.org/show_bug.cgi?id=786509
* GDK W32: Don't leak the atom name stringРуслан Ижбулатов2017-11-251-1/+4
| | | | https://bugzilla.gnome.org/show_bug.cgi?id=786509
* GDK W32: Fix a typo in OLE2 DnD codeРуслан Ижбулатов2017-11-251-1/+1
| | | | https://bugzilla.gnome.org/show_bug.cgi?id=786509
* Only register application/x-rootwindow-drop on X11Руслан Ижбулатов2017-11-251-0/+4
| | | | | | | | | | application/x-rootwindow-drop is not useful anywhere else, so put it under #ifdef GDK_WINDOWING_X11 On W32 this prevents toplevels from automatically becoming valid drop targets with a useless drop type. https://bugzilla.gnome.org/show_bug.cgi?id=786509
* GDK W32: More flexible modal operation modeРуслан Ижбулатов2017-11-255-34/+57
| | | | | | | | | | | | | Instead of using a boolean to indicate a modal operation being in progress, use a set of flags, and allow these to be set and unset independently. Specifically, this allows WM_CAPTURECHANGED handler to only act when a drag-move or drag-resize modal operation is in progress, and ignore DND (which can also cause WM_CAPTURECHANGED to be posted). This avoids a crash due to assertion failure when OLE2 DND code tries to end a modal operation that was already ended by the WM_CAPTURECHANGED handler. https://bugzilla.gnome.org/show_bug.cgi?id=786121
* Be more specific in ::insert-emoji Since tagDaniel Boles2017-11-232-2/+2
| | | | | I had been unsure whether to include the minor version, but :show-emoji-icon already did, so do the same here to match.
* GDK W32: fix monitor pruning codeРуслан Ижбулатов2017-11-231-4/+1
| | | | | Decrement the counter for each removed element, otherwise we skip one element every time we remove one. Also, no need for continue here.
* Add Since to ::insert-emoji, and some trivialitiesDaniel Boles2017-11-222-3/+6
| | | | Document when these keybinding signals were added.
* text view: Support the Emoji chooserMatthias Clasen2017-11-222-1/+77
| | | | | | | | | Similar to GtkEntry, add an "Insert Emoji" context menu item, and add the same keybindings. We don't add the icon here, since it is not clear where it would go. https://bugzilla.gnome.org/show_bug.cgi?id=790029
* Fix indentation mishapMatthias Clasen2017-11-221-4/+4
|
* SpinButton: Explain meaning of nullable AdjustmentDaniel Boles2017-11-221-3/+3
| | | | | configure() marked the @adj argument as (allow-none) but did not explain what passing NULL would do. Fix that, and move it to (nullable) as well.
* doc: Replace uses of #NULL with %NULLDaniel Boles2017-11-226-10/+12
|
* CellRendererPixbuf: Improve property docsDaniel Boles2017-11-221-0/+16
| | | | | | Add Since annotations for the stock-* properties. Add a doc comment for :stock-size in order to link to GtkIconSize. Document :stock-detail as deprecated. It does nothing & is gone in GTK+4
* doc: TextLayout: Add missing (out) annotationsDaniel Boles2017-11-221-2/+2
| | | | and move from (allow-none) to (optional)
* emoji chooser: break out a helper functionMatthias Clasen2017-11-221-17/+25
| | | | This is just a small cleanup.
* entry: Add a key binding for the emoji chooserMatthias Clasen2017-11-222-6/+34
| | | | | | Make Ctrl-. and Ctrl-; bring up the emoji chooser. https://bugzilla.gnome.org/show_bug.cgi?id=789160
* emoji chooser: Make menu key work as expectedMatthias Clasen2017-11-221-7/+23
| | | | | Whenever we have a right-click action, we should make the menu key work as a keyboard-accessible alternative.
* emoji chooser: handle right-clickMatthias Clasen2017-11-221-21/+63
| | | | | | | | Whereever we handle long-press for touch, it makes sense to handle right-click as a faster alternative for mouse-based interaction. This commit makes right-click work to bring up the variation selector for Emojis.
* Trivial cleanupMatthias Clasen2017-11-221-1/+1
| | | | Better to use G_SOURCE_REMOVE than FALSE, for clarity.
* emoji chooser: Don't leak gesturesMatthias Clasen2017-11-221-0/+4
| | | | We were not freeing these gestures as we should.
* emojichooser: animate the adjustmentBenjamin Otte2017-11-221-28/+8
| | | | | ... instead of doing a dance with the scrolled window to get it to scroll the adjustment.
* frame-clock: Fix typo in API documentationBastien Nocera2017-11-221-1/+1
|
* Update Spanish translationDaniel Mustieles2017-11-201-355/+366
|
* Update Spanish translationDaniel Mustieles2017-11-201-270/+316
|
* Update Turkish translationMuhammet Kara2017-11-191-375/+365
|
* Update Italian translationMilo Casagrande2017-11-171-404/+414
|
* Update Italian translationMilo Casagrande2017-11-171-10/+5
|
* Update Italian translationMilo Casagrande2017-11-171-125/+138
|
* icontheme: Add a trailing / when enumerating resourcesMatthias Clasen2017-11-161-1/+3
| | | | This avoids extra string copies in GResource.
* application: Append a / to the icon resource pathMatthias Clasen2017-11-161-1/+1
| | | | | | | g_resources_enumerate_children expects the path to end in a '/' (even though thats not stated in the docs), and will copy it if that isn't the case. Avoid the copy by putting a '/' there to begin with.
* icontheme: Append a / to the resource pathMatthias Clasen2017-11-161-1/+1
| | | | | | | g_resources_enumerate_children expects the path to end in a '/' (even though thats not stated in the docs), and will copy it if that isn't the case. Avoid the copy by putting a '/' there to begin with.
* gdk: Fix GDK_ALL_EVENTS_MASKBenjamin Otte2017-11-131-1/+1
| | | | | This mask was forgotten to update when the last 2 event masks were added, probably because it looks like it's already maxed.
* gtkplacessidebar: Fix new tab/window handling for cloud accountsCarlos Soriano2017-11-131-6/+12
| | | | | | | | | | | It wasn't taking into account whether the sidebar had support for them or not, resulting in a file chooser with open in new tab/window menu items when it's not supported. To fix it, do as with the other menus and check for the availability of new tab/window flags. https://bugzilla.gnome.org/show_bug.cgi?id=786123
* gtkplacessidebar: Adapt to libcloudproviders 0.2.0Carlos Soriano2017-11-133-129/+229
| | | | | | And a few improvements on the way. https://bugzilla.gnome.org/show_bug.cgi?id=786123
* css: avoid copying resource dataChristian Hergert2017-11-121-6/+7
| | | | | | | | | | | To avoid copying data from gresources to the heap, we can use the newly added gtk_file_load_bytes(). That function will check for resource:// URIs and access their internal data directly. Other URI schemes will read the contents into memory and return a GBytes as normal. https://bugzilla.gnome.org/show_bug.cgi?id=790270
* utils: add gtk_file_load_bytes() helperChristian Hergert2017-11-122-1/+39
| | | | | | | | This helper will load GBytes for a GFile, but try to reuse the embedded data for a gresource to reduce the chances of copying data to the heap. https://bugzilla.gnome.org/show_bug.cgi?id=790270
* a11y: Handle a treeview with no columnsBenjamin Otte2017-11-131-1/+1
| | | | | Code was spewing criticals to stderr because of nonexisting columns. So check that there's actually an existing column first.
* progresstracker: Don't hand out NaNBenjamin Otte2017-11-121-3/+3
| | | | | | | | | When the duration is set to 0, clamp it to 1us. This way we're almost correct: We should really instantly finish, but we don't. But we do respect the delay. Doing this properly would require some refactoring of how the progress tracker actually maintains progress, and this is just a quick fix.
* Update Friulian translationFabio Tomat2017-11-101-450/+468
|
* Updated Norwegian bokmål translation.Kjartan Maraas2017-11-091-7/+7
|
* Window: Document get_icon() return as nullableDaniel Boles2017-11-091-1/+1
|
* CssProvider: Use consistent theme name placeholderDaniel Boles2017-11-081-3/+3
| | | | | | commit 475d916eb92c0106d09525bcca938f05fd6a81b5 added various paths that use theme-name for this, but the existing path already used THEME, with a subsequent description referring to the latter. So use that everywhere
* 3.22.263.22.26Matthias Clasen2017-11-072-2/+27
|
* Update Slovak translationDušan Kazik2017-11-071-379/+389
|