forked from amazingfate/loongoffice
...detected with a modified trunk Clang with
> Index: lib/Sema/SemaDeclCXX.cpp
> ===================================================================
> --- lib/Sema/SemaDeclCXX.cpp (revision 219190)
> +++ lib/Sema/SemaDeclCXX.cpp (working copy)
> @@ -1917,9 +1917,10 @@
> const Type *T = FD.getType()->getBaseElementTypeUnsafe();
> // FIXME: Destruction of ObjC lifetime types has side-effects.
> if (const CXXRecordDecl *RD = T->getAsCXXRecordDecl())
> - return !RD->isCompleteDefinition() ||
> - !RD->hasTrivialDefaultConstructor() ||
> - !RD->hasTrivialDestructor();
> + return !RD->hasAttr<WarnUnusedAttr>() &&
> + (!RD->isCompleteDefinition() ||
> + !RD->hasTrivialDefaultConstructor() ||
> + !RD->hasTrivialDestructor());
> return false;
> }
>
> @@ -3517,9 +3518,11 @@
> bool addFieldInitializer(CXXCtorInitializer *Init) {
> AllToInit.push_back(Init);
>
> +#if 0
> // Check whether this initializer makes the field "used".
> if (Init->getInit()->HasSideEffects(S.Context))
> S.UnusedPrivateFields.remove(Init->getAnyMember());
> +#endif
>
> return false;
> }
to warn about members of SAL_WARN_UNUSED-annotated class types, and warn about
initializations with side effects (cf.
<http://lists.cs.uiuc.edu/pipermail/cfe-dev/2014-October/039602.html>
"-Wunused-private-field distracted by side effects").
Change-Id: I3f3181c4eb8180ca28e1fa3dffc9dbe1002c6628
79 lines
2.4 KiB
C++
79 lines
2.4 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
* with this work for additional information regarding copyright
|
|
* ownership. The ASF licenses this file to you under the Apache
|
|
* License, Version 2.0 (the "License"); you may not use this file
|
|
* except in compliance with the License. You may obtain a copy of
|
|
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
|
*/
|
|
|
|
#ifndef INCLUDED_XMLOFF_SOURCE_TEXT_XMLINDEXTOCSOURCECONTEXT_HXX
|
|
#define INCLUDED_XMLOFF_SOURCE_TEXT_XMLINDEXTOCSOURCECONTEXT_HXX
|
|
|
|
#include "XMLIndexSourceBaseContext.hxx"
|
|
#include <com/sun/star/uno/Reference.h>
|
|
|
|
|
|
namespace com { namespace sun { namespace star {
|
|
namespace xml { namespace sax { class XAttributeList; } }
|
|
namespace beans { class XPropertySet; }
|
|
} } }
|
|
|
|
|
|
/**
|
|
* Import table of context source element
|
|
*/
|
|
class XMLIndexTOCSourceContext : public XMLIndexSourceBaseContext
|
|
{
|
|
const OUString sCreateFromMarks;
|
|
const OUString sLevel;
|
|
const OUString sCreateFromOutline;
|
|
const OUString sCreateFromLevelParagraphStyles;
|
|
|
|
sal_Int32 nOutlineLevel;
|
|
bool bUseOutline;
|
|
bool bUseMarks;
|
|
bool bUseParagraphStyles;
|
|
|
|
public:
|
|
|
|
TYPEINFO_OVERRIDE();
|
|
|
|
XMLIndexTOCSourceContext(
|
|
SvXMLImport& rImport,
|
|
sal_uInt16 nPrfx,
|
|
const OUString& rLocalName,
|
|
::com::sun::star::uno::Reference<
|
|
::com::sun::star::beans::XPropertySet> & rPropSet);
|
|
|
|
virtual ~XMLIndexTOCSourceContext();
|
|
|
|
protected:
|
|
|
|
virtual void ProcessAttribute(
|
|
enum IndexSourceParamEnum eParam,
|
|
const OUString& rValue) SAL_OVERRIDE;
|
|
|
|
virtual void EndElement() SAL_OVERRIDE;
|
|
|
|
virtual SvXMLImportContext* CreateChildContext(
|
|
sal_uInt16 nPrefix,
|
|
const OUString& rLocalName,
|
|
const ::com::sun::star::uno::Reference<
|
|
::com::sun::star::xml::sax::XAttributeList> & xAttrList ) SAL_OVERRIDE;
|
|
};
|
|
|
|
#endif
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|