v1_encoder.cpp 2.05 KB
Newer Older
1
/*
2
    Copyright (c) 2007-2014 Contributors as noted in the AUTHORS file
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19

    This file is part of 0MQ.

    0MQ is free software; you can redistribute it and/or modify it under
    the terms of the GNU Lesser General Public License as published by
    the Free Software Foundation; either version 3 of the License, or
    (at your option) any later version.

    0MQ is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

20
#include "encoder.hpp"
21 22 23 24
#include "v1_encoder.hpp"
#include "likely.hpp"
#include "wire.hpp"

25
zmq::v1_encoder_t::v1_encoder_t (size_t bufsize_) :
26
    encoder_base_t <v1_encoder_t> (bufsize_)
27 28 29 30 31 32 33 34 35
{
    //  Write 0 bytes to the batch and go to message_ready state.
    next_step (NULL, 0, &v1_encoder_t::message_ready, true);
}

zmq::v1_encoder_t::~v1_encoder_t ()
{
}

36
void zmq::v1_encoder_t::size_ready ()
37 38
{
    //  Write message body into the buffer.
39 40
    next_step (in_progress->data (), in_progress->size (),
        &v1_encoder_t::message_ready, true);
41 42
}

43
void zmq::v1_encoder_t::message_ready ()
44
{
45
    //  Get the message size.
46
    size_t size = in_progress->size ();
47

48 49 50 51 52 53 54 55
    //  Account for the 'flags' byte.
    size++;

    //  For messages less than 255 bytes long, write one byte of message size.
    //  For longer messages write 0xff escape character followed by 8-byte
    //  message size. In both cases 'flags' field follows.
    if (size < 255) {
        tmpbuf [0] = (unsigned char) size;
56
        tmpbuf [1] = (in_progress->flags () & msg_t::more);
57
        next_step (tmpbuf, 2, &v1_encoder_t::size_ready, false);
58 59
    }
    else {
60 61
        tmpbuf [0] = 0xff;
        put_uint64 (tmpbuf + 1, size);
62
        tmpbuf [9] = (in_progress->flags () & msg_t::more);
63
        next_step (tmpbuf, 10, &v1_encoder_t::size_ready, false);
64 65
    }
}