hprose.io.serialize.ZonedDateTimeSerializer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hprose-java Show documentation
Show all versions of hprose-java Show documentation
Hprose is a High Performance Remote Object Service Engine.
It is a modern, lightweight, cross-language, cross-platform, object-oriented, high performance, remote dynamic communication middleware. It is not only easy to use, but powerful. You just need a little time to learn, then you can use it to easily construct cross language cross platform distributed application system.
Hprose supports many programming languages, for example:
* AAuto Quicker
* ActionScript
* ASP
* C++
* Dart
* Delphi/Free Pascal
* dotNET(C#, Visual Basic...)
* Golang
* Java
* JavaScript
* Node.js
* Objective-C
* Perl
* PHP
* Python
* Ruby
* ...
Through Hprose, You can conveniently and efficiently intercommunicate between those programming languages.
This project is the implementation of Hprose for Java.
/**********************************************************\
| |
| hprose |
| |
| Official WebSite: http://www.hprose.com/ |
| http://www.hprose.org/ |
| |
\**********************************************************/
/**********************************************************\
* *
* ZonedDateTimeSerializer.java *
* *
* ZonedDateTime serializer class for Java. *
* *
* LastModified: Apr 17, 2016 *
* Author: Ma Bingyao *
* *
\**********************************************************/
package hprose.io.serialize;
import static hprose.io.HproseTags.TagString;
import static hprose.io.HproseTags.TagUTC;
import java.io.IOException;
import java.io.OutputStream;
import java.time.ZoneOffset;
import java.time.ZonedDateTime;
final class ZonedDateTimeSerializer implements Serializer {
public final static ZonedDateTimeSerializer instance = new ZonedDateTimeSerializer();
public final static void write(OutputStream stream, WriterRefer refer, ZonedDateTime datetime) throws IOException {
if (refer != null) refer.set(datetime);
if (!(datetime.getOffset().equals(ZoneOffset.UTC))) {
stream.write(TagString);
ValueWriter.write(stream, datetime.toString());
}
else {
int year = datetime.getYear();
if (year > 9999 || year < 1) {
stream.write(TagString);
ValueWriter.write(stream, datetime.toString());
}
else {
ValueWriter.writeDate(stream, year, datetime.getMonthValue(), datetime.getDayOfMonth());
ValueWriter.writeTime(stream, datetime.getHour(), datetime.getMinute(), datetime.getSecond(), 0, false, true);
ValueWriter.writeNano(stream, datetime.getNano());
stream.write(TagUTC);
}
}
}
public final void write(Writer writer, ZonedDateTime obj) throws IOException {
OutputStream stream = writer.stream;
WriterRefer refer = writer.refer;
if (refer == null || !refer.write(stream, obj)) {
write(stream, refer, obj);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy