From 3cd054099bad1135634e7083b19c168aa75596fb Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 10:26:17 -0400 Subject: [PATCH 01/15] Let grdimage shading=None or False work Refactor grdimage to check `if "I" in kwargs` to using `if kwargs.get("I") is not None`. --- pygmt/src/grdimage.py | 2 +- pygmt/tests/test_grdimage.py | 15 +++++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/pygmt/src/grdimage.py b/pygmt/src/grdimage.py index 52cb637e32a..155f0ef2a70 100644 --- a/pygmt/src/grdimage.py +++ b/pygmt/src/grdimage.py @@ -166,7 +166,7 @@ def grdimage(self, grid, **kwargs): file_context = lib.virtualfile_from_data(check_kind="raster", data=grid) with contextlib.ExitStack() as stack: # shading using an xr.DataArray - if "I" in kwargs and data_kind(kwargs["I"]) == "grid": + if kwargs.get("I") is not None and data_kind(kwargs["I"]) == "grid": shading_context = lib.virtualfile_from_grid(kwargs["I"]) kwargs["I"] = stack.enter_context(shading_context) diff --git a/pygmt/tests/test_grdimage.py b/pygmt/tests/test_grdimage.py index b6ec545b782..efa1e73e636 100644 --- a/pygmt/tests/test_grdimage.py +++ b/pygmt/tests/test_grdimage.py @@ -92,6 +92,21 @@ def test_grdimage_file(): return fig +@pytest.mark.mpl_image_compare(filename="test_grdimage_slice.png") +@pytest.mark.parametrize("shading", [None, False]) +def test_grdimage_default_no_shading(grid, shading): + """ + Plot an image with no shading. + + This is a regression test for + https://github.com/GenericMappingTools/pygmt/issues/1852 + """ + grid_ = grid.sel(lat=slice(-30, 30)) + fig = Figure() + fig.grdimage(grid_, cmap="earth", projection="M6i", shading=shading) + return fig + + @check_figures_equal() @pytest.mark.parametrize( "shading", From 3b722e67daddbc4e1303fdfa028074da5d26e22a Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 10:40:45 -0400 Subject: [PATCH 02/15] Let grd2cpt's categorical, cyclic and output work with None input --- pygmt/src/grd2cpt.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/pygmt/src/grd2cpt.py b/pygmt/src/grd2cpt.py index 2173fe30bc7..2e8e80357f9 100644 --- a/pygmt/src/grd2cpt.py +++ b/pygmt/src/grd2cpt.py @@ -160,14 +160,14 @@ def grd2cpt(grid, **kwargs): ``categorical=True``. {V} """ - if "W" in kwargs and "Ww" in kwargs: + if kwargs.get("W") is not None and kwargs.get("Ww") is not None: raise GMTInvalidInput("Set only categorical or cyclic to True, not both.") with Session() as lib: file_context = lib.virtualfile_from_data(check_kind="raster", data=grid) with file_context as infile: - if "H" not in kwargs: # if no output is set + if kwargs.get("H") is None: # if no output is set arg_str = " ".join([infile, build_arg_string(kwargs)]) - if "H" in kwargs: # if output is set + if kwargs.get("H") is not None: # if output is set outfile = kwargs.pop("H") if not outfile or not isinstance(outfile, str): raise GMTInvalidInput("'output' should be a proper file name.") From 7b10bd29dca733de0dfae9c04dddbc4185d547eb Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 10:52:46 -0400 Subject: [PATCH 03/15] Let grd2xyz's outcols work with None input Specifically when output_type="pandas" too. --- pygmt/src/grd2xyz.py | 2 +- pygmt/tests/test_grd2xyz.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/pygmt/src/grd2xyz.py b/pygmt/src/grd2xyz.py index 46797022abf..f9fb6a0d06f 100644 --- a/pygmt/src/grd2xyz.py +++ b/pygmt/src/grd2xyz.py @@ -159,7 +159,7 @@ def grd2xyz(grid, output_type="pandas", outfile=None, **kwargs): elif outfile is None and output_type == "file": raise GMTInvalidInput("Must specify 'outfile' for ASCII output.") - if "o" in kwargs and output_type == "pandas": + if kwargs.get("o") is not None and output_type == "pandas": raise GMTInvalidInput( "If 'outcols' is specified, 'output_type' must be either 'numpy'" "or 'file'." diff --git a/pygmt/tests/test_grd2xyz.py b/pygmt/tests/test_grd2xyz.py index 97abb59000a..4cb172d3684 100644 --- a/pygmt/tests/test_grd2xyz.py +++ b/pygmt/tests/test_grd2xyz.py @@ -45,7 +45,7 @@ def test_grd2xyz_format(grid): np.testing.assert_allclose(orig_val, xyz_val) xyz_array = grd2xyz(grid=grid, output_type="numpy") assert isinstance(xyz_array, np.ndarray) - xyz_df = grd2xyz(grid=grid, output_type="pandas") + xyz_df = grd2xyz(grid=grid, output_type="pandas", outcols=None) assert isinstance(xyz_df, pd.DataFrame) assert list(xyz_df.columns) == ["lon", "lat", "z"] From 2e58272e41a48eb55a1beaf09ebf6ee2bf7a69d1 Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 11:43:29 -0400 Subject: [PATCH 04/15] Let grdgradient's tiles, normalize and outgrid work with None input --- pygmt/src/grdgradient.py | 4 ++-- pygmt/tests/test_grdgradient.py | 7 ++++++- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/pygmt/src/grdgradient.py b/pygmt/src/grdgradient.py index b70c2cbf980..fbb22ea1568 100644 --- a/pygmt/src/grdgradient.py +++ b/pygmt/src/grdgradient.py @@ -164,7 +164,7 @@ def grdgradient(grid, **kwargs): >>> new_grid = pygmt.grdgradient(grid=grid, azimuth=10) """ with GMTTempFile(suffix=".nc") as tmpfile: - if "Q" in kwargs and "N" not in kwargs: + if kwargs.get("Q") is not None and kwargs.get("N") is None: raise GMTInvalidInput("""Must specify normalize if tiles is specified.""") if not args_in_kwargs(args=["A", "D", "E"], kwargs=kwargs): raise GMTInvalidInput( @@ -174,7 +174,7 @@ def grdgradient(grid, **kwargs): with Session() as lib: file_context = lib.virtualfile_from_data(check_kind="raster", data=grid) with file_context as infile: - if "G" not in kwargs: # if outgrid is unset, output to tempfile + if kwargs.get("G") is None: # if outgrid is unset, output to tempfile kwargs.update({"G": tmpfile.name}) outgrid = kwargs["G"] arg_str = " ".join([infile, build_arg_string(kwargs)]) diff --git a/pygmt/tests/test_grdgradient.py b/pygmt/tests/test_grdgradient.py index 4f908a2236c..df4810e2ec9 100644 --- a/pygmt/tests/test_grdgradient.py +++ b/pygmt/tests/test_grdgradient.py @@ -57,8 +57,13 @@ def test_grdgradient_no_outgrid(grid, expected_grid): """ Test the azimuth and direction parameters for grdgradient with no set outgrid. + + This is a regression test for + https://github.com/GenericMappingTools/pygmt/issues/1807. """ - result = grdgradient(grid=grid, azimuth=10, region=[-53, -49, -20, -17]) + result = grdgradient( + grid=grid, azimuth=10, region=[-53, -49, -20, -17], outgrid=None + ) # check information of the output grid assert isinstance(result, xr.DataArray) assert result.gmt.gtype == 1 # Geographic grid From 84408485315b9c86a13c91d4c4c9ea61a94d5728 Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 12:46:19 -0400 Subject: [PATCH 05/15] Let grdview's drapegrid work with None inputs --- pygmt/src/grdview.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/pygmt/src/grdview.py b/pygmt/src/grdview.py index 404fc490cc0..b0a7193cddd 100644 --- a/pygmt/src/grdview.py +++ b/pygmt/src/grdview.py @@ -126,7 +126,9 @@ def grdview(self, grid, **kwargs): file_context = lib.virtualfile_from_data(check_kind="raster", data=grid) with contextlib.ExitStack() as stack: - if "G" in kwargs: # deal with kwargs["G"] if drapegrid is xr.DataArray + if ( + kwargs.get("G") is not None + ): # deal with kwargs["G"] if drapegrid is xr.DataArray drapegrid = kwargs["G"] if data_kind(drapegrid) in ("file", "grid"): if data_kind(drapegrid) == "grid": From e1b71d22a6cdda134f525575ab74924ef3cc14d8 Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 12:52:53 -0400 Subject: [PATCH 06/15] Let makecpt's categorical, cyclic and output work with None inputs --- pygmt/src/makecpt.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/pygmt/src/makecpt.py b/pygmt/src/makecpt.py index bf52be37f80..057afeeb268 100644 --- a/pygmt/src/makecpt.py +++ b/pygmt/src/makecpt.py @@ -147,11 +147,11 @@ def makecpt(**kwargs): ``categorical=True``. """ with Session() as lib: - if "W" in kwargs and "Ww" in kwargs: + if kwargs.get("W") is not None and kwargs.get("Ww") is not None: raise GMTInvalidInput("Set only categorical or cyclic to True, not both.") - if "H" not in kwargs: # if no output is set + if kwargs.get("H") is None: # if no output is set arg_str = build_arg_string(kwargs) - elif "H" in kwargs: # if output is set + elif kwargs.get("H") is not None: # if output is set outfile = kwargs.pop("H") if not outfile or not isinstance(outfile, str): raise GMTInvalidInput("'output' should be a proper file name.") From 2d78667741cb7880bff22e57405b08cfdcab14a9 Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 12:56:39 -0400 Subject: [PATCH 07/15] Let plot's style, color, intensity and transparency work with None input --- pygmt/src/plot.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/pygmt/src/plot.py b/pygmt/src/plot.py index adff9682295..da4b575b428 100644 --- a/pygmt/src/plot.py +++ b/pygmt/src/plot.py @@ -218,15 +218,15 @@ def plot(self, data=None, x=None, y=None, size=None, direction=None, **kwargs): kind = data_kind(data, x, y) extra_arrays = [] - if "S" in kwargs and kwargs["S"][0] in "vV" and direction is not None: + if kwargs.get("S") is not None and kwargs["S"][0] in "vV" and direction is not None: extra_arrays.extend(direction) elif ( - "S" not in kwargs + kwargs.get("S") is None and kind == "geojson" and data.geom_type.isin(["Point", "MultiPoint"]).all() ): # checking if the geometry of a geoDataFrame is Point or MultiPoint kwargs["S"] = "s0.2c" - elif "S" not in kwargs and kind == "file" and data.endswith(".gmt"): + elif kwargs.get("S") is None and kind == "file" and data.endswith(".gmt"): # checking that the data is a file path to set default style try: with open(which(data), mode="r", encoding="utf8") as file: @@ -236,7 +236,7 @@ def plot(self, data=None, x=None, y=None, size=None, direction=None, **kwargs): kwargs["S"] = "s0.2c" except FileNotFoundError: pass - if "G" in kwargs and is_nonstr_iter(kwargs["G"]): + if kwargs.get("G") is not None and is_nonstr_iter(kwargs["G"]): if kind != "vectors": raise GMTInvalidInput( "Can't use arrays for color if data is matrix or file." @@ -251,7 +251,7 @@ def plot(self, data=None, x=None, y=None, size=None, direction=None, **kwargs): extra_arrays.append(size) for flag in ["I", "t"]: - if flag in kwargs and is_nonstr_iter(kwargs[flag]): + if kwargs.get(flag) is not None and is_nonstr_iter(kwargs[flag]): if kind != "vectors": raise GMTInvalidInput( f"Can't use arrays for {plot.aliases[flag]} if data is matrix or file." From 900273b83acf58fb6b8601aada50081b4c62e4fa Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 12:59:41 -0400 Subject: [PATCH 08/15] Let plot3d's style, color, intensity & transparency work with None input --- pygmt/src/plot3d.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/pygmt/src/plot3d.py b/pygmt/src/plot3d.py index faabf34395d..42999bd1e19 100644 --- a/pygmt/src/plot3d.py +++ b/pygmt/src/plot3d.py @@ -188,15 +188,15 @@ def plot3d( kind = data_kind(data, x, y, z) extra_arrays = [] - if "S" in kwargs and kwargs["S"][0] in "vV" and direction is not None: + if kwargs.get("S") is not None and kwargs["S"][0] in "vV" and direction is not None: extra_arrays.extend(direction) elif ( - "S" not in kwargs + kwargs.get("S") is None and kind == "geojson" and data.geom_type.isin(["Point", "MultiPoint"]).all() ): # checking if the geometry of a geoDataFrame is Point or MultiPoint kwargs["S"] = "u0.2c" - elif "S" not in kwargs and kind == "file" and data.endswith(".gmt"): + elif kwargs.get("S") is None and kind == "file" and data.endswith(".gmt"): # checking that the data is a file path to set default style try: with open(which(data), mode="r", encoding="utf8") as file: @@ -206,7 +206,7 @@ def plot3d( kwargs["S"] = "u0.2c" except FileNotFoundError: pass - if "G" in kwargs and is_nonstr_iter(kwargs["G"]): + if kwargs.get("G") is not None and is_nonstr_iter(kwargs["G"]): if kind != "vectors": raise GMTInvalidInput( "Can't use arrays for color if data is matrix or file." @@ -221,7 +221,7 @@ def plot3d( extra_arrays.append(size) for flag in ["I", "t"]: - if flag in kwargs and is_nonstr_iter(kwargs[flag]): + if kwargs.get(flag) is not None and is_nonstr_iter(kwargs[flag]): if kind != "vectors": raise GMTInvalidInput( f"Can't use arrays for {plot3d.aliases[flag]} if data is matrix or file." From f1e8d374d7834267ffc8f4749f96c6d75f72f30e Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 13:44:55 -0400 Subject: [PATCH 09/15] Let solar's T work with None input --- pygmt/src/solar.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pygmt/src/solar.py b/pygmt/src/solar.py index 5b0c0a35d5a..51c830d14e4 100644 --- a/pygmt/src/solar.py +++ b/pygmt/src/solar.py @@ -66,7 +66,7 @@ def solar(self, terminator="d", terminator_datetime=None, **kwargs): """ kwargs = self._preprocess(**kwargs) # pylint: disable=protected-access - if "T" in kwargs: + if kwargs.get("T") is not None: raise GMTInvalidInput( "Use 'terminator' and 'terminator_datetime' instead of 'T'." ) From 8d8f1382e693b0a1ecf6259c363ef40e063e5f15 Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 14:05:17 -0400 Subject: [PATCH 10/15] Let transparency work with 0, None and False input --- pygmt/src/text.py | 2 +- pygmt/tests/test_text.py | 14 ++++++++++++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/pygmt/src/text.py b/pygmt/src/text.py index e7eac023cbd..d962c85018b 100644 --- a/pygmt/src/text.py +++ b/pygmt/src/text.py @@ -215,7 +215,7 @@ def text_( extra_arrays = [] # If an array of transparency is given, GMT will read it from # the last numerical column per data record. - if "t" in kwargs and is_nonstr_iter(kwargs["t"]): + if kwargs.get("t") is not None and is_nonstr_iter(kwargs["t"]): extra_arrays.append(kwargs["t"]) kwargs["t"] = "" diff --git a/pygmt/tests/test_text.py b/pygmt/tests/test_text.py index b0f5158e2e5..c160b8214d2 100644 --- a/pygmt/tests/test_text.py +++ b/pygmt/tests/test_text.py @@ -337,6 +337,20 @@ def test_text_varying_transparency(): return fig +@pytest.mark.mpl_image_compare(filename="test_text_input_single_filename.png") +@pytest.mark.parametrize("transparency", [None, False, 0]) +def test_text_no_transparency(transparency): + """ + Add text with no transparency set. + + This is a regression test for + https://github.com/GenericMappingTools/pygmt/issues/1852. + """ + fig = Figure() + fig.text(region=[10, 70, -5, 10], textfiles=POINTS_DATA, transparency=transparency) + return fig + + @pytest.mark.mpl_image_compare def test_text_nonstr_text(): """ From 58390de0b91039b91e0e52709ed2a3509a20de0c Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 14:10:25 -0400 Subject: [PATCH 11/15] Let project's center, convention and generate work with None inputs --- pygmt/src/project.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/pygmt/src/project.py b/pygmt/src/project.py index 1c3f422e638..5a80f12975d 100644 --- a/pygmt/src/project.py +++ b/pygmt/src/project.py @@ -210,13 +210,13 @@ def project(data=None, x=None, y=None, z=None, outfile=None, **kwargs): by ``outfile``) """ - if "C" not in kwargs: + if kwargs.get("C") is None: raise GMTInvalidInput("The `center` parameter must be specified.") - if "G" not in kwargs and data is None: + if kwargs.get("G") is None and data is None: raise GMTInvalidInput( "The `data` parameter must be specified unless `generate` is used." ) - if "G" in kwargs and "F" in kwargs: + if kwargs.get("G") is not None and kwargs.get("F") is not None: raise GMTInvalidInput( "The `convention` parameter is not allowed with `generate`." ) @@ -225,7 +225,7 @@ def project(data=None, x=None, y=None, z=None, outfile=None, **kwargs): if outfile is None: # Output to tmpfile if outfile is not set outfile = tmpfile.name with Session() as lib: - if "G" not in kwargs: + if kwargs.get("G") is None: # Choose how data will be passed into the module table_context = lib.virtualfile_from_data( check_kind="vector", data=data, x=x, y=y, z=z, required_z=False @@ -242,7 +242,7 @@ def project(data=None, x=None, y=None, z=None, outfile=None, **kwargs): # if user did not set outfile, return pd.DataFrame if outfile == tmpfile.name: - if "G" in kwargs: + if kwargs.get("G") is not None: column_names = list("rsp") result = pd.read_csv(tmpfile.name, sep="\t", names=column_names) else: From bc09dcbef6c5ec9e634f9ee41eeefa0f4677433d Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Wed, 30 Mar 2022 14:13:59 -0400 Subject: [PATCH 12/15] Let velo's spec work with None inputs Or rather, catch it properly if someone uses spec=None. --- pygmt/src/velo.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/pygmt/src/velo.py b/pygmt/src/velo.py index c27128ee270..60a46f99d9e 100644 --- a/pygmt/src/velo.py +++ b/pygmt/src/velo.py @@ -238,8 +238,12 @@ def velo(self, data=None, **kwargs): """ kwargs = self._preprocess(**kwargs) # pylint: disable=protected-access - if "S" not in kwargs or ("S" in kwargs and not isinstance(kwargs["S"], str)): - raise GMTInvalidInput("Spec is a required argument and has to be a string.") + if kwargs.get("S") is None or ( + kwargs.get("S") is not None and not isinstance(kwargs["S"], str) + ): + raise GMTInvalidInput( + "The parameter `spec` is required and has to be a string." + ) if isinstance(data, np.ndarray) and not pd.api.types.is_numeric_dtype(data): raise GMTInvalidInput( From 56fee1f481256c81969dbb5a8c0de4d55967b612 Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Thu, 31 Mar 2022 10:37:57 -0400 Subject: [PATCH 13/15] Apply suggestions from code review Co-authored-by: Meghan Jones Co-authored-by: Dongdong Tian --- pygmt/src/grd2cpt.py | 2 +- pygmt/src/grdview.py | 5 ++--- pygmt/src/makecpt.py | 2 +- 3 files changed, 4 insertions(+), 5 deletions(-) diff --git a/pygmt/src/grd2cpt.py b/pygmt/src/grd2cpt.py index 2e8e80357f9..2b78c736b24 100644 --- a/pygmt/src/grd2cpt.py +++ b/pygmt/src/grd2cpt.py @@ -167,7 +167,7 @@ def grd2cpt(grid, **kwargs): with file_context as infile: if kwargs.get("H") is None: # if no output is set arg_str = " ".join([infile, build_arg_string(kwargs)]) - if kwargs.get("H") is not None: # if output is set + else: # if output is set outfile = kwargs.pop("H") if not outfile or not isinstance(outfile, str): raise GMTInvalidInput("'output' should be a proper file name.") diff --git a/pygmt/src/grdview.py b/pygmt/src/grdview.py index b0a7193cddd..506438129b4 100644 --- a/pygmt/src/grdview.py +++ b/pygmt/src/grdview.py @@ -126,9 +126,8 @@ def grdview(self, grid, **kwargs): file_context = lib.virtualfile_from_data(check_kind="raster", data=grid) with contextlib.ExitStack() as stack: - if ( - kwargs.get("G") is not None - ): # deal with kwargs["G"] if drapegrid is xr.DataArray + if kwargs.get("G") is not None: + # deal with kwargs["G"] if drapegrid is xr.DataArray drapegrid = kwargs["G"] if data_kind(drapegrid) in ("file", "grid"): if data_kind(drapegrid) == "grid": diff --git a/pygmt/src/makecpt.py b/pygmt/src/makecpt.py index 057afeeb268..226ce38cc4e 100644 --- a/pygmt/src/makecpt.py +++ b/pygmt/src/makecpt.py @@ -151,7 +151,7 @@ def makecpt(**kwargs): raise GMTInvalidInput("Set only categorical or cyclic to True, not both.") if kwargs.get("H") is None: # if no output is set arg_str = build_arg_string(kwargs) - elif kwargs.get("H") is not None: # if output is set + else: # if output is set outfile = kwargs.pop("H") if not outfile or not isinstance(outfile, str): raise GMTInvalidInput("'output' should be a proper file name.") From b7fd3662e9ce027cf9ff3d5a4d48b4dd93d49ec3 Mon Sep 17 00:00:00 2001 From: actions-bot <58130806+actions-bot@users.noreply.github.com> Date: Thu, 31 Mar 2022 14:40:55 +0000 Subject: [PATCH 14/15] [format-command] fixes --- pygmt/src/grdview.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pygmt/src/grdview.py b/pygmt/src/grdview.py index 506438129b4..5c1afdd216b 100644 --- a/pygmt/src/grdview.py +++ b/pygmt/src/grdview.py @@ -126,7 +126,7 @@ def grdview(self, grid, **kwargs): file_context = lib.virtualfile_from_data(check_kind="raster", data=grid) with contextlib.ExitStack() as stack: - if kwargs.get("G") is not None: + if kwargs.get("G") is not None: # deal with kwargs["G"] if drapegrid is xr.DataArray drapegrid = kwargs["G"] if data_kind(drapegrid) in ("file", "grid"): From c7725e08c1474ed92425507cfe11ceee70b73bf4 Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Mon, 4 Apr 2022 13:24:10 -0400 Subject: [PATCH 15/15] Update pygmt/src/grdgradient.py using walrus operator Co-authored-by: Meghan Jones --- pygmt/src/grdgradient.py | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/pygmt/src/grdgradient.py b/pygmt/src/grdgradient.py index fbb22ea1568..3286ecd5e29 100644 --- a/pygmt/src/grdgradient.py +++ b/pygmt/src/grdgradient.py @@ -174,9 +174,8 @@ def grdgradient(grid, **kwargs): with Session() as lib: file_context = lib.virtualfile_from_data(check_kind="raster", data=grid) with file_context as infile: - if kwargs.get("G") is None: # if outgrid is unset, output to tempfile - kwargs.update({"G": tmpfile.name}) - outgrid = kwargs["G"] + if (outgrid := kwargs.get("G")) is None: + kwargs["G"] = outgrid = tmpfile.name # output to tmpfile arg_str = " ".join([infile, build_arg_string(kwargs)]) lib.call_module("grdgradient", arg_str)