]> git.llucax.com Git - z.facultad/75.42/plaqui.git/commitdiff
- Se corrige la bomba para que tenga mas informacion sobre el flujo maximo y
authorRicardo Markiewicz <gazer.arg@gmail.com>
Thu, 23 Oct 2003 19:57:22 +0000 (19:57 +0000)
committerRicardo Markiewicz <gazer.arg@gmail.com>
Thu, 23 Oct 2003 19:57:22 +0000 (19:57 +0000)
 actual.
 - El ejemplo es completamente funcional y si se cambia algun valor los flujos
 siguen dando bien actualizados :-)
 - Se pone al dia el diagrama de clases

Constructor/constructor.cpp
Model/include/source.h
Model/src/bomb.cpp
Model/src/main.cpp
docs/clases.dia

index 449e7c35c581de574bb88f0e4713391881a5144b..98f6ab9ad5d1b5ce03734e143796559c02db7c57 100644 (file)
@@ -82,12 +82,7 @@ void Constructor::on_item_drag_begin(const Glib::RefPtr<Gdk::DragContext>& conte
 
 void Constructor::on_item_drag_data_get(const Glib::RefPtr<Gdk::DragContext>& context, GtkSelectionData* selection_data, guint info, guint time)
 {      
-       if ( strcmp((const char *)selection_data->data,"item_codo.png")==0)
-               gtk_selection_data_set (selection_data, selection_data->target, 10, (const guchar*)"item_codo.png", 13);
-       if ( strcmp((const char *)selection_data->data,"item_canio.png")==0)
-               gtk_selection_data_set (selection_data, selection_data->target, 10, (const guchar*)"item_canio.png", 14);
-       if ( strcmp((const char *)selection_data->data,"item_y.png")==0)
-               gtk_selection_data_set (selection_data, selection_data->target, 10, (const guchar*)"item_y.png", 10);
+       gtk_selection_data_set (selection_data, selection_data->target, 10, (const guchar*)"item_codo.png", 13);
 }
 
 void Constructor::on_item_drop_drag_received(const Glib::RefPtr<Gdk::DragContext>& context, int x, int y, GtkSelectionData* selection_data, guint info, guint time)
index 48a9a12ce3ed436c0f98179d4628d812d73a2c71..41a7266c85a1db6dad679c4185fff3a9a7d7a078 100644 (file)
@@ -17,8 +17,12 @@ public:
        virtual bool get_output();
 
        virtual void simulate();
+       float get_actual_flow() { return actual_flow; }
+       float get_max_flow() { return max_flow; }
+       void  set_max_flow(float _f) { max_flow = _f; }
 protected:
        float max_flow;
+       float actual_flow;
 private:
        Source(const Source &):Control("null") {}
        Source &operator = (const Source &) { return *this; }
index 9bae0a50c3c893922a99e9e1e9f8f064cd6db134..b9159a66706a8e4a1963a996236199b692d2d649 100644 (file)
@@ -10,7 +10,7 @@ Bomb::Bomb(const std::string &_name):Source(_name)
        out_slots = 1;
        active = true;
        open = true;
-       max_flow = 1;
+       max_flow = actual_flow = 0.0f;
 }
 
 Bomb::~Bomb()
@@ -20,13 +20,15 @@ Bomb::~Bomb()
 void Bomb::update()
 {
        if (updated) return;
+       actual_flow = 99999;
        updated = true;
        send_msg(OUT, MSG_QUERY_MAX_FLOW);
 }
 
 void Bomb::simulate()
 {
-       std::cout << name << "::Flujo entregado = " << (active && open)?max_flow:0;
+       std::cout << name << "::Flujo actual = " << ((active && open)?actual_flow:0) \
+       << " de " << max_flow;
        std::cout << ((active && open)?" (funcionando)":" (apagada)") << std::endl;
 }
 
@@ -46,12 +48,18 @@ void Bomb::recieve_msg(int msg, IConector *who, void *data)
                        // Me preguntan por el flujo máximo.
                        // Primero me actualizo, y luego respondo
                        update();
-                       float tmp = (active && open)?max_flow:0;
+                       float tmp;
+                       if (active && open) {
+                               tmp = (actual_flow<max_flow)?actual_flow:max_flow;
+                       } else {
+                               tmp = 0.0f;
+                       }
                        who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
                }
                break;
                case MSG_RESPONSE_MAX_FLOW: {
-                       max_flow = *((float *)data);
+                       float tmp = *((float *)data);
+                       if (tmp < actual_flow) actual_flow = tmp;
                }
                break;
                default:
index 2b4e5a9766095f15e5da6074486e1ee6fef0a058..237e158770bf98af83eee5e10622be36ab783714 100644 (file)
@@ -15,6 +15,7 @@ int main(int argc, char *argv[])
        Conduct *canio2;
 
        bomba = new Bomb("bomba");
+       bomba->set_max_flow(3);
        canio1 = new Conduct("cond_1");
        canio1->set_max_flow(10);
        canio2 = new Conduct("cond_2");
index d05f6f79ecfad75ad405dce018d60732b65a1b6c..8ac71763db207fed6ed11b5b777c56787d4f9715 100644 (file)
Binary files a/docs/clases.dia and b/docs/clases.dia differ