Ignore:
Timestamp:
Mar 26, 2014, 6:28:32 PM (10 years ago)
Author:
hock@…
Message:

WARNING! This revision is not intended for productive use!

!! DEBUGGING ONLY !!

Extreme debugging of StreamTransport.
"Typo" in the locking-code, was very hard to track down!

This revision is stored since a lot dabug code was written and should not just be deleted.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • source/ariba/utility/transport/StreamTransport/StreamTransport.cpp

    r12060 r12773  
    366366        parent(parent),
    367367        out_queues(8), //TODO How much priorities shall we have?
    368         sending(false)
     368        sending(false),
     369        MAGIC_NUMBER(424242)
    369370{
    370371        header.length = 0;
     
    594595    bool restart_sending = false;
    595596   
     597        // FIXME Mario DEBUGGING  --  copy !!
     598        reboost::shared_buffer_t buff = packet.linearize();
     599        reboost::message_t msg;
     600        msg.push_back(buff);
     601        assert ( msg.MAGIC_NUMBER == 421337 );
     602        // [ DEBUGGING ]
     603       
     604       
    596605    // enqueue packet  [locked]
    597606    {
    598         unique_lock(out_queues_lock);
    599        
    600         assert( priority < out_queues.size() );
    601         out_queues[priority].push(packet);
     607        boost::mutex::scoped_lock lock(out_queues_lock);
     608               
     609                int debuggingA = out_queues[priority].size();
     610//              assert ( debuggingA < 1000 ); // XXX
     611               
     612                assert ( this->valid );
     613       
     614        assert( priority < out_queues.size() );  // NOTE: actual assert, not in context with the extended debugging..
     615//         out_queues[priority].push(packet);  // FIXME Mario
     616                out_queues[priority].push(msg);            // FIXME Mario
     617               
     618                // XXX
     619                int debuggingB = out_queues[priority].size();
     620                int magic = out_queues[priority].back().MAGIC_NUMBER;
     621                assert ( debuggingB == debuggingA + 1 );
     622                assert ( magic == 421337 );
    602623       
    603624        if ( ! sending )
     
    622643    bool found = false;
    623644
     645        // XXX Mario: Debugging
     646        if ( ! this->valid )
     647        {
     648                this->sending = false;
     649                cout << "/// StreamConnection::send_next_package() on INVALID STREAM" << endl;
     650                return;
     651        }
     652       
    624653    // find packet with highest priority  [locked]
    625654    {
    626         unique_lock(out_queues_lock);
     655        boost::mutex::scoped_lock lock(out_queues_lock);
     656               
     657                assert ( this->valid ); // XXX TODO ggf. in if (valid) Àndern...
     658                assert ( this->sending );
     659                assert ( this->MAGIC_NUMBER == 424242 );
     660                assert ( this->out_queues.size() == 8 );
    627661       
    628662        for ( vector<OutQueue>::iterator it = out_queues.begin();
    629663                it != out_queues.end(); it++ )
    630664        {
     665                        int debugging = it->size();  // XXX debugging
     666//                      assert ( debugging < 1000 );
     667                       
    631668            if ( !it->empty() )
    632669            {
Note: See TracChangeset for help on using the changeset viewer.