@Override public final String toString() { return descriptor.method().getName(); }
/** * Return method detail descriptor of the requested method. Returns {@code null} if not found. * * @param aMethod Method to look up. This argument must not be {@code null}. * @return method detail descriptor of the requested method. * @since 0.5 */ public final CompositeMethodDetailDescriptor getMethodDescriptor( Method aMethod ) { for( CompositeMethodDetailDescriptor descriptor : methods ) { MethodDescriptor methodDescriptor = descriptor.descriptor(); Method method = methodDescriptor.method(); if( method.equals( aMethod ) ) { return descriptor; } } return null; }
/** * Do the filter for method return type (Property, Association, ManyAssociation, NamedAssociation) * by removing the entry from the list if not the above. * * @param list list of CompositeMethodDetailDescriptor */ private void doFilter( List<CompositeMethodDetailDescriptor> list ) { if( list.isEmpty() ) { return; } Iterator<CompositeMethodDetailDescriptor> iter = list.iterator(); while( iter.hasNext() ) { CompositeMethodDetailDescriptor descriptor = iter.next(); Method method = descriptor.descriptor().method(); if( Property.class.isAssignableFrom( method.getReturnType() ) || Association.class.isAssignableFrom( method.getReturnType() ) || ManyAssociation.class.isAssignableFrom( method.getReturnType() ) || NamedAssociation.class.isAssignableFrom( method.getReturnType() ) ) { continue; } iter.remove(); } } }
Method method = descriptor.descriptor().method(); if( Property.class.isAssignableFrom( method.getReturnType() ) )
private List<CompositeMethodDetailDescriptor> findState( Iterable<CompositeMethodDetailDescriptor> iter ) { List<CompositeMethodDetailDescriptor> publicList = new ArrayList<>(); List<CompositeMethodDetailDescriptor> privateList = new ArrayList<>(); for( CompositeMethodDetailDescriptor descriptor : iter ) { Class<?> compositeClass = descriptor.composite().descriptor().types().findFirst().orElse( null ); Class<?> mixinMethodClass = descriptor.descriptor().method().getDeclaringClass(); if( mixinMethodClass.isAssignableFrom( compositeClass ) ) { publicList.add( descriptor ); } else { privateList.add( descriptor ); } } // combine into one list, with public listed first then private publicList.addAll( privateList ); // filter Property, Association, ManyAssociation and NamedAssociation doFilter( publicList ); return publicList; }
public JsonObjectBuilder toJson() { JsonObjectBuilder builder = Json.createObjectBuilder(); builder.add( "name", descriptor().method().getName() ); builder.add( "type", descriptor().method().getReturnType().getName() ); { JsonArrayBuilder paramsBuilder = Json.createArrayBuilder(); Arrays.stream( descriptor().method().getParameters() ) .map( Parameter::toString ) .forEach( paramsBuilder::add ); // .forEach( param -> paramsBuilder.add( param.getName() + " : " + param.getType() ) ); builder.add( "parameters", paramsBuilder ); } builder.add( "constraints", constraints().toJson() ); builder.add( "concerns", concerns().toJson() ); builder.add( "sideeffects", sideEffects().toJson() ); return builder; } }
Class<?> mixinMethodClass = descriptor.descriptor().method().getDeclaringClass(); compositeDescriptor.types().forEach( mixinType ->
Node node = document.createElement( "method" ); addAttribute( "name", descriptor.method().getName(), node );
String compositeMethodUri = context.createCompositeMethodUri( compositeUri, compositeMethodDescriptor.method() ); context.addType( compositeMethodUri, PolygeneRdf.TYPE_METHOD ); context.addRelationship( compositeUri, PolygeneRdf.RELATIONSHIP_METHOD, compositeMethodUri );