Skip to content

Commit

Permalink
Change the function definition to 'grid, points=None' in an compatibl…
Browse files Browse the repository at this point in the history
…e way
  • Loading branch information
seisman committed May 7, 2022
1 parent 1080ace commit d70444f
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 5 deletions.
38 changes: 33 additions & 5 deletions pygmt/src/grdtrack.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
"""
grdtrack - Sample grids at specified (x,y) locations.
"""
import warnings

import pandas as pd
import xarray as xr
from pygmt.clib import Session
from pygmt.exceptions import GMTInvalidInput
from pygmt.helpers import (
Expand All @@ -11,6 +14,7 @@
kwargs_to_strings,
use_alias,
)
from pygmt.src.which import which

__doctest_skip__ = ["grdtrack"]

Expand Down Expand Up @@ -43,7 +47,7 @@
w="wrap",
)
@kwargs_to_strings(R="sequence", S="sequence", i="sequence_comma", o="sequence_comma")
def grdtrack(points=None, grid=None, newcolname=None, outfile=None, **kwargs):
def grdtrack(grid, points=None, newcolname=None, outfile=None, **kwargs):
r"""
Sample grids at specified (x,y) locations.
Expand All @@ -67,14 +71,14 @@ def grdtrack(points=None, grid=None, newcolname=None, outfile=None, **kwargs):
Parameters
----------
points : str or {table-like}
Pass in either a file name to an ASCII data table, a 2D
{table-classes}.
grid : xarray.DataArray or str
Gridded array from which to sample values from, or a filename (netcdf
format).
points : str or {table-like}
Pass in either a file name to an ASCII data table, a 2D
{table-classes}.
newcolname : str
Required if ``points`` is a :class:`pandas.DataFrame`. The name for the
new column in the track :class:`pandas.DataFrame` table where the
Expand Down Expand Up @@ -292,6 +296,30 @@ def grdtrack(points=None, grid=None, newcolname=None, outfile=None, **kwargs):
if points is not None and kwargs.get("E") is not None:
raise GMTInvalidInput("Can't set both 'points' and 'profile'.")

# Backward compatibility with old parameter order "points, grid".
# deprecated_version="0.7.0", remove_version="v0.9.0"
is_a_grid = True
if not isinstance(grid, (xr.DataArray, xr.Dataset, str)):
is_a_grid = False
elif isinstance(grid, str):
try:
print(which(grid, download="a"))
_ = xr.open_dataarray(which(grid, download="a"))
is_a_grid = True
except ValueError:
is_a_grid = False
if not is_a_grid:
msg = (
"Positional parameters 'points, grid' of pygmt.grdtrack() is changed "
"to 'grid, points=None' since v0.7.0. It's likely that you're NOT "
"passing an valid grid as the first positional argument or "
"passing an invalid grid to the 'grid' parameter. "
"Please check the order of arguments with the latest documentation. "
"The warning will be removed in v0.9.0."
)
grid, points = points, grid
warnings.warn(msg, category=FutureWarning, stacklevel=1)

with GMTTempFile(suffix=".csv") as tmpfile:
with Session() as lib:
# Store the xarray.DataArray grid in virtualfile
Expand Down
15 changes: 15 additions & 0 deletions pygmt/tests/test_grdtrack.py
Original file line number Diff line number Diff line change
Expand Up @@ -176,3 +176,18 @@ def test_grdtrack_set_points_and_profile(dataarray, dataframe):
"""
with pytest.raises(GMTInvalidInput):
grdtrack(grid=dataarray, points=dataframe, profile="BL/TR")


def test_grdtrack_old_parameter_order(dataframe, dataarray, expected_array):
"""
Run grdtrack with the old parameter order 'points, grid'.
This test should be removed in v0.9.0.
"""
for points in (POINTS_DATA, dataframe):
for grid in ("@static_earth_relief.nc", dataarray):
with pytest.warns(expected_warning=FutureWarning) as record:
output = grdtrack(points, grid)
assert len(record) == 1
assert isinstance(output, pd.DataFrame)
npt.assert_allclose(np.array(output), expected_array)

0 comments on commit d70444f

Please sign in to comment.