[api] Refactored and deleted duplicate ApiPoint

This commit is contained in:
Alex Zolotarev 2013-06-25 18:47:48 +03:00 committed by Alex Zolotarev
parent 8a9eacc353
commit b20c78f4a8
13 changed files with 96 additions and 154 deletions

View file

@ -601,8 +601,8 @@ namespace android
{
m2::PointD pivot(MercatorBounds::LonToX(apiPoint.m_lon),
MercatorBounds::LatToY(apiPoint.m_lat));
ActivatePopup(pivot, apiPoint.m_title, "", IMAGE_ARROW);
m_bmBaloon.get()->setOnClickListener(bind(&Framework::OnAcitvateApiPoint, this, _1, apiPoint));
ActivatePopup(pivot, apiPoint.m_name, "", IMAGE_ARROW);
m_bmBaloon.get()->setOnClickListener(bind(&Framework::OnActivateApiPoint, this, _1, apiPoint));
return;
}
else
@ -709,7 +709,7 @@ namespace android
if (m_bmBaloon == NULL)
return;
ScreenBase screen = m_work.GetNavigator().Screen();
ScreenBase const & screen = m_work.GetNavigator().Screen();
m_bmBaloon->onScreenSize(screen.GetWidth(), screen.GetHeight());
}
@ -762,26 +762,21 @@ namespace android
/// @todo this is weird hack, we should reconsider Android lifecycle handling design
m_doLoadState = false;
url_api::Request request;
// if we have only one point
// and import is successful - show balloon
if (m_work.SetViewportByURL(url, request) && request.m_points.size() == 1)
url_scheme::ApiPoint apiPoint;
if (m_work.SetViewportByURL(url, apiPoint))
{
//we need it only for one-point-call
url_api::Point const point = request.m_points.front();
m2::PointD pt(MercatorBounds::LonToX(request.m_viewportLon),
MercatorBounds::LatToY(request.m_viewportLat));
ActivatePopup(pt, point.m_name, "", IMAGE_ARROW);
// we need it only for one-point-call
m2::PointD const globalPoint(MercatorBounds::LonToX(apiPoint.m_lon), MercatorBounds::LatToY(apiPoint.m_lat));
ActivatePopup(globalPoint, apiPoint.m_name, "", IMAGE_ARROW);
// For geo and ge0 draw placemark
if (!strings::StartsWith(url, "mapswithme"))
{
m_work.DrawPlacemark(pt);
m_work.DrawPlacemark(globalPoint);
m_work.Invalidate();
}
url_scheme::ApiPoint const apiPoint {point.m_lat, point.m_lon, point.m_name, point.m_id};
m_bmBaloon.get()->setOnClickListener(bind(&Framework::OnAcitvateApiPoint, this, _1, apiPoint));
m_bmBaloon.get()->setOnClickListener(bind(&Framework::OnActivateApiPoint, this, _1, apiPoint));
return true;
}
@ -799,9 +794,8 @@ namespace android
m_bookmarkActivatedListener(bmkAndCat);
}
void Framework::OnAcitvateApiPoint(gui::Element * e, url_scheme::ApiPoint const & apiPoint)
void Framework::OnActivateApiPoint(gui::Element * e, url_scheme::ApiPoint const & apiPoint)
{
LOG(LERROR, ("POINT on api point listener", apiPoint.m_title, apiPoint.m_id));
m_apiPointActivatedListener(apiPoint);
}
@ -879,7 +873,7 @@ extern "C"
"onApiPointActivated",
"(DDLjava/lang/String;Ljava/lang/String;)V");
jstring j_name = jni::ToJavaString(jniEnv, apiPoint.m_title);
jstring j_name = jni::ToJavaString(jniEnv, apiPoint.m_name);
jstring j_id = jni::ToJavaString(jniEnv, apiPoint.m_id);
jniEnv->CallVoidMethod(*obj.get(), methodID, apiPoint.m_lat, apiPoint.m_lon, j_name, j_id);
}

View file

@ -89,7 +89,7 @@ namespace android
// Balloon click callbacks
void OnActivatePoi(gui::Element * e, ::Framework::AddressInfo const & addrInfo, m2::PointD const & globalPoint);
void OnActivateBookmark(gui::Element * e, BookmarkAndCategory const & bmkAndCat);
void OnAcitvateApiPoint(gui::Element * e, url_scheme::ApiPoint const & apiPoint);
void OnActivateApiPoint(gui::Element * e, url_scheme::ApiPoint const & apiPoint);
void OnActivateMyPosition(gui::Element * e);

View file

@ -62,16 +62,16 @@ void InitLocalizedStrings()
- (void)applicationDidBecomeActive:(UIApplication *)application
{
UIPasteboard *pasteboard = [UIPasteboard generalPasteboard];
UIPasteboard * pasteboard = [UIPasteboard generalPasteboard];
if (GetPlatform().IsPro() && !m_didOpenedWithUrl)
{
NSString * url = [pasteboard.string stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
if ([url length])
{
url_api::Request request;
if (GetFramework().SetViewportByURL([url UTF8String], request))
url_scheme::ApiPoint apiPoint;
if (GetFramework().SetViewportByURL([url UTF8String], apiPoint))
{
[self showParsedBookmarkOnMap: request];
[self showParsedBookmarkOnMap:apiPoint];
pasteboard.string = @"";
}
}
@ -178,10 +178,10 @@ void InitLocalizedStrings()
// geo scheme support, see http://tools.ietf.org/html/rfc5870
if ([scheme isEqualToString:@"geo"] || [scheme isEqualToString:@"ge0"])
{
url_api::Request request;
if (GetFramework().SetViewportByURL([[url.absoluteString stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding] UTF8String], request))
url_scheme::ApiPoint apiPoint;
if (GetFramework().SetViewportByURL([[url.absoluteString stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding] UTF8String], apiPoint))
{
[self showParsedBookmarkOnMap: request];
[self showParsedBookmarkOnMap:apiPoint];
m_didOpenedWithUrl = YES;
if ([scheme isEqualToString:@"geo"])
[[Statistics instance] logEvent:@"geo Import"];
@ -192,8 +192,8 @@ void InitLocalizedStrings()
}
if ([scheme isEqualToString:@"mapswithme"])
{
url_api::Request request;
if (GetFramework().SetViewportByURL([[url.absoluteString stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding] UTF8String], request));
url_scheme::ApiPoint apiPoint;
if (GetFramework().SetViewportByURL([[url.absoluteString stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding] UTF8String], apiPoint));
{
[self showMap];
[m_mapViewController prepareForApi];
@ -251,15 +251,12 @@ void InitLocalizedStrings()
m_navController.navigationBarHidden = YES;
}
-(void) showParsedBookmarkOnMap:(url_api::Request) request
-(void) showParsedBookmarkOnMap:(url_scheme::ApiPoint const &)apiPoint
{
[self showMap];
m2::PointD point(MercatorBounds::LonToX(request.m_viewportLon),
MercatorBounds::LatToY(request.m_viewportLat));
NSString * name = [NSString stringWithUTF8String: request.m_points.front().m_name.c_str()];
[m_mapViewController showBalloonWithText:name andGlobalPoint:point];
m2::PointD const globalPoint(MercatorBounds::LonToX(apiPoint.m_lon), MercatorBounds::LatToY(apiPoint.m_lat));
NSString * name = [NSString stringWithUTF8String:apiPoint.m_name.c_str()];
[m_mapViewController showBalloonWithText:name andGlobalPoint:globalPoint];
}
@end

View file

@ -1412,7 +1412,7 @@ void Framework::AddBookmarkAndSetViewport(Bookmark & bm, m2::RectD const & viewP
ShowRectExVisibleScale(viewPort);
}
bool Framework::SetViewportByURL(string const & url, url_api::Request & request)
bool Framework::SetViewportByURL(string const & url, url_scheme::ApiPoint & balloonPoint)
{
if (strings::StartsWith(url, "geo"))
{
@ -1423,29 +1423,24 @@ bool Framework::SetViewportByURL(string const & url, url_api::Request & request)
if (info.IsValid())
{
// @TODO this is hack to kick-off release
request.m_points.push_back(url_api::Point());
url_api::Point & newPoint = request.m_points.back();
newPoint.m_name = m_stringsBundle.GetString("dropped_pin");
request.m_viewportLat = newPoint.m_lat = info.m_lat;
request.m_viewportLon = newPoint.m_lon = info.m_lon;
request.m_viewportZoomLevel = info.m_zoom;
balloonPoint.m_name = m_stringsBundle.GetString("dropped_pin");
balloonPoint.m_lat = info.m_lat;
balloonPoint.m_lon = info.m_lon;
SetViewPortSync(info.GetViewport());
return true;
}
}
else if (strings::StartsWith(url, "ge0"))
{
url_api::Ge0Parser parser;
if (parser.Parse(url, request))
url_scheme::Ge0Parser parser;
double zoomLevel;
if (parser.Parse(url, balloonPoint, zoomLevel))
{
url_api::Point & point = request.m_points.front();
if (point.m_name.empty())
point.m_name = m_stringsBundle.GetString("dropped_pin");
if (balloonPoint.m_name.empty())
balloonPoint.m_name = m_stringsBundle.GetString("dropped_pin");
m2::PointD const center(MercatorBounds::LonToX(request.m_viewportLon), MercatorBounds::LatToY(request.m_viewportLat));
SetViewPortSync(scales::GetRectForLevel(request.m_viewportZoomLevel, center, 1));
m2::PointD const center(MercatorBounds::LonToX(balloonPoint.m_lon), MercatorBounds::LatToY(balloonPoint.m_lat));
SetViewPortSync(scales::GetRectForLevel(zoomLevel, center, 1));
return true;
}
}
@ -1456,23 +1451,11 @@ bool Framework::SetViewportByURL(string const & url, url_api::Request & request)
// Can do better consider nav bar size
SetViewPortSync(MercatorBounds::FromLatLonRect(m_ParsedMapApi.GetLatLonRect()));
// Populate request if request has only one point
// with this one point to show balloon.
// @todo: refactor to more general model, Point and ApiPoint must not exist together.
if (m_ParsedMapApi.GetPoints().size() == 1)
if (!m_ParsedMapApi.GetPoints().empty())
{
url_scheme::ApiPoint const apiPoint = m_ParsedMapApi.GetPoints().front();
url_api::Point point;
request.m_viewportLat = point.m_lat = apiPoint.m_lat;
request.m_viewportLon = point.m_lon = apiPoint.m_lon;
point.m_name = apiPoint.m_title;
point.m_id = apiPoint.m_id;
request.m_points.push_back(point);
balloonPoint = m_ParsedMapApi.GetPoints().front();
return true;
}
return true;
}
}
return false;

View file

@ -10,7 +10,6 @@
#include "feature_vec_model.hpp"
#include "bookmark.hpp"
#include "bookmark_manager.hpp"
#include "url_api.hpp"
#include "mwm_url.hpp"
#include "../defines.hpp"
@ -306,7 +305,8 @@ public:
m2::PointD GetViewportCenter() const;
void SetViewportCenter(m2::PointD const & pt);
bool SetViewportByURL(string const & url, url_api::Request & request);
/// @param[out] outPoint is a point in url, where we need to show balloon
bool SetViewportByURL(string const & url, url_scheme::ApiPoint & balloonPoint);
bool NeedRedraw() const;
void SetNeedRedraw(bool flag);

View file

@ -1,5 +1,5 @@
#include "ge0_parser.hpp"
#include "url_api.hpp"
#include "mwm_url.hpp"
#include "../api/internal/c/api-client-internals.h"
@ -10,8 +10,10 @@
#include "../base/math.hpp"
#include "../base/string_utils.hpp"
namespace url_scheme
{
url_api::Ge0Parser::Ge0Parser()
Ge0Parser::Ge0Parser()
{
for (size_t i = 0; i < 256; ++i)
m_base64ReverseCharTable[i] = 255;
@ -22,7 +24,7 @@ url_api::Ge0Parser::Ge0Parser()
}
}
bool url_api::Ge0Parser::Parse(string const & url, Request & request)
bool Ge0Parser::Parse(string const & url, url_scheme::ApiPoint & outPoint, double & outZoomLevel)
{
// URL format:
//
@ -38,44 +40,36 @@ bool url_api::Ge0Parser::Parse(string const & url, Request & request)
const int LATLON_LENGTH = NAME_POSITON_IN_URL - LATLON_POSITION - 1;
const size_t MAX_NAME_LENGTH = 256;
request.Clear();
if (url.size() < 16 || !strings::StartsWith(url, "ge0://"))
return false;
uint8_t const zoomI = DecodeBase64Char(url[ZOOM_POSITION]);
if (zoomI > 63)
return false;
request.m_viewportZoomLevel = DecodeZoom(zoomI);
outZoomLevel = DecodeZoom(zoomI);
request.m_points.push_back(url_api::Point());
url_api::Point & newPt = request.m_points.back();
DecodeLatLon(url.substr(LATLON_POSITION, LATLON_LENGTH), outPoint.m_lat, outPoint.m_lon);
DecodeLatLon(url.substr(LATLON_POSITION, LATLON_LENGTH), newPt.m_lat, newPt.m_lon);
ASSERT(MercatorBounds::ValidLon(newPt.m_lon), (newPt.m_lon));
ASSERT(MercatorBounds::ValidLat(newPt.m_lat), (newPt.m_lat));
request.m_viewportLat = newPt.m_lat;
request.m_viewportLon = newPt.m_lon;
ASSERT(MercatorBounds::ValidLon(outPoint.m_lon), (outPoint.m_lon));
ASSERT(MercatorBounds::ValidLat(outPoint.m_lat), (outPoint.m_lat));
if (url.size() >= NAME_POSITON_IN_URL)
newPt.m_name = DecodeName(url.substr(NAME_POSITON_IN_URL,
min(url.size() - NAME_POSITON_IN_URL, MAX_NAME_LENGTH)));
outPoint.m_name = DecodeName(url.substr(NAME_POSITON_IN_URL, min(url.size() - NAME_POSITON_IN_URL, MAX_NAME_LENGTH)));
return true;
}
uint8_t url_api::Ge0Parser::DecodeBase64Char(char const c)
uint8_t Ge0Parser::DecodeBase64Char(char const c)
{
return m_base64ReverseCharTable[static_cast<uint8_t>(c)];
}
double url_api::Ge0Parser::DecodeZoom(uint8_t const zoomByte)
double Ge0Parser::DecodeZoom(uint8_t const zoomByte)
{
//Coding zoom - int newZoom = ((oldZoom - 4) * 4)
return static_cast<double>(zoomByte) / 4 + 4;
}
void url_api::Ge0Parser::DecodeLatLon(string const & url, double & lat, double & lon)
void Ge0Parser::DecodeLatLon(string const & url, double & lat, double & lon)
{
int latInt = 0, lonInt = 0;
DecodeLatLonToInt(url, latInt, lonInt, url.size());
@ -83,7 +77,7 @@ void url_api::Ge0Parser::DecodeLatLon(string const & url, double & lat, double &
lon = DecodeLonFromInt(lonInt, (1 << MAPSWITHME_MAX_COORD_BITS) - 1);
}
void url_api::Ge0Parser::DecodeLatLonToInt(string const & url, int & lat, int & lon, int const bytes)
void Ge0Parser::DecodeLatLonToInt(string const & url, int & lat, int & lon, int const bytes)
{
for(int i = 0, shift = MAPSWITHME_MAX_COORD_BITS - 3; i < bytes; ++i, shift -= 3)
{
@ -102,17 +96,17 @@ void url_api::Ge0Parser::DecodeLatLonToInt(string const & url, int & lat, int &
lon += middleOfSquare;
}
double url_api::Ge0Parser::DecodeLatFromInt(int const lat, int const maxValue)
double Ge0Parser::DecodeLatFromInt(int const lat, int const maxValue)
{
return static_cast<double>(lat) / maxValue * 180 - 90;
}
double url_api::Ge0Parser::DecodeLonFromInt(int const lon, int const maxValue)
double Ge0Parser::DecodeLonFromInt(int const lon, int const maxValue)
{
return static_cast<double>(lon) / (maxValue + 1.0) * 360.0 - 180;
}
string url_api::Ge0Parser::DecodeName(string name)
string Ge0Parser::DecodeName(string name)
{
ValidateName(name);
name = UrlDecode(name);
@ -120,7 +114,7 @@ string url_api::Ge0Parser::DecodeName(string name)
return name;
}
void url_api::Ge0Parser::SpacesToUnderscore(string & name)
void Ge0Parser::SpacesToUnderscore(string & name)
{
for (size_t i = 0; i < name.size(); ++i)
if (name[i] == ' ')
@ -129,7 +123,7 @@ void url_api::Ge0Parser::SpacesToUnderscore(string & name)
name[i] = ' ';
}
void url_api::Ge0Parser::ValidateName(string & name)
void Ge0Parser::ValidateName(string & name)
{
if (name.empty())
return;
@ -147,7 +141,9 @@ void url_api::Ge0Parser::ValidateName(string & name)
name.resize(name.size() - 2);
}
bool url_api::Ge0Parser::IsHexChar(char const a)
bool Ge0Parser::IsHexChar(char const a)
{
return ((a >= '0' && a <= '9') || (a >= 'A' && a <= 'F') || (a >= 'a' && a <= 'f'));
}
} // namespace url_scheme

View file

@ -3,17 +3,17 @@
#include "../std/string.hpp"
namespace url_api
namespace url_scheme
{
struct Request;
struct ApiPoint;
class Ge0Parser
{
public:
Ge0Parser();
bool Parse(string const & url, Request & request);
bool Parse(string const & url, url_scheme::ApiPoint & outPoint, double & outZoomLevel);
protected:
uint8_t DecodeBase64Char(char const c);

View file

@ -56,7 +56,6 @@ HEADERS += \
geometry_processors.hpp \
bookmark_manager.hpp \
ge0_parser.hpp \
url_api.hpp \
SOURCES += \
feature_vec_model.cpp \

View file

@ -1,7 +1,7 @@
#include "../../testing/testing.hpp"
#include "../ge0_parser.hpp"
#include "../url_api.hpp"
#include "../mwm_url.hpp"
#include "../../api/internal/c/api-client-internals.h"
#include "../../api/src/c/api-client.h"
@ -9,8 +9,8 @@
#include "../../base/macros.hpp"
using url_api::Ge0Parser;
using url_api::Request;
using url_scheme::Ge0Parser;
using url_scheme::ApiPoint;
namespace
{
@ -40,29 +40,30 @@ double GetLonEpsilon(int coordBytes)
void TestSuccess(char const * s, double lat, double lon, double zoom, char const * name)
{
Ge0Parser parser;
Request request;
bool const result = parser.Parse(s, request);
ApiPoint apiPoint;
double parsedZoomLevel;
bool const result = parser.Parse(s, apiPoint, parsedZoomLevel);
TEST(result, (s, zoom, lat, lon, name));
TEST_EQUAL(request.m_points.size(), 1, (s, zoom, lat, lon, name));
TEST_EQUAL(request.m_points[0].m_name, string(name), (s));
TEST_EQUAL(request.m_points[0].m_id, string(), (s));
TEST_EQUAL(apiPoint.m_name, string(name), (s));
TEST_EQUAL(apiPoint.m_id, string(), (s));
double const latEps = GetLatEpsilon(9);
double const lonEps = GetLonEpsilon(9);
TEST(fabs(request.m_points[0].m_lat - lat) <= latEps, (s, zoom, lat, lon, name));
TEST(fabs(request.m_points[0].m_lon - lon) <= lonEps, (s, zoom, lat, lon, name));
TEST(fabs(apiPoint.m_lat - lat) <= latEps, (s, zoom, lat, lon, name));
TEST(fabs(apiPoint.m_lon - lon) <= lonEps, (s, zoom, lat, lon, name));
TEST(fabs(request.m_viewportLat - lat) <= latEps, (s, zoom, lat, lon, name));
TEST(fabs(request.m_viewportLon - lon) <= lonEps, (s, zoom, lat, lon, name));
TEST_ALMOST_EQUAL(request.m_viewportZoomLevel, zoom, (s, zoom, lat, lon, name));
TEST(fabs(apiPoint.m_lat - lat) <= latEps, (s, zoom, lat, lon, name));
TEST(fabs(apiPoint.m_lon - lon) <= lonEps, (s, zoom, lat, lon, name));
TEST_ALMOST_EQUAL(parsedZoomLevel, zoom, (s, zoom, lat, lon, name));
}
void TestFailure(char const * s)
{
Ge0Parser parser;
Request request;
bool const result = parser.Parse(s, request);
ApiPoint apiPoint;
double zoomLevel;
bool const result = parser.Parse(s, apiPoint, zoomLevel);
TEST_EQUAL(result, false, (s));
}

View file

@ -19,7 +19,7 @@ UNIT_TEST(MapApiSmoke)
TEST_EQUAL(api.GetPoints().size(), 1, ());
TEST_EQUAL(api.GetPoints()[0].m_lat, 38.970559, ());
TEST_EQUAL(api.GetPoints()[0].m_lon, -9.419289, ());
TEST_EQUAL(api.GetPoints()[0].m_title, "Point Name", ());
TEST_EQUAL(api.GetPoints()[0].m_name, "Point Name", ());
TEST_EQUAL(api.GetPoints()[0].m_id, "", ());
TEST_EQUAL(api.GetGlobalBackUrl(), "", ());
}
@ -47,7 +47,7 @@ UNIT_TEST(MapApiPointNameBeforeLatLon)
ParsedMapApi api(Uri("mapswithme://map?n=Name&ll=1,2"));
TEST(api.IsValid(), ());
TEST_EQUAL(api.GetPoints().size(), 1, ());
TEST_EQUAL(api.GetPoints()[0].m_title, "", ());
TEST_EQUAL(api.GetPoints()[0].m_name, "", ());
}
UNIT_TEST(MapApiPointNameOverwritten)
@ -55,7 +55,7 @@ UNIT_TEST(MapApiPointNameOverwritten)
ParsedMapApi api(Uri("mapswithme://map?ll=1,2&n=A&N=B"));
TEST(api.IsValid(), ());
TEST_EQUAL(api.GetPoints().size(), 1, ());
TEST_EQUAL(api.GetPoints()[0].m_title, "B", ());
TEST_EQUAL(api.GetPoints()[0].m_name, "B", ());
}
UNIT_TEST(MapApiMultiplePoints)
@ -65,11 +65,11 @@ UNIT_TEST(MapApiMultiplePoints)
TEST_EQUAL(api.GetPoints().size(), 3, ());
TEST_EQUAL(api.GetPoints()[0].m_lat, 1.1, ());
TEST_EQUAL(api.GetPoints()[0].m_lon, 1.2, ());
TEST_EQUAL(api.GetPoints()[0].m_title, "A", ());
TEST_EQUAL(api.GetPoints()[1].m_title, "", ());
TEST_EQUAL(api.GetPoints()[0].m_name, "A", ());
TEST_EQUAL(api.GetPoints()[1].m_name, "", ());
TEST_EQUAL(api.GetPoints()[1].m_lat, 2.1, ());
TEST_EQUAL(api.GetPoints()[1].m_lon, 2.2, ());
TEST_EQUAL(api.GetPoints()[2].m_title, "C", ());
TEST_EQUAL(api.GetPoints()[2].m_name, "C", ());
TEST_EQUAL(api.GetPoints()[2].m_lat, -3.1, ());
TEST_EQUAL(api.GetPoints()[2].m_lon, -3.2, ());
}
@ -81,7 +81,7 @@ UNIT_TEST(MapApiInvalidPointLatLonButValidOtherParts)
TEST_EQUAL(api.GetPoints().size(), 1, ());
TEST_EQUAL(api.GetPoints()[0].m_lat, 2, ());
TEST_EQUAL(api.GetPoints()[0].m_lon, 2, ());
TEST_EQUAL(api.GetPoints()[0].m_title, "B", ());
TEST_EQUAL(api.GetPoints()[0].m_name, "B", ());
}
UNIT_TEST(MapApiPointURLEncoded)
@ -89,7 +89,7 @@ UNIT_TEST(MapApiPointURLEncoded)
ParsedMapApi api(Uri("mwm://map?ll=1,2&n=%D0%9C%D0%B8%D0%BD%D1%81%D0%BA&id=http%3A%2F%2Fmap%3Fll%3D1%2C2%26n%3Dtest"));
TEST(api.IsValid(), ());
TEST_EQUAL(api.GetPoints().size(), 1, ());
TEST_EQUAL(api.GetPoints()[0].m_title, "\xd0\x9c\xd0\xb8\xd0\xbd\xd1\x81\xd0\xba", ());
TEST_EQUAL(api.GetPoints()[0].m_name, "\xd0\x9c\xd0\xb8\xd0\xbd\xd1\x81\xd0\xba", ());
TEST_EQUAL(api.GetPoints()[0].m_id, "http://map?ll=1,2&n=test", ());
}
@ -216,7 +216,7 @@ string generatePartOfUrl(url_scheme::ApiPoint const & point)
{
stringstream stream;
stream << "&ll=" << strings::ToString(point.m_lat) << "," << strings::ToString(point.m_lon)
<< "&n=" << point.m_title
<< "&n=" << point.m_name
<< "&id=" << point.m_id;
return stream.str();
}
@ -241,7 +241,7 @@ void generateRandomTest(size_t numberOfPoints, size_t stringLength)
point.m_lat *= random.Generate() % 2 == 0 ? 1 : -1;
point.m_lon = random.Generate() % 180;
point.m_lon *= random.Generate() % 2 == 0 ? 1 : -1;
point.m_title = randomString(stringLength, i);
point.m_name = randomString(stringLength, i);
point.m_id = randomString(stringLength, i);
vect[i] = point;
}
@ -256,7 +256,7 @@ void generateRandomTest(size_t numberOfPoints, size_t stringLength)
{
TEST_EQUAL(points[i].m_lat, vect[i].m_lat, ());
TEST_EQUAL(points[i].m_lon, vect[i].m_lon, ());
TEST_EQUAL(points[i].m_title, vect[i].m_title, ());
TEST_EQUAL(points[i].m_name, vect[i].m_name, ());
TEST_EQUAL(points[i].m_id, vect[i].m_id, ());
}
TEST_EQUAL(api.GetApiVersion(), 1, ());

View file

@ -103,7 +103,7 @@ void ParsedMapApi::AddKeyValue(string key, string const & value)
else if (key == "n")
{
if (!m_points.empty())
m_points.back().m_title = value;
m_points.back().m_name = value;
else
LOG(LWARNING, ("Map API: Point name with no point. 'll' should come first!"));
}

View file

@ -10,7 +10,7 @@ struct ApiPoint
{
double m_lat;
double m_lon;
string m_title;
string m_name;
string m_id;
};

View file

@ -1,28 +0,0 @@
#include "../std/vector.hpp"
namespace url_api
{
struct Point
{
Point() : m_lat(0), m_lon(0) {}
double m_lat;
double m_lon;
string m_name;
string m_id;
};
struct Request
{
vector<Point> m_points;
double m_viewportLat, m_viewportLon, m_viewportZoomLevel;
void Clear()
{
m_points.clear();
m_viewportLat = m_viewportLon = m_viewportZoomLevel = 0;
}
};
} // namespace url_api