use of sqlite.kripton58.BeanInner in project kripton by xcesco.
the class BeanBeanBindMap method serializeOnJacksonAsString.
@Override
public int serializeOnJacksonAsString(BeanBean object, JsonGenerator jacksonSerializer) throws Exception {
jacksonSerializer.writeStartObject();
int fieldCount = 0;
// Serialized Field:
// field id (mapped with "id")
jacksonSerializer.writeStringField("id", PrimitiveUtils.writeLong(object.id));
// field value (mapped with "value")
if (object.value != null) {
fieldCount++;
int n = object.value.length;
BeanInner item;
// write wrapper tag
jacksonSerializer.writeFieldName("value");
if (n > 0) {
jacksonSerializer.writeStartArray();
for (int i = 0; i < n; i++) {
item = object.value[i];
if (item == null) {
jacksonSerializer.writeString("null");
} else {
if (beanInnerBindMap.serializeOnJacksonAsString(item, jacksonSerializer) == 0) {
jacksonSerializer.writeNullField("value");
}
}
}
jacksonSerializer.writeEndArray();
} else {
jacksonSerializer.writeString("");
}
}
// field value2 (mapped with "value2")
if (object.value2 != null) {
fieldCount++;
int n = object.value2.length;
BeanInner item;
// write wrapper tag
jacksonSerializer.writeFieldName("value2");
if (n > 0) {
jacksonSerializer.writeStartArray();
for (int i = 0; i < n; i++) {
item = object.value2[i];
if (item == null) {
jacksonSerializer.writeString("null");
} else {
if (beanInnerBindMap.serializeOnJacksonAsString(item, jacksonSerializer) == 0) {
jacksonSerializer.writeNullField("value2");
}
}
}
jacksonSerializer.writeEndArray();
} else {
jacksonSerializer.writeString("");
}
}
jacksonSerializer.writeEndObject();
return fieldCount;
}
use of sqlite.kripton58.BeanInner in project kripton by xcesco.
the class BeanBeanBindMap method parseOnJackson.
/**
* parse with jackson
*/
@Override
public BeanBean parseOnJackson(JsonParser jacksonParser) throws Exception {
BeanBean instance = new BeanBean();
String fieldName;
if (jacksonParser.currentToken() == null) {
jacksonParser.nextToken();
}
if (jacksonParser.currentToken() != JsonToken.START_OBJECT) {
jacksonParser.skipChildren();
return instance;
}
while (jacksonParser.nextToken() != JsonToken.END_OBJECT) {
fieldName = jacksonParser.getCurrentName();
jacksonParser.nextToken();
// Parse fields:
switch(fieldName) {
case "id":
// field id (mapped with "id")
instance.id = jacksonParser.getLongValue();
break;
case "value":
// field value (mapped with "value")
if (jacksonParser.currentToken() == JsonToken.START_ARRAY) {
ArrayList<BeanInner> collection = new ArrayList<>();
BeanInner item = null;
while (jacksonParser.nextToken() != JsonToken.END_ARRAY) {
if (jacksonParser.currentToken() == JsonToken.VALUE_NULL) {
item = null;
} else {
item = beanInnerBindMap.parseOnJackson(jacksonParser);
}
collection.add(item);
}
instance.value = CollectionUtils.asArray(collection, new BeanInner[collection.size()]);
}
break;
case "value2":
// field value2 (mapped with "value2")
if (jacksonParser.currentToken() == JsonToken.START_ARRAY) {
ArrayList<BeanInner> collection = new ArrayList<>();
BeanInner item = null;
while (jacksonParser.nextToken() != JsonToken.END_ARRAY) {
if (jacksonParser.currentToken() == JsonToken.VALUE_NULL) {
item = null;
} else {
item = beanInnerBindMap.parseOnJackson(jacksonParser);
}
collection.add(item);
}
instance.value2 = CollectionUtils.asArray(collection, new BeanInner[collection.size()]);
}
break;
default:
jacksonParser.skipChildren();
break;
}
}
return instance;
}
use of sqlite.kripton58.BeanInner in project kripton by xcesco.
the class BeanBeanTable method serializeValue.
/**
* for attribute value serialization
*/
public static byte[] serializeValue(BeanInner[] value) {
if (value == null) {
return null;
}
KriptonJsonContext context = KriptonBinder.jsonBind();
try (KriptonByteArrayOutputStream stream = new KriptonByteArrayOutputStream();
JacksonWrapperSerializer wrapper = context.createSerializer(stream)) {
JsonGenerator jacksonSerializer = wrapper.jacksonGenerator;
jacksonSerializer.writeStartObject();
int fieldCount = 0;
if (value != null) {
fieldCount++;
int n = value.length;
BeanInner item;
// write wrapper tag
jacksonSerializer.writeFieldName("element");
jacksonSerializer.writeStartArray();
for (int i = 0; i < n; i++) {
item = value[i];
if (item == null) {
jacksonSerializer.writeNull();
} else {
beanInnerBindMap.serializeOnJackson(item, jacksonSerializer);
}
}
jacksonSerializer.writeEndArray();
}
jacksonSerializer.writeEndObject();
jacksonSerializer.flush();
return stream.toByteArray();
} catch (Exception e) {
throw (new KriptonRuntimeException(e.getMessage()));
}
}
use of sqlite.kripton58.BeanInner in project kripton by xcesco.
the class BeanBeanTable method parseValue.
/**
* for attribute value parsing
*/
public static BeanInner[] parseValue(byte[] input) {
if (input == null) {
return null;
}
KriptonJsonContext context = KriptonBinder.jsonBind();
try (JacksonWrapperParser wrapper = context.createParser(input)) {
JsonParser jacksonParser = wrapper.jacksonParser;
// START_OBJECT
jacksonParser.nextToken();
// value of "element"
jacksonParser.nextValue();
BeanInner[] result = null;
if (jacksonParser.currentToken() == JsonToken.START_ARRAY) {
ArrayList<BeanInner> collection = new ArrayList<>();
BeanInner item = null;
while (jacksonParser.nextToken() != JsonToken.END_ARRAY) {
if (jacksonParser.currentToken() == JsonToken.VALUE_NULL) {
item = null;
} else {
item = beanInnerBindMap.parseOnJackson(jacksonParser);
}
collection.add(item);
}
result = CollectionUtils.asArray(collection, new BeanInner[collection.size()]);
}
return result;
} catch (Exception e) {
throw (new KriptonRuntimeException(e.getMessage()));
}
}
use of sqlite.kripton58.BeanInner in project kripton by xcesco.
the class BeanBeanTable method serializeValue2.
/**
* for attribute value2 serialization
*/
public static byte[] serializeValue2(BeanInner[] value) {
if (value == null) {
return null;
}
KriptonJsonContext context = KriptonBinder.jsonBind();
try (KriptonByteArrayOutputStream stream = new KriptonByteArrayOutputStream();
JacksonWrapperSerializer wrapper = context.createSerializer(stream)) {
JsonGenerator jacksonSerializer = wrapper.jacksonGenerator;
jacksonSerializer.writeStartObject();
int fieldCount = 0;
if (value != null) {
fieldCount++;
int n = value.length;
BeanInner item;
// write wrapper tag
jacksonSerializer.writeFieldName("element");
jacksonSerializer.writeStartArray();
for (int i = 0; i < n; i++) {
item = value[i];
if (item == null) {
jacksonSerializer.writeNull();
} else {
beanInnerBindMap.serializeOnJackson(item, jacksonSerializer);
}
}
jacksonSerializer.writeEndArray();
}
jacksonSerializer.writeEndObject();
jacksonSerializer.flush();
return stream.toByteArray();
} catch (Exception e) {
throw (new KriptonRuntimeException(e.getMessage()));
}
}
Aggregations