Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Save Atlas to ProtobufAtlas similar to TextAtlas #99

Merged
merged 39 commits into from
Mar 29, 2018
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
bb7706a
Fully integrated protobuf build flow with gradle. See ECLIPSE_README.…
lucaspcram Mar 19, 2018
1890bc8
Fixed spotless application to ignore generated source code.
lucaspcram Mar 19, 2018
a03cade
Initial, naive implementation of proto specs for Tags and Points.
lucaspcram Mar 19, 2018
4e05e34
Small updates to the README files.
lucaspcram Mar 20, 2018
18611a3
Started implementation of naive ProtoAtlasBuilder
lucaspcram Mar 20, 2018
f382466
Implemented Point and Line packing.
lucaspcram Mar 21, 2018
fd9af27
Stylistic and structural changes per PR notes.
lucaspcram Mar 22, 2018
fbdaacc
Trying to get Areas working with the serializer.
lucaspcram Mar 22, 2018
c9720fe
Fixed tab indentation to use spaces in suppressions.xml
lucaspcram Mar 22, 2018
bc15496
Trying to fix the Area serialization. Currently failing due to Polygo…
lucaspcram Mar 22, 2018
a804b72
Fixed failing tests, which were due to bad copy paste.
lucaspcram Mar 22, 2018
40437f7
Integrated a few PR style suggestions.
lucaspcram Mar 22, 2018
70abe50
Added an area count to the metadata.
lucaspcram Mar 22, 2018
1eba0c9
Last of the copy paste shenanigans that I messed up. I hope. lol
lucaspcram Mar 22, 2018
d08f1a8
Ok. If this is not the last copy-paste bug then I resign.
lucaspcram Mar 22, 2018
5aa04a8
Initial drafts of Node and Edge protos.
lucaspcram Mar 22, 2018
539337e
Added unit tests for the proto converter classes.
lucaspcram Mar 23, 2018
0bfec87
Changed packages on the converter classes per PR suggestions.
lucaspcram Mar 23, 2018
5ce39d5
Forgot to stage this file.
lucaspcram Mar 23, 2018
6359a6f
Implemented support for Nodes and Edges.
lucaspcram Mar 23, 2018
ba3b136
Almost done with relations. Small bug with the OSM identifier. See un…
lucaspcram Mar 23, 2018
6db5ee7
Fixed bug with relation packing. Relations work!
lucaspcram Mar 24, 2018
a7266a6
Lots of ProtoAtlas testing.
lucaspcram Mar 26, 2018
27aa4e2
Added some commands for converting between Packed and ProtoAtlases. T…
lucaspcram Mar 26, 2018
4cd48d0
Fixed spotless formatting issue.
lucaspcram Mar 26, 2018
4a06a5d
Wrote a quick test class to investigate the proto size discrepancies.
lucaspcram Mar 26, 2018
cd9fb95
Fixed bug where tags containing delimiter characters were not deseria…
lucaspcram Mar 26, 2018
f8db3ff
Added a ProtoAtlas file suffix to FileSuffix per Mike suggestion
lucaspcram Mar 26, 2018
307b015
Changed hardcoded protoc value in build.gradle
lucaspcram Mar 27, 2018
0e19a0b
Tweak to buildflow. Gradle project refresh still requires a rebuild, but
lucaspcram Mar 28, 2018
2678b77
Small tweak to prevent Gradle Refresh from deleting the generated code.
lucaspcram Mar 28, 2018
bc6f404
Added a task to actually clear the generated code.
lucaspcram Mar 29, 2018
fe1e9a1
Slight tweak to build.gradle to fix beforeMerged
lucaspcram Mar 29, 2018
3918bb8
Hopefully ready for merge
lucaspcram Mar 29, 2018
ee43801
Finalized fixes to gradle. Everything should work now.
lucaspcram Mar 29, 2018
eeeb127
Slight change to README
lucaspcram Mar 29, 2018
0d4e3f0
Fixed checkstyle and spotless suppressions to deal with new generated…
lucaspcram Mar 29, 2018
9657bac
Final changes before merge. Hopefully we are ready to go.
lucaspcram Mar 29, 2018
79e7450
Fixed some nits.
lucaspcram Mar 29, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fixed bug where tags containing delimiter characters were not deseria…
…lized correctly.
  • Loading branch information
lucaspcram committed Mar 26, 2018
commit cd9fb958987bb6f2edece621ec59e81ccb98def4
Original file line number Diff line number Diff line change
Expand Up @@ -83,9 +83,11 @@ public PackedAtlas read(final Resource resource)
protoAtlasContainer.getNumberOfNodes(), protoAtlasContainer.getNumberOfAreas(),
protoAtlasContainer.getNumberOfLines(), protoAtlasContainer.getNumberOfPoints(),
protoAtlasContainer.getNumberOfRelations());

// TODO it would be nice to programmatically determine which protobuf version is in use
final AtlasMetaData atlasMetaData = new AtlasMetaData(atlasSize, true, "unknown",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Wondering if we should have any kind of tag to specify this atlas was built from Proto?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll take a look at that class and see if there's something I can add.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh I just mean add an entry into the Metadata tags saying source=proto and proto_version=xx (not sure if you can read that dynamically, but assuming yes).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ah ok yeah can do. Did you have some fancy method in mind or should I just write code that greps build.gradle?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I thought there might be an easier way! If there's not, I wouldn't worry about it.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll mark it as TODO and if some simple way presents itself I'll be sure to implement it.

"ProtoAtlas", "unknown", "unknown", Maps.hashMap());

final PackedAtlasBuilder builder = new PackedAtlasBuilder().withSizeEstimates(atlasSize)
.withMetaData(atlasMetaData).withName(resource.getName());

Expand Down

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
import org.openstreetmap.atlas.exception.CoreException;
import org.openstreetmap.atlas.proto.ProtoTag;
import org.openstreetmap.atlas.utilities.collections.Maps;
import org.openstreetmap.atlas.utilities.collections.StringList;
import org.openstreetmap.atlas.utilities.conversion.TwoWayConverter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
Expand Down Expand Up @@ -53,8 +52,8 @@ public List<ProtoTag> backwardConvert(final Map<String, String> osmTagMap)
valueText = entry.getValue();
}

final String fullTag = keyText + TAG_DELIMITER + valueText;
tagBuilder.setTagText(fullTag);
tagBuilder.setKey(keyText);
tagBuilder.setValue(valueText);
protoTags.add(tagBuilder.build());

}
Expand All @@ -69,15 +68,7 @@ public Map<String, String> convert(final List<ProtoTag> protoTagList)
final Map<String, String> result = Maps.hashMap();
for (final ProtoTag tag : protoTagList)
{
final StringList tagSplit = StringList.split(tag.getTagText(), TAG_DELIMITER);
if (tagSplit.size() == 2)
{
result.put(tagSplit.get(0), tagSplit.get(1));
}
if (tagSplit.size() == 1)
{
result.put(tagSplit.get(0), "");
}
result.put(tag.getKey(), tag.getValue());
}
return result;
}
Expand Down
3 changes: 2 additions & 1 deletion src/main/proto/Tag.proto
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,6 @@ option java_outer_classname = "ProtoTagWrapper";
package org.openstreetmap.atlas.proto;

message ProtoTag {
optional string tagText = 1;
optional string key = 1;
optional string value = 2;
}
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,8 @@ public void testOSMToProtoTagList()
osmTagMap.put("key1", "value1");
osmTagMap.put("key2", "value2");
final List<ProtoTag> protoTagList = new ArrayList<>();
protoTagList.add(ProtoTag.newBuilder().setTagText("key1=value1").build());
protoTagList.add(ProtoTag.newBuilder().setTagText("key2=value2").build());
protoTagList.add(ProtoTag.newBuilder().setKey("key1").setValue("value1").build());
protoTagList.add(ProtoTag.newBuilder().setKey("key2").setValue("value2").build());

final List<ProtoTag> listFromMap = converter.backwardConvert(osmTagMap);
Assert.assertEquals(protoTagList, listFromMap);
Expand All @@ -52,8 +52,8 @@ public void testProtoTagListToOSM()
{
final ProtoTagListConverter converter = new ProtoTagListConverter();
final List<ProtoTag> protoTagList = new ArrayList<>();
protoTagList.add(ProtoTag.newBuilder().setTagText("key1=value1").build());
protoTagList.add(ProtoTag.newBuilder().setTagText("key2=value2").build());
protoTagList.add(ProtoTag.newBuilder().setKey("key1").setValue("value1").build());
protoTagList.add(ProtoTag.newBuilder().setKey("key2").setValue("value2").build());
final Map<String, String> osmTagMap = new HashMap<>();
osmTagMap.put("key1", "value1");
osmTagMap.put("key2", "value2");
Expand Down