Coverage Report

Created: 2025-08-24 06:21

/src/logging-log4cxx/src/main/cpp/fileoutputstream.cpp
Line
Count
Source (jump to first uncovered line)
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/fileoutputstream.h>
20
#include <log4cxx/helpers/pool.h>
21
#include <log4cxx/helpers/exception.h>
22
#include <log4cxx/helpers/bytebuffer.h>
23
#include <apr_file_io.h>
24
25
using namespace LOG4CXX_NS;
26
using namespace LOG4CXX_NS::helpers;
27
28
struct FileOutputStream::FileOutputStreamPrivate
29
{
30
3.25k
  FileOutputStreamPrivate() : fileptr(nullptr) {}
31
32
  Pool pool;
33
  apr_file_t* fileptr;
34
};
35
36
IMPLEMENT_LOG4CXX_OBJECT(FileOutputStream)
37
38
FileOutputStream::FileOutputStream(const LogString& filename,
39
3.25k
  bool append) : m_priv(std::make_unique<FileOutputStreamPrivate>())
40
3.25k
{
41
3.25k
  m_priv->fileptr = open(filename, append, m_priv->pool);
42
3.25k
}
log4cxx::helpers::FileOutputStream::FileOutputStream(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, bool)
Line
Count
Source
39
1.00k
  bool append) : m_priv(std::make_unique<FileOutputStreamPrivate>())
40
1.00k
{
41
1.00k
  m_priv->fileptr = open(filename, append, m_priv->pool);
42
1.00k
}
log4cxx::helpers::FileOutputStream::FileOutputStream(std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> > const&, bool)
Line
Count
Source
39
2.25k
  bool append) : m_priv(std::make_unique<FileOutputStreamPrivate>())
40
2.25k
{
41
2.25k
  m_priv->fileptr = open(filename, append, m_priv->pool);
42
2.25k
}
43
44
FileOutputStream::FileOutputStream(const logchar* filename,
45
0
  bool append) : m_priv(std::make_unique<FileOutputStreamPrivate>())
46
0
{
47
0
  m_priv->fileptr = open(filename, append, m_priv->pool);
48
0
}
Unexecuted instantiation: log4cxx::helpers::FileOutputStream::FileOutputStream(char const*, bool)
Unexecuted instantiation: log4cxx::helpers::FileOutputStream::FileOutputStream(wchar_t const*, bool)
49
50
apr_file_t* FileOutputStream::open(const LogString& filename,
51
  bool append, Pool& pool)
52
3.25k
{
53
3.25k
  apr_fileperms_t perm = APR_OS_DEFAULT;
54
3.25k
  apr_int32_t flags = APR_WRITE | APR_CREATE;
55
56
3.25k
  if (append)
57
1.25k
  {
58
1.25k
    flags |= APR_APPEND;
59
1.25k
  }
60
2.00k
  else
61
2.00k
  {
62
2.00k
    flags |= APR_TRUNCATE;
63
2.00k
  }
64
65
3.25k
  File fn;
66
3.25k
  fn.setPath(filename);
67
3.25k
  apr_file_t* fileptr = 0;
68
3.25k
  apr_status_t stat = fn.open(&fileptr, flags, perm, pool);
69
70
3.25k
  if (stat != APR_SUCCESS)
71
0
  {
72
0
    throw IOException(filename, stat);
73
0
  }
74
75
3.25k
  return fileptr;
76
3.25k
}
log4cxx::helpers::FileOutputStream::open(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, bool, log4cxx::helpers::Pool&)
Line
Count
Source
52
1.00k
{
53
1.00k
  apr_fileperms_t perm = APR_OS_DEFAULT;
54
1.00k
  apr_int32_t flags = APR_WRITE | APR_CREATE;
55
56
1.00k
  if (append)
57
417
  {
58
417
    flags |= APR_APPEND;
59
417
  }
60
586
  else
61
586
  {
62
586
    flags |= APR_TRUNCATE;
63
586
  }
64
65
1.00k
  File fn;
66
1.00k
  fn.setPath(filename);
67
1.00k
  apr_file_t* fileptr = 0;
68
1.00k
  apr_status_t stat = fn.open(&fileptr, flags, perm, pool);
69
70
1.00k
  if (stat != APR_SUCCESS)
71
0
  {
72
0
    throw IOException(filename, stat);
73
0
  }
74
75
1.00k
  return fileptr;
76
1.00k
}
log4cxx::helpers::FileOutputStream::open(std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> > const&, bool, log4cxx::helpers::Pool&)
Line
Count
Source
52
2.25k
{
53
2.25k
  apr_fileperms_t perm = APR_OS_DEFAULT;
54
2.25k
  apr_int32_t flags = APR_WRITE | APR_CREATE;
55
56
2.25k
  if (append)
57
835
  {
58
835
    flags |= APR_APPEND;
59
835
  }
60
1.41k
  else
61
1.41k
  {
62
1.41k
    flags |= APR_TRUNCATE;
63
1.41k
  }
64
65
2.25k
  File fn;
66
2.25k
  fn.setPath(filename);
67
2.25k
  apr_file_t* fileptr = 0;
68
2.25k
  apr_status_t stat = fn.open(&fileptr, flags, perm, pool);
69
70
2.25k
  if (stat != APR_SUCCESS)
71
0
  {
72
0
    throw IOException(filename, stat);
73
0
  }
74
75
2.25k
  return fileptr;
76
2.25k
}
77
78
FileOutputStream::~FileOutputStream()
79
3.25k
{
80
3.25k
  if (m_priv->fileptr)
81
0
  {
82
0
    apr_file_close(m_priv->fileptr);
83
0
  }
84
3.25k
}
85
86
void FileOutputStream::close(Pool& /* p */)
87
3.25k
{
88
3.25k
  if (m_priv->fileptr)
89
3.25k
  {
90
3.25k
    apr_status_t stat = apr_file_close(m_priv->fileptr);
91
92
3.25k
    if (stat != APR_SUCCESS)
93
0
    {
94
0
      throw IOException(stat);
95
0
    }
96
97
3.25k
    m_priv->fileptr = NULL;
98
3.25k
  }
99
3.25k
}
100
101
void FileOutputStream::flush(Pool& /* p */)
102
16.2k
{
103
16.2k
}
104
105
void FileOutputStream::write(ByteBuffer& buf, Pool& /* p */ )
106
93.1k
{
107
93.1k
  if (m_priv->fileptr == NULL)
108
0
  {
109
0
    throw NullPointerException(LOG4CXX_STR("FileOutputStream"));
110
0
  }
111
112
93.1k
  size_t nbytes = buf.remaining();
113
93.1k
  size_t pos = buf.position();
114
93.1k
  const char* data = buf.data();
115
116
175k
  while (nbytes > 0)
117
81.9k
  {
118
81.9k
    apr_status_t stat = apr_file_write(
119
81.9k
        m_priv->fileptr, data + pos, &nbytes);
120
121
81.9k
    if (stat != APR_SUCCESS)
122
0
    {
123
0
      throw IOException(stat);
124
0
    }
125
126
81.9k
    pos += nbytes;
127
81.9k
    buf.position(pos);
128
81.9k
    nbytes = buf.remaining();
129
81.9k
  }
130
93.1k
}
131
132
0
apr_file_t* FileOutputStream::getFilePtr() const{
133
0
  return m_priv->fileptr;
134
0
}
135