*/
package org.opendaylight.yangtools.yang.data.codec.gson;
-import com.google.common.base.Preconditions;
-
-import java.net.URI;
-
+import com.google.gson.stream.JsonWriter;
+import java.io.IOException;
+import javax.annotation.Nonnull;
import org.opendaylight.yangtools.yang.common.QName;
-import org.opendaylight.yangtools.yang.data.util.AbstractModuleStringIdentityrefCodec;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+import org.opendaylight.yangtools.yang.data.util.ModuleStringIdentityrefCodec;
import org.opendaylight.yangtools.yang.model.api.Module;
import org.opendaylight.yangtools.yang.model.api.SchemaContext;
-final class JSONStringIdentityrefCodec extends AbstractModuleStringIdentityrefCodec implements JSONCodec<QName> {
- private final SchemaContext context;
-
- JSONStringIdentityrefCodec(final SchemaContext context) {
- this.context = Preconditions.checkNotNull(context);
- }
-
- @Override
- protected Module moduleForPrefix(final String prefix) {
- return context.findModuleByName(prefix, null);
+final class JSONStringIdentityrefCodec extends ModuleStringIdentityrefCodec implements JSONCodec<QName> {
+ JSONStringIdentityrefCodec(final SchemaContext context, final QNameModule parentModule) {
+ super(context, parentModule);
}
@Override
- protected String prefixForNamespace(final URI namespace) {
- final Module module = context.findModuleByNamespaceAndRevision(namespace, null);
- return module == null ? null : module.getName();
+ protected Module moduleForPrefix(@Nonnull final String prefix) {
+ if (prefix.isEmpty()) {
+ return context.findModuleByNamespaceAndRevision(parentModuleQname.getNamespace(),
+ parentModuleQname.getRevision());
+ } else {
+ return context.findModuleByName(prefix, null);
+ }
}
+ /**
+ * Serialize QName with specified JsonWriter.
+ *
+ * @param writer JsonWriter
+ * @param value QName
+ */
@Override
- public boolean needQuotes() {
- return true;
+ public void serializeToWriter(JsonWriter writer, QName value) throws IOException {
+ writer.value(serialize(value));
}
}