Testings with ObjectMapper
This commit is contained in:
parent
22f96431fa
commit
e657777d56
@ -30,19 +30,15 @@ import com.fasterxml.jackson.core.JsonProcessingException;
|
|||||||
import com.fasterxml.jackson.databind.MapperFeature;
|
import com.fasterxml.jackson.databind.MapperFeature;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import com.fasterxml.jackson.databind.SerializationFeature;
|
import com.fasterxml.jackson.databind.SerializationFeature;
|
||||||
|
import com.fasterxml.jackson.databind.node.ObjectNode;
|
||||||
import java.awt.Dialog;
|
import java.awt.Dialog;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
import javax.swing.InputVerifier;
|
|
||||||
import javax.swing.JComponent;
|
|
||||||
import javax.swing.JDialog;
|
|
||||||
import javax.swing.JTextField;
|
|
||||||
import opensesim.AbstractAsset;
|
import opensesim.AbstractAsset;
|
||||||
import opensesim.World;
|
import opensesim.World;
|
||||||
import opensesim.gui.EscDialog;
|
import opensesim.gui.EscDialog;
|
||||||
import opensesim.gui.Globals;
|
import opensesim.gui.Globals;
|
||||||
import opensesim.sesim.Assets.BasicAsset;
|
|
||||||
import opensesim.util.IDGenerator.Id;
|
import opensesim.util.IDGenerator.Id;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
@ -208,12 +204,15 @@ public class AssetEditorDialog extends EscDialog {
|
|||||||
|
|
||||||
String vs;
|
String vs;
|
||||||
try {
|
try {
|
||||||
|
|
||||||
vs = mapper.writeValueAsString(dialog.assetEditorPanel);
|
vs = mapper.writeValueAsString(dialog.assetEditorPanel);
|
||||||
System.out.print(vs);
|
System.out.print(vs);
|
||||||
} catch (JsonProcessingException ex) {
|
} catch (JsonProcessingException ex) {
|
||||||
Logger.getLogger(AssetEditorDialog.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(AssetEditorDialog.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ObjectNode n = mapper.valueToTree(dialog.assetEditorPanel);
|
||||||
|
|
||||||
return dialog.newId;
|
return dialog.newId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,8 +25,14 @@
|
|||||||
*/
|
*/
|
||||||
package opensesim.gui.AssetEditor;
|
package opensesim.gui.AssetEditor;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
import com.fasterxml.jackson.databind.SerializationFeature;
|
||||||
import java.util.AbstractMap;
|
import java.util.AbstractMap;
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.logging.Level;
|
||||||
|
import java.util.logging.Logger;
|
||||||
import javax.swing.table.AbstractTableModel;
|
import javax.swing.table.AbstractTableModel;
|
||||||
import javax.swing.table.DefaultTableModel;
|
import javax.swing.table.DefaultTableModel;
|
||||||
import javax.swing.table.TableModel;
|
import javax.swing.table.TableModel;
|
||||||
@ -35,6 +41,7 @@ import opensesim.sesim.Assets.BasicAsset;
|
|||||||
import opensesim.World;
|
import opensesim.World;
|
||||||
import opensesim.gui.Globals;
|
import opensesim.gui.Globals;
|
||||||
import opensesim.util.IDGenerator.Id;
|
import opensesim.util.IDGenerator.Id;
|
||||||
|
import opensesim.util.SeSimObjectMapper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@ -72,6 +79,7 @@ public class AssetListPanel extends javax.swing.JPanel {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m.setRowCount(0);
|
m.setRowCount(0);
|
||||||
|
|
||||||
for (AbstractAsset a : world.getAssetCollection()) {
|
for (AbstractAsset a : world.getAssetCollection()) {
|
||||||
m.addRow(new Object[]{
|
m.addRow(new Object[]{
|
||||||
a.getID(),
|
a.getID(),
|
||||||
@ -79,12 +87,23 @@ public class AssetListPanel extends javax.swing.JPanel {
|
|||||||
a.getName(),
|
a.getName(),
|
||||||
a.getTypeName()
|
a.getTypeName()
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Collection ac;
|
||||||
|
ObjectMapper om = new ObjectMapper();
|
||||||
|
om.disable(SerializationFeature.FAIL_ON_EMPTY_BEANS);
|
||||||
|
try {
|
||||||
|
String s = om.writeValueAsString(world.getAssetCollection());
|
||||||
|
System.out.printf("MyValues %s", s);
|
||||||
|
} catch (JsonProcessingException ex) {
|
||||||
|
Logger.getLogger(AssetListPanel.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public TableModel getModel() {
|
private TableModel getModel() {
|
||||||
|
|
||||||
class TModel extends DefaultTableModel {
|
class TModel extends DefaultTableModel {
|
||||||
|
|
||||||
|
57
src/opensesim/util/SeSimObjectMapper.java
Normal file
57
src/opensesim/util/SeSimObjectMapper.java
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, 7u83 <7u83@mail.ru>
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
package opensesim.util;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.databind.MapperFeature;
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
import com.fasterxml.jackson.databind.SerializationFeature;
|
||||||
|
import com.fasterxml.jackson.databind.node.ObjectNode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author 7u83 <7u83@mail.ru>
|
||||||
|
*/
|
||||||
|
public final class SeSimObjectMapper extends ObjectMapper {
|
||||||
|
|
||||||
|
Object object;
|
||||||
|
|
||||||
|
public SeSimObjectMapper(Object o) {
|
||||||
|
super();
|
||||||
|
object = o;
|
||||||
|
// disable auto detection
|
||||||
|
disable(MapperFeature.AUTO_DETECT_CREATORS,
|
||||||
|
MapperFeature.AUTO_DETECT_FIELDS,
|
||||||
|
MapperFeature.AUTO_DETECT_GETTERS,
|
||||||
|
MapperFeature.AUTO_DETECT_IS_GETTERS);
|
||||||
|
// if you want to prevent an exception when classes have no annotated properties
|
||||||
|
disable(SerializationFeature.FAIL_ON_EMPTY_BEANS);
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectNode getObjectNode() {
|
||||||
|
return valueToTree(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user