geodesic_wgs84 1.32.3 → 1.32.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/ext/geodesic_wgs84/geodesic_wgs84.c +9 -2
- data/lib/geodesic_wgs84/version.rb +1 -1
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b4a19b3e66edf105991e6a8e6c0acb8d29c6c197
|
4
|
+
data.tar.gz: e3755015bd64e51c3ca22396781fa392e784d180
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: b05d2197eb4ffc5896a7a8485412a4a24d694d10f36e9ef8d6282c83ece941bba96837e836bddea1bad1ec1d67be7c43aebbe7bec79e42321970a02e15e227da
|
7
|
+
data.tar.gz: 8614bfb13b0980fa39b38459eb14bb095f2469f967c0d52c085c628c2a5ece842920442f41ab0639b294d77aeabe66291c8a3d1a941bfeb0af2969dc50cf660e
|
@@ -132,24 +132,31 @@ static VALUE
|
|
132
132
|
wgs84_lat_lon_dms(int argc, VALUE *argv, VALUE klass)
|
133
133
|
{
|
134
134
|
double lat, lon;
|
135
|
+
int valid = 0;
|
135
136
|
char lat_buf[64], lon_buf[64];
|
136
137
|
VALUE tmp;
|
137
138
|
|
138
139
|
if (argc == 2) {
|
139
140
|
lat = wgs84_get_value(argv[0]);
|
140
141
|
lon = wgs84_get_value(argv[1]);
|
141
|
-
|
142
|
+
valid = 1;
|
142
143
|
}
|
143
144
|
|
144
145
|
if (argc == 1 && TYPE(*argv) == T_ARRAY && RARRAY_LEN(*argv) == 2) {
|
145
146
|
lat = wgs84_get_value(rb_ary_entry(*argv, 0));
|
146
147
|
lon = wgs84_get_value(rb_ary_entry(*argv, 1));
|
147
|
-
|
148
|
+
valid = 1;
|
148
149
|
}
|
149
150
|
|
150
151
|
if (argc == 1 && !NIL_P(tmp = rb_check_array_type(*argv))) {
|
151
152
|
lat = wgs84_get_value(rb_ary_entry(tmp, 0));
|
152
153
|
lon = wgs84_get_value(rb_ary_entry(tmp, 1));
|
154
|
+
valid = 1;
|
155
|
+
}
|
156
|
+
|
157
|
+
if (valid == 1) {
|
158
|
+
wgs84_make_dms(lat, lat_buf);
|
159
|
+
wgs84_make_dms(lon, lon_buf);
|
153
160
|
return rb_ary_new3(2L, rb_str_new2(lat_buf), rb_str_new2(lon_buf));
|
154
161
|
}
|
155
162
|
|