Cooperator framework

19/06/2006 - 18:25 por Daniel A. Calvin | Informe spam
Amigos, les cuento que hace unos meses empezamos a trabajar con un grupo de
amigos en un proyecto para crear un framework que saque provecho de las
ventajas de .Net 2.0
La idea original fue de Eugenio Serrano y me invito a trabajar junto a el y
otros amigos.
El proyecto es un framewok de desarrollo, seguramente estarán pensando: otro
más :-)
Nos decidimos a hacer este nuevo con la idea principal de que sea bien facil
de usar y de acercar los objetos a mas gente de una forma facil.

Hemos trabajado con mucha energía estos últimos meses y hemos logrado armar
algo muy interesante según nuestra opinion.

Los objetivos que nos planteamos fueron:

- 100% Orientado a objetos
- Aplanar la curva de aprendizaje y facilitar el camino de quienes aún están
condicionados por el modelo relacional.
- No usar datasets
- No usamos reflection.
- Modelo totalmente tipado, esto significa que las clases de persistencia y
recuperacion de objetos devuelven un tipo especifico y no un tipo object.
- Debido a la potencia de VS2005 se pueden bindear estos objetos a los
controles sin escribir una linea de codigo, y aporvechar las venjas de
edicion de VS2005
- No depende de la estructura relacional, soporta cualquier tipo de
estructura de base de datos.
- No hay que modificar la Primary Key o crear un campo unique en las tablas.
- Usa stored procedures.
- Soporta concurrencia
- Las condiciones de busqueda se expresan mediante objetos específicos
tipados y extendibles por el programador que terminan ejecutando un Stored
Procedure en forma transparente.
- En la capa de negocio todo se expresa en términos del dominio, incluido
los filtros y busquedas.
- Genera código en base a scripts escritos en el lenguaje que prefiera el
programador. Por defecto estan en c#, pero puedo escribir un script en c#,
para generar código SQL, o puedo escribir un script en vb.net para generar
código c#.
- Hay un modelo propuesto de las clases que se generaran que se basa en el
modelo de datos, pero el programador, antes de generar las clases edita
dicho modelo en una herramienta muy facil de usar y define como sera el
modelo que desea crear.
- Si las opciones de modelado que provee la herramienta no alcanzan, el
programador puede editar los templates y generar su propio modelo.
- La herramienta de generacion, genera 2 archivos por cada clase usando
clases parciales pensado para que el programador solo modifique una de las
2.
Si mas tarde se agrega un nuevo campo a una tabla, se puede volver a generar
el otro archivo de manera de no "pisar" cualquier codigo que el programador
ya haya escrito en esa clase.
- Soporta transacciones desconectadas.
- Licencia tipo open source, aún no hemos optado por cual, pero será de
código abierto.

Todo esto lo logramos de forma poco invasiva, implementando interfaces y
valiendonos de las nuevas características del net framework 2.0, sobre todo
Generics y clases parciales.

El framework será publicado en un término no mayor a 60 días.

Nos gustaría mucho contar con algún retorno por parte de la comunidad,
principalmente que cosas les molesta de otras herraminetas de este tipo,
incluso que les gustaría tener y aún no han encontrado en otros frameworks.

Desde ya muchas gracias

Daniel Calvin

Preguntas similare

Leer las respuestas

#26 Vyacheslav Popov
20/06/2006 - 20:17 | Informe spam
Daniel, perdona por el mal entendido, pero sigo sin comprender, que es lo
que hace Cooperator.

¿Te importa poner un ejemplo?

Saludos.

"Daniel A. Calvin" escribió en el
mensaje news:
Mostrar la cita
#27 Vyacheslav Popov
20/06/2006 - 20:24 | Informe spam
Entonces, si no se utiliza reflection habrá que crear, como mínimo, para
cada una de las clases de dominio los métodos CRUD en la fachada de
persistencia, crear un adaptador correspondiente y pasarle el control.

Si es así, con un poco de reflection se podría ahorrar muchas líneas de
código. ¿no?

Saludos.

"Daniel A. Calvin" escribió en el
mensaje news:
Mostrar la cita
#28 Daniel A. Calvin
20/06/2006 - 20:25 | Informe spam
Hola Alfredo

No hemos inventado nada, la rueda cuadrada a la que haces referencia tiene
muchos años de aplicación.

Si lees Proceso Unificado, los Patrones del GoF y algunas otras cosas, la
mayoría muy bien documentadas y formalizadas en la decada del 90'.

Vas a ver que esta rueda cuadrada existe y se usa en lugares donde la rueda
redonda no permitía implementar soluciones escalables, mantenibles, etc, etc.

De todas formas la intención no es polemizar.

Cooperator no inventa este tipo de prácticas, simplemente es una herramienta
para que, quien quiere adoptar ese estilo o arquitectura, lo pueda hacer con
un poco de facilidad.

Saludos

Daniel A. Calvin
MCP


"Alfredo Novoa" escribió:

Mostrar la cita
#29 Daniel A. Calvin
20/06/2006 - 20:26 | Informe spam
Hola Diego

Por ahora no hemos hecho nada al respecto, tal vez si hay gente que quiera
aportar su experiencia podamos encarar algo en el futuro.

Gracias
Daniel A. Calvin
MCP


"Diego (DCD)" escribió:

Mostrar la cita
#30 Daniel A. Calvin
20/06/2006 - 20:31 | Informe spam
Vyacheslav Popov

Mostrar la cita
Esto lo decide el desarrollador.

Mostrar la cita
No nos parecio una situación muy común. Será una característica para tener
en cuenta, aunque no creo que la implementemos.

Gracias


Daniel A. Calvin
MCP


"Vyacheslav Popov" escribió:

Mostrar la cita
Ads by Google
Search Busqueda sugerida