bump product version to 4.1.6.2
[LibreOffice.git] / writerfilter / source / doctok / WW8BinTableImpl.cxx
blob1aa3c9bb9a255483432da4b58143566d4732b59e
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include "WW8BinTableImpl.hxx"
22 namespace writerfilter {
23 namespace doctok
25 using namespace ::std;
27 void PageNumber::dump(OutputWithDepth<string> & /*output*/) const
31 sal_uInt32 WW8BinTableImpl::getPageNumber(const Fc & rFc) const
33 sal_uInt32 nResult = 0;
35 if (mPageMap.find(rFc) == mPageMap.end())
37 sal_uInt32 left = 0;
38 sal_uInt32 right = getEntryCount();
40 while (right - left > 1)
42 sal_uInt32 middle = (right + left) / 2;
44 Fc aFc = getFc(middle);
46 if (rFc < aFc)
47 right = middle;
48 else
49 left = middle;
53 nResult = getPageNumber(left);
54 mPageMap[rFc] = nResult;
57 else
58 nResult = mPageMap[rFc];
60 return nResult;
63 string WW8BinTableImpl::toString() const
65 string aResult;
66 char sBuffer[255];
68 aResult += "(";
70 for (sal_uInt32 n = 0; n < getEntryCount(); n++)
72 if (n > 0)
73 aResult += ", ";
75 snprintf(sBuffer, 255, "%" SAL_PRIxUINT32, getFc(n).get());
76 aResult += sBuffer;
77 aResult += "->";
78 snprintf(sBuffer, 255, "%" SAL_PRIxUINT32, getPageNumber(n));
79 aResult += sBuffer;
82 aResult += ")";
84 return aResult;
88 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */