Commit Graph

43813 Commits

Author SHA1 Message Date
Ell
6c0326a4fa app: add gimp_gegl_node_has_key()
... which determines if a node's operation-class has a specific
key, and can be used instead of gimp_gegl_node_get_key() when only
existence is important, to avoid compiler warnings.

Update the rest of the code to use the new function.
2020-04-07 19:42:48 +03:00
Ell
2bd0b77ad0 app: use gimp_drawable_supports_alpha() in GimpDrawableFilter
... instead of GIMP_IS_LAYER()
2020-04-07 19:42:48 +03:00
Ell
80fd7386e2 app: use gimp_drawable_filter_get_format() in GimpFilterTool
... to set the visibility of the clipping-mode combo based on the
filter's actual output format, instead of the drawable format.
2020-04-07 19:42:48 +03:00
Ell
9906efd28a app: add gimp_drawable_filter_get_{drawable,operation,format}()
... which return the filter's drawable, operation, and output
format, respectively.
2020-04-07 19:42:48 +03:00
58e5b57492 Update Chinese (Taiwan) translation 2020-04-07 00:49:19 +00:00
a813c0db3a Update Chinese (Taiwan) translation 2020-04-07 00:45:48 +00:00
6d442eb76e Update Chinese (Taiwan) translation 2020-04-07 00:40:54 +00:00
63ca72c84f Update Swedish translation 2020-04-06 18:36:51 +00:00
4af498496a Fixes to Catalan translation 2020-04-05 21:04:47 +02:00
d332b1bd8d Update Polish translation 2020-04-05 12:20:13 +02:00
ebd89523bb Update Ukrainian translation 2020-04-05 06:52:42 +00:00
c82bf2978a app: make version + revision string translatable.
Also add some comment for translators on this string and another.
Thanks to Piotr Drąg for commenting on these.

(cherry picked from commit 023919d606)
2020-04-04 16:41:38 +02:00
d942908a3b Updated Italian translation 2020-04-04 01:53:13 +02:00
2484871cbc plug-ins: do not use strcpy() when src and dest overlap.
I don't reproduce these build warnings in my build but frogonia reported
them:

> warning: 'strcpy' accessing 1 byte at offsets 0 and [0, 2147483645] may overlap 1 byte at offset 0 [-Wrestrict]

And indeed the man of strcpy() clearly states that "The strings may not
overlap" (which is clearly not guaranted in current code as we don't
know the size of what's after the substring).
strncpy() might have done the trick as it doesn't say anything about
possible overlap or not, but let's just use memmove() instead where it
is clearly written that memory areas may overlap (note that bcopy() as
proposed by ankh would have also done the trick, but it is marked as
deprecated).

(cherry picked from commit 291af71e95)
2020-04-04 01:13:12 +02:00
19618a5b82 NEWS: update. 2020-04-03 20:52:42 +02:00
7665228bdb Issue #4487: change "Save color values from transparent pixels"…
… defaults to FALSE for PNG, TIFF.
The logics is that in most case, when alpha is 0, you don't expect color
to be retrieved and some people were bothered by this when erasing data
with eraser tool or selection deletion.

For the WIP image as well as for XCF format, we definitely want to keep
color data as there are workflows where you would want to erase/unerase
pixels subtly (selection also are not binary and should not be expected
to erase color data on layers with alpha channel). So we want to keep
the non-destructive behavior there.
Yet for export formats, going for "deleting what looks deleted" is a
valid approach, especially as it has been argued that experienced users
would know how to read and change the format options (and these
experienced users are likely the ones who may have valid reasons to want
pixels with full transparency to keep color values).
PNG and TIFF were the only 2 formats where I see such options, so
changing the default for these 2 plug-ins.

(cherry picked from commit 105c4efc8b for
the TIFF one and adapted to gimp-2-10 code for PNG)
2020-04-03 20:17:37 +02:00
168426a7b0 Issue #4904: GIMP startup SLOW due to failed access to…
… oscp-router0[12].gnome.org.

The file was opened asynchronously through g_file_read_async() but the
actually reading from a GFileInputStream was actually done in the
callback, in the main thread. So it may be possible that file is
accessible but connection is very slow or non-reliable and actual
reading would block the main process. I am assuming this is what may
have happened for this reporter.

Instead let's use g_file_load_contents_async() which does the file
opening, reading and closing all in the asynchronous task, hence would
not slow down anything even if the remote resource is unavailable or
connection is very slow.

(cherry picked from commit cc16ec5f9f)
2020-04-03 19:33:03 +02:00
Ell
64603c2ce6 Issue #4895 - Crash when dragging a dockable dialog
Apparently, the "drag-begin" signal of dockbook tabs can be raised
multiple times when a drag begins (this seems to happen randomly,
and rarely -- possibly a GTK bug).  In
gimp_paned_box_drag_callback(), which gets called in response, make
sure not to leak the corresponding idle source in this case, which
can lead to a segfault if the widget is destroyed before the idle
is run.

(cherry picked from commit 6bae5d8cf7)
2020-04-03 20:05:49 +03:00
ace03e5bc0 Updated Italian translation 2020-04-03 18:01:50 +02:00
927cea860a Updated Italian translation 2020-04-03 15:14:27 +02:00
Ell
b5e88ab95a app: regenerate config-enums.c 2020-04-02 22:32:09 +03:00
Ell
17e14487b8 app: add missing change to gimpdrawablefilter.c 2020-04-02 22:23:00 +03:00
c3f93e5fef app: run gtk_widget_show() on the new checkbox.
It was unneeded on master, surely because there must be a
gtk_widget_show_all() run somewhere down the line.

Also reuse the button widget (not so important, but while I'm at it).
2020-04-02 18:25:34 +02:00
Ell
d35f8c67e7 app: add missing changes to last commits
(cherry picked from commit 491dc85242)
2020-04-02 19:18:22 +03:00
Ell
122d4b6f05 app: don't detroy cached data when disabling filter-tool preview
In GimpFilterTool, use gimp_drawable_filter_set_preview(), added in
the previous commit, to toggle the filter's preview, instead of
removing and re-adding the filter.  This avoids destroying cached
results when disabling the preview, allowing to quickly toggle the
preview on and off to compare the result.

(cherry picked from commit 912b36a8f8)
2020-04-02 19:04:53 +03:00
Ell
1da36f32a1 app: add gimp_drawable_filter_set_preview()
... which allows enabling/disabling the filter's preview, without
destroying cached data.

(cherry picked from commit 7ec033d896)
2020-04-02 18:57:12 +03:00
Ell
98e1f6a846 app: rename gimp_drawable_filter_set_preview() to _set_preview_split()
... in preparation for next commit.

Update GimpFilterTool accordingly.

(cherry picked from commit 616530e235)
2020-04-02 18:57:11 +03:00
Ell
3d727809da app: add gimp_applicator_set_active()
... which allows temporarily turning the applicator into a NOP,
without destroying cached data.

This commit also improves gimp_applicator_set_{src,dest}_buffer().

(cherry picked from commit e324e2d4b3)
2020-04-02 18:56:15 +03:00
9f04d96d9b Updated Italian translation 2020-04-02 11:37:02 +02:00
281b480d62 Update Ukrainian translation 2020-04-01 19:35:02 +00:00
825b2a7c91 NEWS: update. 2020-04-01 21:25:28 +02:00
16678f4db0 app: make new feature delete-pixels in Crop tool FALSE by default.
Better have the non-destructive behavior by default.

(cherry picked from commit 6a972786d9)
2020-04-01 21:17:59 +02:00
d5fc3e8009 app: leave locked pixels alone when cropping
Cropping tools will no longer discard layer data that falls out of the
crop region if the layer's pixels are locked

(cherry picked from commit 9a9e2e9a19)
2020-04-01 21:17:58 +02:00
824a5a4580 app: make deletion of cropped pixels in crop tool optional
Adds a new "Delete cropped pixels" toggle to the crop tool options,
to allow turning off the deletion of layer data that falls out of the
crop region.

(cherry picked from commit ee97c25b87)
2020-04-01 21:17:57 +02:00
3689332483 Update Ukrainian translation 2020-04-01 18:30:29 +00:00
f2e46deb73 NEWS: update. 2020-04-01 18:24:52 +02:00
b8c4e936eb Issue #4871: Plug-ins not translated.
Revert "app: also localize LC_TIME to GUI language."
This reverts commit a4e65ac836.

LC_TIME format apparently does not accept the broader format with just
the lang part, for instance "fr". The region is necessary, like "fr_FR".
In our supported languages, we were mostly using lang only except for a
few langs where we support regional variants.
This makes sense as time format may be quite different depending on
regions (dates are quite different in GB vs US, though that was actually
one of the cases where we were using accurate locale format).

And the main issue is that it was not only breaking time localization.
Normal string localization (LANGUAGE) got somehow broken as well by
broken LC_TIME.

Anyway for now let's just stick to whatever OS-set time format (even
though it may differ from GIMP Preferences-set language defaults).

(cherry picked from commit 39890a49eb)
2020-04-01 18:13:31 +02:00
1b14b13e40 app: no generic comment when no revision comment set.
After discussing with Schumaml and Houz on IRC, let's just drop the
generic comment which may be confusing and is probably unecessary,
especially now that I write the revision number (present and new ones).
So let's just assume people understand that they should update, even
when GIMP version stays the same (this was the case I was the most wary
about, that people think the notification is an error as since they have
the last version, they don't have to update GIMP).

I hesitated to at least leave just the simple "It is recommended to
update." sentence but after much hesitation, let's go with no generic
comment at all. The download button by itself should suffice.

Of course, when a specific revision comment is set in
gimp_versions.json, it is still displayed.

(cherry picked from commit 56ffa2fd11)
2020-04-01 16:47:54 +02:00
6cd49b8e6e Fix GTK+3 only code from commit 6d0886032d.
- gtk_show_uri_on_window() replaced by gtk_show_uri()
- gtk_button_new_from_icon_name replaced by
  gtk_image_new_from_icon_name() in a GtkButton.
- gtk_widget_set_margin_top() removed.
2020-04-01 15:39:25 +02:00
3c50032a7b app: do not free non-allocated DBus manager.
While this issue was unseen so far on common desktop machines, the CI
build encountered it, hence failing 6 of the unit tests.
A connection to the bus could not be established hence the dbus_manager
was never allocated, and finally it would crash at exit if we tried to
unref it unconditionnally. Use g_clear_object() instead.

Also add some stderr output for easier debugging, for when one of the 2
possible error cases might happen (as documented by g_bus_own_name()).

(cherry picked from commit 2c1efdedf0)
2020-04-01 15:08:35 +02:00
e0f3a9d834 app-tools, app: gimp-debug-tool crashing with NULL release_date.
The crash dialog was failing to be created when using the last version
of GIMP!

(cherry picked from commit d76c8e8cc3)
2020-04-01 15:08:35 +02:00
e3d83fb8e5 app: fix minor indentation bugs.
(cherry picked from commit dd705e21c0)
2020-04-01 15:08:35 +02:00
6d0886032d app: GUI improvements to the update display in About dialog.
- Instead of the download link being just a link button (similar to
  browser "blue text" links), make it a proper button encompassing the
  update icon and the download text "Download GIMP X.Y.Z".
- Make also the revision number part of the download information.
- Frame title is now "Update available!" instead of "New version
  available!" (because it's not necessarily a new version, it can also
  be just a package revision. "Update" is more generic).
- When no update is available, the "Check for updates" button is big and
  has a label, and also now an icon. When an update is available, hence
  we display now a button for the download link, the "Check for updates"
  button becomes small with icon only in order not to take visual
  priority over the download itself (yet allowing to re-check for even
  newer information).

(cherry picked from commit a55e898c96)
2020-04-01 15:08:35 +02:00
0badb9d468 app: display revision number in About dialog if > 0.
(cherry picked from commit 21e090aba5)
2020-04-01 15:08:35 +02:00
108f782f5e app: let's display the release comment in update notification…
… when there is one such comment.

(cherry picked from commit 75a03b02f4)
2020-04-01 15:08:35 +02:00
9d03027fb3 app: show time of last version update check.
As noted on IRC, after the first update check on a given day, it looks
like the check button does nothing. Therefore also display the check
time to clearly show the button click was taken into account (simply
there are no updates, hence only displayed check time is updated).

(cherry picked from commit a05b085112)
2020-04-01 15:08:35 +02:00
0521e58006 Update Ukrainian translation 2020-03-31 18:08:28 +00:00
4d847c9f06 App gimptooleditor fix tooltip text
(cherry picked from commit 450ebd5e2b)
2020-03-31 02:37:45 +00:00
dd4cec577d app: print gimp_versions.json parsing error on stderr.
Do it even on stable builds as it can help diagnose bugs on releases.
Note that the issue we had just know with casing on the build-id would
not have been seen by such stderr output anyway. Just in case for future
issues.
2020-03-30 14:40:20 +02:00
6154099e3c Update Polish translation 2020-03-29 13:00:22 +02:00