Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/flbulgarelli/tadp-meta-builder
Proof of concept of a MetaBuilder
https://github.com/flbulgarelli/tadp-meta-builder
Last synced: 17 days ago
JSON representation
Proof of concept of a MetaBuilder
- Host: GitHub
- URL: https://github.com/flbulgarelli/tadp-meta-builder
- Owner: flbulgarelli
- Created: 2012-02-15T19:51:38.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2012-06-20T15:38:46.000Z (over 12 years ago)
- Last Synced: 2024-10-17T14:28:11.490Z (29 days ago)
- Language: Groovy
- Homepage:
- Size: 131 KB
- Stars: 1
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Problema
Cansados de escribir una y otra vez builders a mano, queremos construir un MetaBuilder: un builder de builders,
el cual nos permita especificar, empleando un DSL simple, al menos los siguientes aspectos de un builder genérico:* Cuales son las propiedades que se pueden configurar: un builder genérico no
configurará a discreción cualquier propiedad, sino solamente un subconjunto que le indiquemos
* Cuales propiedades son opcionales, cual es y su valor por defecto
* Validaciones que se puedan realizar sobre las propiedades, y sobre el objeto antes y después de ser construido
* La estrategia de construcción del objeto (se le puede pasar la clase o un bloque de código que se comporte como factory method)
* La estrategia de inyección de las propiedades (si es por constructor/argumento del bloque o si es por setter)
* Propiedades que son colecciones, para las que se expongan métodos estilo addXXX
* Propiedades cuyo valor este fijo# Caso de uso:
Un metabuilder nos permitirá construir clases de builders genéricos, que harán las veces de fábrica de builders genéricos similares. Es decir,
el caso de uso típico será:1. Se instanciará un metabuilder y se lo configurará
2. El metabuilder construirá una clase de builder genérico con la configuración dada
3. Se instanciará la clase de builder genérico, lo que devolverá un builder genérico, y se lo configurará
4. El builder genérico construirá el objeto deseado con la configuración dad# Que hay aquí
En este proyecto contiene pruebas de concepto de 4 estilos diferentes de DSLs, desde mas sencillos hasta más complejos:
* Estilo mensajes encadenados (ChainedStyle): nada raro, lo mismo que se podría lograr en Java Ej:
```groovy
receptor.mensaje1(valor1, valor2).mensaje2(valor3, valor4)
```* Estilo de bloque y métodos con paremtros nombrados (BlockStyle). Se logra tomando mapas como argumentos. Ej:
```groovy
receptor.hacer {
mensaje1 etiqueta1: valor1, etiqueta2: valor2
mensaje2 etiqueta1: valor3, etiqueta2: valor4
}
```* Estilo de bloques anidados (NestedStyle): se logra haciendo uso de methodMissing y métodos que toman bloques por parámetros, a los que se les cambia el delegate Ej:
```groovy
receptor.hacer {
bloque1 {
bloque2(valor1)
bloque3(valor2) {
bloqueN {
}
}
}
}
```* Estilo tabular (TabularStyle): Se logra poniendo en el contexto del bloque objetos que entiendan el mensaje or, los cuales consituirán siempre la primera columna de la tabla. Es necesario redefinir getProperty, para descubrir el orden en que son colocados los títulos de la tabla. Ej:
```groovy
receptor.hacer {
'--------+---------+---------'
titlo1 | titulo2 | titulo3
'--------+---------+---------'
valor1 | valor2 | valor3
valor4 | valor5 | valor6
'--------+---------+---------'
}
```# Estado de desarrollo
Por ahora solo están implementados los estilos Chained, Nested y Tabular, de forma parcial