- Timestamp:
- 2016-02-01T23:47:27+01:00 (9 years ago)
- Location:
- trunk
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/org/openstreetmap/josm/gui/datatransfer/PrimitiveTransferable.java
r9563 r9711 19 19 20 20 /** 21 * Data flavor for{@link PrimitiveData}.21 * A wrapper for a collection of {@link PrimitiveData}. 22 22 */ 23 public static final DataFlavor PRIMITIVE_DATA = new DataFlavor(PrimitiveData.class, PrimitiveData.class.getName()); 23 public static final class Data { 24 private final Collection<PrimitiveData> primitiveData; 25 26 private Data(Collection<PrimitiveData> primitiveData) { 27 this.primitiveData = primitiveData; 28 } 29 30 /** 31 * Returns the contained {@link PrimitiveData} 32 * @return the contained {@link PrimitiveData} 33 */ 34 public Collection<PrimitiveData> getPrimitiveData() { 35 return primitiveData; 36 } 37 } 38 39 /** 40 * Data flavor for {@link PrimitiveData} which is wrapped in {@link Data}. 41 */ 42 public static final DataFlavor PRIMITIVE_DATA = new DataFlavor(Data.class, Data.class.getName()); 24 43 private final Collection<? extends OsmPrimitive> primitives; 25 44 … … 47 66 return getStringData(); 48 67 } else if (PRIMITIVE_DATA.equals(flavor)) { 49 return get RelationMemberData();68 return getPrimitiveData(); 50 69 } 51 70 throw new UnsupportedFlavorException(flavor); … … 63 82 } 64 83 65 protected Collection<PrimitiveData> getRelationMemberData() {84 protected Data getPrimitiveData() { 66 85 final Collection<PrimitiveData> r = new ArrayList<>(primitives.size()); 67 86 for (OsmPrimitive primitive : primitives) { 68 87 r.add(primitive.save()); 69 88 } 70 return r;89 return new Data(r); 71 90 } 72 91 } -
trunk/src/org/openstreetmap/josm/gui/datatransfer/RelationMemberTransferable.java
r9563 r9711 19 19 20 20 /** 21 * Data flavor for{@link RelationMemberData}.21 * A wrapper for a collection of {@link RelationMemberData}. 22 22 */ 23 public static final DataFlavor RELATION_MEMBER_DATA = new DataFlavor(RelationMemberData.class, RelationMemberData.class.getName()); 23 public static final class Data { 24 private final Collection<RelationMemberData> relationMemberDatas; 25 26 private Data(Collection<RelationMemberData> primitiveData) { 27 this.relationMemberDatas = primitiveData; 28 } 29 30 /** 31 * Returns the contained {@link RelationMemberData} 32 * @return the contained {@link RelationMemberData} 33 */ 34 public Collection<RelationMemberData> getRelationMemberData() { 35 return relationMemberDatas; 36 } 37 } 38 39 /** 40 * Data flavor for {@link RelationMemberData} which is wrapped in {@link Data}. 41 */ 42 public static final DataFlavor RELATION_MEMBER_DATA = new DataFlavor(Data.class, Data.class.getName()); 24 43 private final Collection<RelationMember> members; 25 44 … … 64 83 } 65 84 66 protected Collection<RelationMemberData>getRelationMemberData() {85 protected Data getRelationMemberData() { 67 86 final Collection<RelationMemberData> r = new ArrayList<>(members.size()); 68 87 for (RelationMember member : members) { 69 88 r.add(new RelationMemberData(member.getRole(), member.getType(), member.getUniqueId())); 70 89 } 71 return r;90 return new Data(r); 72 91 } 73 92 } -
trunk/src/org/openstreetmap/josm/gui/dialogs/relation/MemberTransferHandler.java
r9379 r9711 64 64 protected void importRelationMemberData(TransferSupport support, final MemberTable destination, int insertRow) 65 65 throws UnsupportedFlavorException, IOException { 66 //noinspection unchecked 67 @SuppressWarnings("unchecked") 68 final Collection<RelationMemberData> memberData = (Collection<RelationMemberData>) 66 final RelationMemberTransferable.Data memberData = (RelationMemberTransferable.Data) 69 67 support.getTransferable().getTransferData(RelationMemberTransferable.RELATION_MEMBER_DATA); 70 importData(destination, insertRow, memberData , new Function<RelationMemberData, RelationMember>() {68 importData(destination, insertRow, memberData.getRelationMemberData(), new Function<RelationMemberData, RelationMember>() { 71 69 @Override 72 70 public RelationMember apply(RelationMemberData member) { … … 84 82 protected void importPrimitiveData(TransferSupport support, final MemberTable destination, int insertRow) 85 83 throws UnsupportedFlavorException, IOException { 86 //noinspection unchecked 87 @SuppressWarnings("unchecked") 88 final Collection<PrimitiveData> data = (Collection<PrimitiveData>) 84 final PrimitiveTransferable.Data data = (PrimitiveTransferable.Data) 89 85 support.getTransferable().getTransferData(PrimitiveTransferable.PRIMITIVE_DATA); 90 importData(destination, insertRow, data , new Function<PrimitiveData, RelationMember>() {86 importData(destination, insertRow, data.getPrimitiveData(), new Function<PrimitiveData, RelationMember>() { 91 87 @Override 92 88 public RelationMember apply(PrimitiveData data) { -
trunk/test/unit/org/openstreetmap/josm/gui/datatransfer/PrimitiveTransferableTest.java
r9669 r9711 4 4 import static org.junit.Assert.assertEquals; 5 5 import static org.junit.Assert.assertFalse; 6 import static org.junit.Assert.assertNotNull;7 6 import static org.junit.Assert.assertTrue; 8 7 import static org.openstreetmap.josm.gui.datatransfer.PrimitiveTransferable.PRIMITIVE_DATA; … … 57 56 */ 58 57 @Test 59 @SuppressWarnings("unchecked")60 58 public void testGetTransferDataNominal() throws UnsupportedFlavorException { 61 59 PrimitiveTransferable pt = new PrimitiveTransferable(Collections.singleton(new Node(1))); 62 60 assertEquals("node 1 # incomplete\n", pt.getTransferData(DataFlavor.stringFlavor)); 63 Collection<PrimitiveData> td = ( Collection<PrimitiveData>) pt.getTransferData(PRIMITIVE_DATA);61 Collection<PrimitiveData> td = ((PrimitiveTransferable.Data) pt.getTransferData(PRIMITIVE_DATA)).getPrimitiveData(); 64 62 assertEquals(1, td.size()); 65 assert NotNull(td.iterator().next());63 assertTrue(td.iterator().next() instanceof PrimitiveData); 66 64 } 67 65 -
trunk/test/unit/org/openstreetmap/josm/gui/datatransfer/RelationMemberTransferableTest.java
r9669 r9711 4 4 import static org.junit.Assert.assertEquals; 5 5 import static org.junit.Assert.assertFalse; 6 import static org.junit.Assert.assertNotNull;7 6 import static org.junit.Assert.assertTrue; 8 7 import static org.openstreetmap.josm.gui.datatransfer.RelationMemberTransferable.RELATION_MEMBER_DATA; … … 17 16 import org.openstreetmap.josm.JOSMFixture; 18 17 import org.openstreetmap.josm.data.osm.Node; 19 import org.openstreetmap.josm.data.osm.PrimitiveData;20 18 import org.openstreetmap.josm.data.osm.RelationMember; 19 import org.openstreetmap.josm.data.osm.RelationMemberData; 21 20 22 21 /** … … 58 57 */ 59 58 @Test 60 @SuppressWarnings("unchecked")61 59 public void testGetTransferDataNominal() throws UnsupportedFlavorException { 62 60 RelationMemberTransferable rmt = new RelationMemberTransferable(Collections.singleton(new RelationMember("test", new Node(1)))); 63 61 assertEquals("node 1 test # incomplete\n", rmt.getTransferData(DataFlavor.stringFlavor)); 64 Collection< PrimitiveData> td = (Collection<PrimitiveData>) rmt.getTransferData(RELATION_MEMBER_DATA);62 Collection<RelationMemberData> td = ((RelationMemberTransferable.Data) rmt.getTransferData(RELATION_MEMBER_DATA)).getRelationMemberData(); 65 63 assertEquals(1, td.size()); 66 assert NotNull(td.iterator().next());64 assertTrue(td.iterator().next() instanceof RelationMemberData); 67 65 } 68 66
Note:
See TracChangeset
for help on using the changeset viewer.