//Nombre: Fulanito de tal //Usuario: 1 //Estado: En Proceso //Reflection-----> Ingenieria Inversa de Objetos... se ve como estan construidos public Tarea Modificar(Dictionary <String, String> camposAModificar, KeyValuePair <String, String> condicion) { String identificador = condicion.Key; String valorIdentificador = condicion.Value; Tarea _tarea = new Tarea(); Type _tipo = _tarea.GetType(); PropertyInfo[] _propiedadesTarea = _tipo.GetProperties(); List <ModeloBase> _listaTareas = (_tarea).Listar(); if (_listaTareas != null) { foreach (Tarea _tareaL in _listaTareas) { PropertyInfo _propiedadIdentificador = _tareaL.GetType().GetProperty(identificador); if (_propiedadIdentificador.GetValue(_tareaL).Equals(valorIdentificador)) { foreach (KeyValuePair <String, String> _campoPar in camposAModificar) { foreach (PropertyInfo _propiedad in _propiedadesTarea) { if (_propiedad.Name.Equals(_campoPar.Key)) { _propiedad.SetValue(_tareaL, _campoPar.Value); } } } return(_tareaL); } } } return(null); }
private bool Exec(CmdSeleccionar c) { bool r = false; DataTable dt; this.ComandoComienza(c, string.Empty, SyncroStep.NotSyncro); if (((ActiveTask.GetType() == typeof(PreSincro)) && !_omitPreSincro) || ((ActiveTask.GetType() == typeof(PostSincro)) && !_omitPostSincro)) { switch (_responseCmdSeleccionar) { case (CmdResponse.Data): dt = c.ObtenerDatos(); if (dt.TableName == "Excepcion") { this.ComandoInforma((string)dt.Rows[0]["Mensaje"]); } else { this.ComandoObtieneDatos(dt); } r = true; break; case (CmdResponse.Count): dt = c.ObtenerDatos(); string msg = string.Empty; if (dt.TableName == "Excepcion") { msg = (string)dt.Rows[0]["Mensaje"]; } else { msg = string.Format("Nº de registros recuperados: {0}", dt.Rows.Count.ToString()); } this.ComandoInforma(msg); r = true; break; } } return(r); }