List of usage examples for com.google.gwt.user.rebind.rpc SerializableTypeOracleBuilder SerializableTypeOracleBuilder
public SerializableTypeOracleBuilder(TreeLogger logger, PropertyOracle propertyOracle, GeneratorContextExt context) throws UnableToCompleteException
From source file:com.googlecode.serialization.JsonSerializationGenerator.java
License:Apache License
@Override public String generate(final TreeLogger logger, final GeneratorContext context, final String typeName) throws UnableToCompleteException { factoryType = null;//www.j a v a2s .co m type = null; whiteListType = null; typeParameters = null; //logger.log(TreeLogger.Type.WARN, "typeName:" + typeName); final TypeOracle typeOracle = context.getTypeOracle(); assert typeOracle != null; validateTypes(logger, typeOracle, typeName); final String packageName = factoryType.getPackage().getName(); //logger.log(TreeLogger.Type.WARN, "packageName:" + packageName); final PropertyOracle propertyOracle = context.getPropertyOracle(); // Debugging // logger.log(TreeLogger.Type.WARN, "Logging blacklist:"); // try { // final ConfigurationProperty prop = propertyOracle.getConfigurationProperty("rpc.blacklist"); // for (String value : prop.getValues()) { // logger.log(TreeLogger.Type.WARN, "Blacklist:" + value); // } // } catch (BadPropertyValueException e) { // logger.log(TreeLogger.Type.ERROR, "Could not find property rpc.blacklist"); // throw new UnableToCompleteException(); // } // end Debugging // Load the blacklist/whitelist final BlacklistFilter blacklistTypeFilter = new BlacklistFilter(logger, propertyOracle); final SerializableTypeOracleBuilder typesSentFromBrowserBuilder = new SerializableTypeOracleBuilder(logger, propertyOracle, context); typesSentFromBrowserBuilder.setTypeFilter(blacklistTypeFilter); final SerializableTypeOracleBuilder typesSentToBrowserBuilder = new SerializableTypeOracleBuilder(logger, propertyOracle, context); typesSentToBrowserBuilder.setTypeFilter(blacklistTypeFilter); addRoots(logger, typeOracle, typesSentFromBrowserBuilder, typesSentToBrowserBuilder); final SerializableTypeOracle typesSentFromBrowser = typesSentFromBrowserBuilder.build(logger); final SerializableTypeOracle typesSentToBrowser = typesSentToBrowserBuilder.build(logger); final String typeNameParam; if (typeParameters != null && typeParameters.length > 0) { final StringBuilder sb = new StringBuilder(); sb.append(type.getName()).append("<"); for (JClassType typeParameter : typeParameters) { sb.append(typeParameter.getName()).append(","); } sb.delete(sb.length() - 1, sb.length()); sb.append(">"); typeNameParam = sb.toString(); } else { typeNameParam = type.getName(); } final String typeNameParamInline = typeNameParam.replace(",", "_").replace("<", "_").replace(">", ""); final String jsonTypeSerializer = typeNameParamInline + "_JsonTypeSerializer"; final TypeSerializerCreator tsc = new TypeSerializerCreator(logger, typesSentFromBrowser, typesSentToBrowser, context, packageName + "." + jsonTypeSerializer, jsonTypeSerializer); tsc.realize(logger); final String jsonFactoryName = factoryType.getName().replace('.', '_') + "_AutogeneratedImpl"; final PrintWriter printWriter = context.tryCreate(logger, packageName, jsonFactoryName); if (printWriter != null) { printWriter.append("package ").append(packageName).append(";\n"); printWriter.append("import com.google.gwt.user.client.rpc.impl.Serializer;\n"); printWriter.append("import com.googlecode.gwt.serialization.JsonReader;\n"); printWriter.append("import com.googlecode.gwt.serialization.JsonReaderImpl;\n"); printWriter.append("import com.googlecode.gwt.serialization.JsonSerializationFactory;\n"); printWriter.append("import com.googlecode.gwt.serialization.JsonWriter;\n"); printWriter.append("import com.googlecode.gwt.serialization.JsonWriterImpl;\n"); printWriter.append("import ").append(type.getQualifiedSourceName()).append(";\n"); if (typeParameters != null && typeParameters.length > 0) { for (JClassType typeParameter : typeParameters) { printWriter.append("import ").append(typeParameter.getQualifiedSourceName()).append(";\n"); } } printWriter.append("import ").append(packageName).append(".").append(jsonTypeSerializer) .append(";\n\n"); printWriter.append("public class ").append(jsonFactoryName).append(" implements ") .append(factoryType.getQualifiedSourceName()).append(" {\n"); printWriter.append(" private final Serializer serializer = new ").append(jsonTypeSerializer) .append("();\n"); printWriter.append(" private final JsonReaderImpl<").append(typeNameParam) .append("> reader = new JsonReaderImpl<").append(typeNameParam).append(">(serializer);\n"); printWriter.append(" private final JsonWriterImpl<").append(typeNameParam) .append("> writer = new JsonWriterImpl<").append(typeNameParam).append(">(serializer);\n\n"); printWriter.append(" @Override\n"); printWriter.append(" public JsonReader<").append(typeNameParam).append("> getReader() {\n"); printWriter.append(" return reader;\n"); printWriter.append(" }\n\n"); printWriter.append(" @Override\n"); printWriter.append(" public JsonWriter<").append(typeNameParam).append("> getWriter() {\n"); printWriter.append(" return writer;\n"); printWriter.append(" }\n"); printWriter.append("}\n"); context.commit(logger, printWriter); } return packageName + "." + jsonFactoryName; }
From source file:com.googlecode.serialization.JsonWriterGenerator.java
License:Apache License
@Override public String generate(TreeLogger logger, GeneratorContext context, String typeName) throws UnableToCompleteException { //logger.log(TreeLogger.Type.WARN, "banana typeName:" + typeName); final TypeOracle typeOracle = context.getTypeOracle(); assert typeOracle != null; validateTypes(logger, typeOracle, typeName); final String packageName = rwType.getPackage().getName(); //logger.log(TreeLogger.Type.WARN, "packageName:" + packageName); final PropertyOracle propertyOracle = context.getPropertyOracle(); // Load the blacklist/whitelist final BlacklistFilter blacklistTypeFilter = new BlacklistFilter(logger, propertyOracle); final SerializableTypeOracleBuilder typesSentFromBrowserBuilder = new SerializableTypeOracleBuilder(logger, propertyOracle, context);/* w ww . java 2 s .c o m*/ typesSentFromBrowserBuilder.setTypeFilter(blacklistTypeFilter); final SerializableTypeOracleBuilder typesSentToBrowserBuilder = new SerializableTypeOracleBuilder(logger, propertyOracle, context); typesSentToBrowserBuilder.setTypeFilter(blacklistTypeFilter); addRoots(logger, typeOracle, typesSentFromBrowserBuilder, typesSentToBrowserBuilder); final SerializableTypeOracle typesSentFromBrowser = typesSentFromBrowserBuilder.build(logger); final SerializableTypeOracle typesSentToBrowser = typesSentToBrowserBuilder.build(logger); final String jsonTypeSerializer = type.getName() + "_JsonTypeSerializer"; final TypeSerializerCreator tsc = new TypeSerializerCreator(logger, typesSentFromBrowser, typesSentToBrowser, context, type.getPackage().getName() + "." + jsonTypeSerializer, jsonTypeSerializer); tsc.realize(logger); final String jsonWriterName = rwType.getName().replace('.', '_') + "AutogeneratedImpl"; final PrintWriter jwWriter = context.tryCreate(logger, packageName, jsonWriterName); if (jwWriter != null) { jwWriter.append("package ").append(packageName).append(";\n"); jwWriter.append("import com.google.gwt.user.client.rpc.SerializationException;\n"); jwWriter.append("import com.googlecode.gwt.serialization.JsonSerializationStreamWriter;\n"); jwWriter.append("import com.googlecode.gwt.serialization.JsonWriter;\n"); jwWriter.append("import ").append(type.getQualifiedSourceName()).append(";\n"); jwWriter.append("import ").append(type.getQualifiedSourceName()).append("_JsonTypeSerializer;\n\n"); jwWriter.append("public class ").append(jsonWriterName).append(" implements ") .append(rwType.getQualifiedSourceName()).append(" {\n"); jwWriter.append(" @Override\n"); jwWriter.append(" public String write(final ").append(type.getName()).append(" model) {\n"); jwWriter.append( " final JsonSerializationStreamWriter writer = new JsonSerializationStreamWriter(new ") .append(type.getName()).append("_JsonTypeSerializer());\n"); jwWriter.append(" try {\n"); jwWriter.append(" writer.writeObject(model);\n"); jwWriter.append(" } catch (SerializationException e) {\n"); jwWriter.append(" throw new RuntimeException(e);\n"); jwWriter.append(" }\n"); jwWriter.append(" return writer.toString();\n"); jwWriter.append(" }\n"); jwWriter.append("}\n"); context.commit(logger, jwWriter); } return packageName + "." + jsonWriterName; }
From source file:com.seanchenxi.gwt.storage.rebind.StorageTypeSerializerGenerator.java
License:Apache License
private SerializableTypeOracle buildSerializableTypeOracle(TreeLogger logger, GeneratorContext context, Set<JType> serializables) throws UnableToCompleteException { SerializableTypeOracleBuilder builder = new SerializableTypeOracleBuilder(logger, context.getPropertyOracle(), context); for (JType type : serializables) { builder.addRootType(logger, type); }/* ww w . j ava 2 s . c o m*/ return builder.build(logger); }
From source file:net.zschech.gwt.comet.rebind.CometSerializerGenerator.java
License:Apache License
@Override public RebindResult generateIncrementally(TreeLogger logger, GeneratorContext context, String typeName) throws UnableToCompleteException { TypeOracle typeOracle = context.getTypeOracle(); // Create the CometSerializer impl String packageName = "comet"; String className = typeName.replace('.', '_') + "Impl"; PrintWriter printWriter = context.tryCreate(logger, packageName, className); if (printWriter != null) { try {/*from w w w . j a va2s. c o m*/ JClassType type = typeOracle.getType(typeName); SerialTypes annotation = type.getAnnotation(SerialTypes.class); if (annotation == null) { logger.log(TreeLogger.ERROR, "No SerialTypes annotation on CometSerializer type: " + typeName); throw new UnableToCompleteException(); } SerializableTypeOracleBuilder typesSentToBrowserBuilder = new SerializableTypeOracleBuilder(logger, context.getPropertyOracle(), context); SerializableTypeOracleBuilder typesSentFromBrowserBuilder = new SerializableTypeOracleBuilder( logger, context.getPropertyOracle(), context); for (Class<? extends Serializable> serializable : annotation.value()) { int rank = 0; if (serializable.isArray()) { while (serializable.isArray()) { serializable = (Class<? extends Serializable>) serializable.getComponentType(); rank++; } } JType resolvedType = typeOracle.getType(serializable.getCanonicalName()); while (rank > 0) { resolvedType = typeOracle.getArrayType(resolvedType); rank--; } typesSentToBrowserBuilder.addRootType(logger, resolvedType); } OutputStream pathInfo = context.tryCreateResource(logger, typeName + ".rpc.log"); PrintWriter writer = new PrintWriter(new OutputStreamWriter(pathInfo)); writer.write("====================================\n"); writer.write("Types potentially sent from browser:\n"); writer.write("====================================\n\n"); writer.flush(); typesSentToBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentFromBrowser = typesSentFromBrowserBuilder.build(logger); writer.write("===================================\n"); writer.write("Types potentially sent from server:\n"); writer.write("===================================\n\n"); writer.flush(); typesSentFromBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentToBrowser = typesSentToBrowserBuilder.build(logger); writer.close(); if (pathInfo != null) { context.commitResource(logger, pathInfo).setPrivate(true); } // Create the serializer String modifiedTypeName = typeName.replace('.', '_') + "Serializer"; TypeSerializerCreator tsc = new TypeSerializerCreator(logger, typesSentFromBrowser, typesSentToBrowser, context, "comet." + modifiedTypeName, modifiedTypeName); String realize = tsc.realize(logger); // Create the CometSerializer impl ClassSourceFileComposerFactory composerFactory = new ClassSourceFileComposerFactory(packageName, className); composerFactory.addImport(Serializer.class.getName()); composerFactory.addImport(SerialMode.class.getName()); composerFactory.setSuperclass(typeName); // TODO is the SERIALIZER required for DE RPC? SourceWriter sourceWriter = composerFactory.createSourceWriter(context, printWriter); sourceWriter.print("private Serializer SERIALIZER = new " + realize + "();"); sourceWriter.print("protected Serializer getSerializer() {return SERIALIZER;}"); sourceWriter .print("public SerialMode getMode() {return SerialMode." + annotation.mode().name() + ";}"); sourceWriter.commit(logger); if (annotation.mode() == SerialMode.DE_RPC) { RpcDataArtifact data = new RpcDataArtifact(type.getQualifiedSourceName()); for (JType t : typesSentToBrowser.getSerializableTypes()) { if (!(t instanceof JClassType)) { continue; } JField[] serializableFields = SerializationUtils .getSerializableFields(context.getTypeOracle(), (JClassType) t); List<String> names = Lists.create(); for (int i = 0, j = serializableFields.length; i < j; i++) { names = Lists.add(names, serializableFields[i].getName()); } data.setFields(SerializationUtils.getRpcTypeName(t), names); } context.commitArtifact(logger, data); } } catch (NotFoundException e) { logger.log(TreeLogger.ERROR, "", e); throw new UnableToCompleteException(); } } return new RebindResult(RebindMode.USE_PARTIAL_CACHED, packageName + '.' + className); }
From source file:org.atmosphere.extensions.gwtwrapper.rebind.SerializerGenerator.java
License:Apache License
@Override public RebindResult generateIncrementally(TreeLogger logger, GeneratorContext context, String typeName) throws UnableToCompleteException { TypeOracle typeOracle = context.getTypeOracle(); // Create the CometSerializer impl String packageName = "comet"; String className = typeName.replace('.', '_') + "Impl"; PrintWriter printWriter = context.tryCreate(logger, packageName, className); if (printWriter != null) { try {/* w ww .j av a2 s. c om*/ JClassType type = typeOracle.getType(typeName); GwtSerialTypes annotation = type.getAnnotation(GwtSerialTypes.class); if (annotation == null) { logger.log(TreeLogger.ERROR, "No SerialTypes annotation on CometSerializer type: " + typeName); throw new UnableToCompleteException(); } SerializableTypeOracleBuilder typesSentToBrowserBuilder = new SerializableTypeOracleBuilder(logger, context.getPropertyOracle(), context); SerializableTypeOracleBuilder typesSentFromBrowserBuilder = new SerializableTypeOracleBuilder( logger, context.getPropertyOracle(), context); List<Class<?>> serializableTypes = new ArrayList(); Collections.addAll(serializableTypes, annotation.value()); for (Class<?> serializable : serializableTypes) { int rank = 0; if (serializable.isArray()) { while (serializable.isArray()) { serializable = (Class<?>) serializable.getComponentType(); rank++; } } JType resolvedType = typeOracle.getType(serializable.getCanonicalName()); while (rank > 0) { resolvedType = typeOracle.getArrayType(resolvedType); rank--; } typesSentToBrowserBuilder.addRootType(logger, resolvedType); typesSentFromBrowserBuilder.addRootType(logger, resolvedType); } // Create a resource file to receive all of the serialization information // computed by STOB and mark it as private so it does not end up in the // output. OutputStream pathInfo = context.tryCreateResource(logger, typeName + ".rpc.log"); PrintWriter writer = new PrintWriter(new OutputStreamWriter(pathInfo)); writer.write("====================================\n"); writer.write("Types potentially sent from server:\n"); writer.write("====================================\n\n"); writer.flush(); typesSentToBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentToBrowser = typesSentToBrowserBuilder.build(logger); writer.write("===================================\n"); writer.write("Types potentially sent from browser:\n"); writer.write("===================================\n\n"); writer.flush(); typesSentFromBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentFromBrowser = typesSentFromBrowserBuilder.build(logger); writer.close(); if (pathInfo != null) { context.commitResource(logger, pathInfo).setPrivate(true); } // Create the serializer final String modifiedTypeName = typeName.replace('.', '_'); TypeSerializerCreator tsc = new TypeSerializerCreator(logger, typesSentFromBrowser, typesSentToBrowser, context, "comet." + modifiedTypeName, modifiedTypeName); String realize = tsc.realize(logger); // Create the CometSerializer impl ClassSourceFileComposerFactory composerFactory = new ClassSourceFileComposerFactory(packageName, className); composerFactory.addImport(Serializer.class.getName()); composerFactory.addImport(SerializationException.class.getName()); composerFactory.addImport(Serializable.class.getName()); composerFactory.setSuperclass(typeName); // TODO is the SERIALIZER required for DE RPC? SourceWriter sourceWriter = composerFactory.createSourceWriter(context, printWriter); sourceWriter.print("private Serializer SERIALIZER = new " + realize + "();"); sourceWriter.print("protected Serializer getRPCSerializer() {return SERIALIZER;}"); sourceWriter.commit(logger); } catch (NotFoundException e) { logger.log(TreeLogger.ERROR, "", e); throw new UnableToCompleteException(); } } return new RebindResult(RebindMode.USE_ALL_NEW_WITH_NO_CACHING, packageName + '.' + className); }
From source file:org.atmosphere.gwt.rebind.SerializerGenerator.java
License:Apache License
@Override public RebindResult generateIncrementally(TreeLogger logger, GeneratorContextExt context, String typeName) throws UnableToCompleteException { TypeOracle typeOracle = context.getTypeOracle(); // Create the CometSerializer impl String packageName = "comet"; String className = typeName.replace('.', '_') + "Impl"; PrintWriter printWriter = context.tryCreate(logger, packageName, className); if (printWriter != null) { try {/*from w w w. j a va2s.c o m*/ JClassType type = typeOracle.getType(typeName); SerialTypes annotation = type.getAnnotation(SerialTypes.class); if (annotation == null) { logger.log(TreeLogger.ERROR, "No SerialTypes annotation on CometSerializer type: " + typeName); throw new UnableToCompleteException(); } SerializableTypeOracleBuilder typesSentToBrowserBuilder = new SerializableTypeOracleBuilder(logger, context.getPropertyOracle(), context); SerializableTypeOracleBuilder typesSentFromBrowserBuilder = new SerializableTypeOracleBuilder( logger, context.getPropertyOracle(), context); for (Class<? extends Serializable> serializable : annotation.value()) { int rank = 0; if (serializable.isArray()) { while (serializable.isArray()) { serializable = (Class<? extends Serializable>) serializable.getComponentType(); rank++; } } JType resolvedType = typeOracle.getType(serializable.getCanonicalName()); while (rank > 0) { resolvedType = typeOracle.getArrayType(resolvedType); rank--; } typesSentToBrowserBuilder.addRootType(logger, resolvedType); typesSentFromBrowserBuilder.addRootType(logger, resolvedType); } // Create a resource file to receive all of the serialization information // computed by STOB and mark it as private so it does not end up in the // output. OutputStream pathInfo = context.tryCreateResource(logger, typeName + ".rpc.log"); PrintWriter writer = new PrintWriter(new OutputStreamWriter(pathInfo)); writer.write("====================================\n"); writer.write("Types potentially sent from server:\n"); writer.write("====================================\n\n"); writer.flush(); typesSentToBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentToBrowser = typesSentToBrowserBuilder.build(logger); writer.write("===================================\n"); writer.write("Types potentially sent from browser:\n"); writer.write("===================================\n\n"); writer.flush(); typesSentFromBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentFromBrowser = typesSentFromBrowserBuilder.build(logger); writer.close(); if (pathInfo != null) { context.commitResource(logger, pathInfo).setPrivate(true); } // Create the serializer final String modifiedTypeName = typeName.replace('.', '_'); TypeSerializerCreator tsc = new TypeSerializerCreator(logger, typesSentFromBrowser, typesSentToBrowser, context, "comet." + modifiedTypeName, modifiedTypeName); String realize = tsc.realize(logger); // Create the CometSerializer impl ClassSourceFileComposerFactory composerFactory = new ClassSourceFileComposerFactory(packageName, className); composerFactory.addImport(Serializer.class.getName()); composerFactory.addImport(SerialMode.class.getName()); composerFactory.setSuperclass(typeName); // TODO is the SERIALIZER required for DE RPC? SourceWriter sourceWriter = composerFactory.createSourceWriter(context, printWriter); sourceWriter.print("private Serializer SERIALIZER = new " + realize + "();"); sourceWriter.print("protected Serializer getSerializer() {return SERIALIZER;}"); sourceWriter .print("public SerialMode getMode() {return SerialMode." + annotation.mode().name() + ";}"); sourceWriter.print("public SerialMode getPushMode() {return SerialMode." + annotation.pushmode().name() + ";}"); sourceWriter.commit(logger); if (annotation.mode() == SerialMode.DE_RPC) { RpcDataArtifact data = new RpcDataArtifact(type.getQualifiedSourceName()); for (JType t : typesSentToBrowser.getSerializableTypes()) { if (!(t instanceof JClassType)) { continue; } JField[] serializableFields = SerializationUtils .getSerializableFields(context.getTypeOracle(), (JClassType) t); List<String> names = Lists.create(); for (int i = 0, j = serializableFields.length; i < j; i++) { names = Lists.add(names, serializableFields[i].getName()); } data.setFields(SerializationUtils.getRpcTypeName(t), names); } context.commitArtifact(logger, data); } } catch (NotFoundException e) { logger.log(TreeLogger.ERROR, "", e); throw new UnableToCompleteException(); } } return new RebindResult(RebindStatus.USE_PARTIAL_CACHED, packageName + '.' + className); }
From source file:org.atmosphere.gwt20.rebind.SerializerGenerator.java
License:Apache License
@Override public RebindResult generateIncrementally(TreeLogger logger, GeneratorContext context, String typeName) throws UnableToCompleteException { TypeOracle typeOracle = context.getTypeOracle(); // Create the CometSerializer impl String packageName = "comet"; String className = typeName.replace('.', '_') + "Impl"; PrintWriter printWriter = context.tryCreate(logger, packageName, className); if (printWriter != null) { try {/*w ww . j a v a2 s .c o m*/ JClassType type = typeOracle.getType(typeName); GwtRpcSerialTypes annotation = type.getAnnotation(GwtRpcSerialTypes.class); if (annotation == null) { logger.log(TreeLogger.ERROR, "No SerialTypes annotation on CometSerializer type: " + typeName); throw new UnableToCompleteException(); } SerializableTypeOracleBuilder typesSentToBrowserBuilder = new SerializableTypeOracleBuilder(logger, context.getPropertyOracle(), context); SerializableTypeOracleBuilder typesSentFromBrowserBuilder = new SerializableTypeOracleBuilder( logger, context.getPropertyOracle(), context); List<Class<?>> serializableTypes = new ArrayList(); Collections.addAll(serializableTypes, annotation.value()); for (Class<?> serializable : serializableTypes) { int rank = 0; if (serializable.isArray()) { while (serializable.isArray()) { serializable = (Class<?>) serializable.getComponentType(); rank++; } } JType resolvedType = typeOracle.getType(serializable.getCanonicalName()); while (rank > 0) { resolvedType = typeOracle.getArrayType(resolvedType); rank--; } typesSentToBrowserBuilder.addRootType(logger, resolvedType); typesSentFromBrowserBuilder.addRootType(logger, resolvedType); } // Create a resource file to receive all of the serialization information // computed by STOB and mark it as private so it does not end up in the // output. OutputStream pathInfo = context.tryCreateResource(logger, typeName + ".rpc.log"); PrintWriter writer = new PrintWriter(new OutputStreamWriter(pathInfo)); writer.write("====================================\n"); writer.write("Types potentially sent from server:\n"); writer.write("====================================\n\n"); writer.flush(); typesSentToBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentToBrowser = typesSentToBrowserBuilder.build(logger); writer.write("===================================\n"); writer.write("Types potentially sent from browser:\n"); writer.write("===================================\n\n"); writer.flush(); typesSentFromBrowserBuilder.setLogOutputWriter(writer); SerializableTypeOracle typesSentFromBrowser = typesSentFromBrowserBuilder.build(logger); writer.close(); if (pathInfo != null) { context.commitResource(logger, pathInfo).setPrivate(true); } // Create the serializer final String modifiedTypeName = typeName.replace('.', '_'); TypeSerializerCreator tsc = new TypeSerializerCreator(logger, typesSentFromBrowser, typesSentToBrowser, context, "comet." + modifiedTypeName, modifiedTypeName); String realize = tsc.realize(logger); // Create the CometSerializer impl ClassSourceFileComposerFactory composerFactory = new ClassSourceFileComposerFactory(packageName, className); composerFactory.addImport(Serializer.class.getName()); composerFactory.addImport(SerializationException.class.getName()); composerFactory.addImport(Serializable.class.getName()); composerFactory.setSuperclass(typeName); SourceWriter sourceWriter = composerFactory.createSourceWriter(context, printWriter); sourceWriter.print("private Serializer SERIALIZER = new " + realize + "();"); sourceWriter.print("protected Serializer getRPCSerializer() {return SERIALIZER;}"); sourceWriter.commit(logger); } catch (NotFoundException e) { logger.log(TreeLogger.ERROR, "", e); throw new UnableToCompleteException(); } } return new RebindResult(RebindMode.USE_ALL_NEW_WITH_NO_CACHING, packageName + '.' + className); }
From source file:org.restlet.rebind.ClientProxyGenerator.java
License:LGPL
/** * Generates the code of the necessary object serializers. * //from w w w. j a v a 2 s.c o m * @throws UnableToCompleteException */ protected void generateSerializers() throws UnableToCompleteException { try { this.stob = new SerializableTypeOracleBuilder(getLogger(), getContext().getPropertyOracle(), getTypeOracle()); // Discover and add serializable types getStob().addRootType(getLogger(), getTypeOracle().getType(String.class.getName())); JMethod[] methods = getClassType().getOverridableMethods(); JClassType exceptionClass = getTypeOracle().getType(Exception.class.getName()); JType asyncType = getTypeOracle().getType(AsyncCallback.class.getName()); JType cbType = getTypeOracle().getType(Result.class.getName()); for (JMethod method : methods) { if (!"getClientResource".equals(method.getName())) { JType returnType = method.getReturnType(); if (returnType != JPrimitiveType.VOID) { getStob().addRootType(getLogger(), returnType); } JParameter[] parameters = method.getParameters(); for (JParameter parameter : parameters) { JType parameterType = parameter.getType(); JParameterizedType parameterizedType = parameterType.isParameterized(); if (parameterizedType == null) { // Non generic type. getStob().addRootType(getLogger(), parameterType); } else if (((parameterizedType.getBaseType() != asyncType) && (parameterizedType.getBaseType() != cbType))) { // Generic type but not a callback. getStob().addRootType(getLogger(), parameterType); } else { // Callback type, inspect the "inner" type. if (parameterizedType.getTypeArgs().length > 0) { JClassType t = parameterizedType.getTypeArgs()[0]; // Add the enclosed type if it is not equals to // java.lang.Void. if (t != null && !("Void".equals(t.getName()) && "java.lang".equals(t.getPackage().getName()))) { getStob().addRootType(getLogger(), t); } } } } JType[] exceptions = method.getThrows(); if (exceptions.length > 0) { for (JType exception : exceptions) { if (!exceptionClass.isAssignableFrom(exception.isClass())) { getLogger().log(Type.WARN, "Only checked exceptions are supported"); } getStob().addRootType(getLogger(), exception); } } } } // Log serialization information OutputStream los = getContext().tryCreateResource(getLogger(), getClassType().getQualifiedSourceName() + ".restlet.log"); getStob().setLogOutputStream(los); this.sto = getStob().build(getLogger()); if (los != null) { getContext().commitResource(getLogger(), los).setPrivate(true); } TypeSerializerCreator tsc = null; try { tsc = getTypeSerializerCreatorGwt1_7(); } catch (Exception e) { try { tsc = getTypeSerializerCreatorGwt2_0(); } catch (Exception e2) { getLogger().log(TreeLogger.ERROR, "", e2); throw new UnableToCompleteException(); } } if (tsc != null) { tsc.realize(getLogger()); } else { getLogger().log(TreeLogger.ERROR, "Cannot create a TypeSerializerCreator instance."); throw new UnableToCompleteException(); } } catch (NotFoundException e) { getLogger().log(TreeLogger.ERROR, "", e); throw new UnableToCompleteException(); } }