Package com.dooapp.gaedo.finders

Examples of com.dooapp.gaedo.finders.FieldInformer


  public String consumeFilter(String methodString, String consumableText, Map<String, String> fieldNames,DynamicFinderMethodResolver created) {
    boolean found = false;
    for(Map.Entry<String, String> fieldEntry: fieldNames.entrySet()) {
      if(consumableText.startsWith(fieldEntry.getKey())) {
        consumableText = consumableText.substring(fieldEntry.getKey().length());
        FieldInformer informer = backEnd.getInformer().get(fieldEntry.getValue());
        Map<String, Method> queries = Utils.getUppercasedMap(informer.getClass().getMethods());
        found = false;
        for(Map.Entry<String, Method> methodEntry : queries.entrySet()) {
          if(consumableText.startsWith(methodEntry.getKey())) {
            consumableText = consumableText.substring(methodEntry.getKey().length());
            created.addQueryExpression(informer, methodEntry.getValue());
View Full Code Here


   * @return a {@link FieldInformer} or an exception
   * @see #internalGet(String)
   */
  @Override
  public FieldInformer get(String string, Collection<Property> propertyPath) {
    FieldInformer returned = internalGet(string);
    if(returned instanceof FieldInformerAPI) {
      returned = ((FieldInformerAPI) returned).with(new LinkedList<Property>(propertyPath));
    }
    return returned;
  }
View Full Code Here

      this.field = field;
    }

    @Override
    public FieldInformer get(String string, Collection<Property> propertyPath) {
      FieldInformer returned = ReflectionBackedInformer.this.get(string);
      if(returned instanceof FieldInformerAPI) {
        // Improve path with this informer one
        Collection<Property> newPath = new LinkedList<Property>(propertyPath);
        newPath.add(field);
        returned = ((FieldInformerAPI) returned).with(newPath);
View Full Code Here

   * @return a {@link FieldInformer} if possible, an
   *         {@link UnsupportedOperationException} is fired elsewhere (this
   *         way, we will think about handling it later ;-)
   */
  public FieldInformer getInformerFor(Property field) {
    FieldInformer returned = fieldLocator.getInformerFor(field);
    return returned;
  }
View Full Code Here

   * @return a {@link FieldInformer} or an exception
   * @see #internalGet(String)
   */
  @Override
  public FieldInformer get(String string, Collection<Property> propertyPath) {
    FieldInformer returned = internalGet(string);
    if(returned instanceof FieldInformerAPI) {
      returned = ((FieldInformerAPI) returned).with(new LinkedList<Property>(propertyPath));
    }
    return returned;
  }
View Full Code Here

      this.field = field;
    }

    @Override
    public FieldInformer get(String string, Collection<Property> propertyPath) {
      FieldInformer returned = ReflectionBackedInformer.this.get(string);
      if(returned instanceof FieldInformerAPI) {
        // Improve path with this informer one
        Collection<Property> newPath = new LinkedList<Property>(propertyPath);
        newPath.add(field);
        returned = ((FieldInformerAPI) returned).with(newPath);
View Full Code Here

   * @return a method resolving call to an informer
   */
  private MethodResolver createSubInformerResolvers(Method method) {
    // First thing to check is method startup
    String methodName = method.getName();
    FieldInformer returned = methodNameToFieldInformer(method, realInformer);
    Class<?> returnType = method.getReturnType();
    if (!returnType.isAssignableFrom(returned.getClass())) {
      throw new ReturnTypeMismatchException(method,
          returned.getClass(), returnType);
    }
    return new SubInformerMethodResolver(returned, realInformer);
  }
View Full Code Here

    return locators.add(e);
  }

  @Override
  public FieldInformer getInformerFor(Property field) {
    FieldInformer returned = null;
    Map<FieldInformerLocator, Exception> thrownDuringSearch = new LinkedHashMap<FieldInformerLocator, Exception>();
    for (FieldInformerLocator locator : locators) {
      try {
        returned = locator.getInformerFor(field);
        if (returned != null) {
View Full Code Here

      FieldInformer fieldInformer, Map<String, Object> value) {
    for(Map.Entry<String, Object> entry : value.entrySet()) {
      if(fieldInformer instanceof Informer) {
        Informer beanInformer = (Informer) fieldInformer;
        try {
          FieldInformer usedInformer = beanInformer.get(entry.getKey());
          parent.add(usedInformer, SortingExpression.Direction.valueOf(entry.getValue().toString()));
        } catch(Exception e) {
          logger.log(Level.FINE, "unable to create a sorting expression from field name "+entry.getKey()+" in class "+beanInformer.toString(), e);
        }
      }
View Full Code Here

    } else {
      for(Map.Entry<String, Object> entry : value.entrySet()) {
        if(fieldInformer instanceof Informer) {
          Informer beanInformer = (Informer) fieldInformer;
          try {
            FieldInformer usedInformer = beanInformer.get(entry.getKey());
            buildQueryExpression(parent, usedInformer, (Map<String, Object>) entry.getValue());
          } catch(Exception e) {
            logger.log(Level.FINE, "unable to build query statement from field \""+entry.getKey()+"\"", e);
          }
        } else {
View Full Code Here

TOP

Related Classes of com.dooapp.gaedo.finders.FieldInformer

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.