Coverage Report

Created: 2026-04-12 06:23

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/logging-log4cxx/src/main/cpp/socketoutputstream.cpp
Line
Count
Source
1
/*
2
 * Licensed to the Apache Software Foundation (ASF) under one or more
3
 * contributor license agreements.  See the NOTICE file distributed with
4
 * this work for additional information regarding copyright ownership.
5
 * The ASF licenses this file to You under the Apache License, Version 2.0
6
 * (the "License"); you may not use this file except in compliance with
7
 * the License.  You may obtain a copy of the License at
8
 *
9
 *      http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 */
17
18
#include <log4cxx/logstring.h>
19
#include <log4cxx/helpers/socketoutputstream.h>
20
#include <log4cxx/helpers/socket.h>
21
#include <log4cxx/helpers/bytebuffer.h>
22
#include <log4cxx/helpers/exception.h>
23
24
#include <cstdio>
25
#include <cstring>
26
27
using namespace LOG4CXX_NS;
28
using namespace LOG4CXX_NS::helpers;
29
30
struct SocketOutputStream::SocketOutputStreamPrivate
31
{
32
  ByteList array;
33
  SocketPtr socket;
34
};
35
36
IMPLEMENT_LOG4CXX_OBJECT(SocketOutputStream)
37
38
SocketOutputStream::SocketOutputStream(const SocketPtr& socket1)
39
0
  : m_priv(std::make_unique<SocketOutputStreamPrivate>())
40
0
{
41
0
  m_priv->socket = socket1;
42
0
}
43
44
SocketOutputStream::~SocketOutputStream()
45
0
{
46
0
}
47
48
void SocketOutputStream::close(Pool& p)
49
0
{
50
0
  flush(p);
51
0
  m_priv->socket->close();
52
0
}
53
54
void SocketOutputStream::flush(Pool& /* p */)
55
0
{
56
0
  if (m_priv->array.size() > 0)
57
0
  {
58
0
    ByteBuffer buf((char*) &m_priv->array[0], m_priv->array.size());
59
0
    m_priv->socket->write(buf);
60
0
    m_priv->array.resize(0);
61
0
  }
62
0
}
63
64
void SocketOutputStream::write(ByteBuffer& buf, Pool& /* p */ )
65
0
{
66
0
  if (buf.remaining() > 0)
67
0
  {
68
0
    const size_t count = buf.remaining();
69
0
    const size_t sz = m_priv->array.size();
70
71
0
    if (count > m_priv->array.max_size() - sz)
72
0
    {
73
0
      throw IllegalArgumentException(LOG4CXX_STR("SocketOutputStream::write overflow"));
74
0
    }
75
76
0
    m_priv->array.resize(sz + count);
77
0
    memcpy(&m_priv->array[sz], buf.current(), count);
78
0
    buf.increment_position(count);
79
0
  }
80
0
}
81
82