mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-05 21:31:08 -06:00
`include-what-you-use` diagnostics, in practice, are specific to the environment's compiler and standard library. Update includes to satisfy IWYU for our CI job under Debian 13. Some patterns: * Types named in virtual `override` signatures no longer require includes since the overridden signature already names them. * A function argument's type needs to be included even if its constructor is called only by implicit conversion. For example, constructing a `std::function` from a lambda now requires `<functional>`. * Some prior mysterious `<type_traits>` inclusions are no longer required.
36 lines
958 B
C++
36 lines
958 B
C++
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
file LICENSE.rst or https://cmake.org/licensing for details. */
|
|
#include "cmPlistParser.h"
|
|
|
|
#include <vector>
|
|
|
|
#include <cm3p/json/reader.h>
|
|
#include <cm3p/json/value.h>
|
|
|
|
#include "cmUVProcessChain.h"
|
|
#include "cmUVStream.h"
|
|
|
|
cm::optional<Json::Value> cmParsePlist(std::string const& filename)
|
|
{
|
|
cmUVProcessChainBuilder builder;
|
|
builder.AddCommand(
|
|
{ "/usr/bin/plutil", "-convert", "json", "-o", "-", filename });
|
|
builder.SetBuiltinStream(cmUVProcessChainBuilder::Stream_OUTPUT);
|
|
|
|
auto chain = builder.Start();
|
|
chain.Wait();
|
|
|
|
auto const& status = chain.GetStatus(0);
|
|
if (status.ExitStatus != 0) {
|
|
return cm::nullopt;
|
|
}
|
|
|
|
Json::Reader reader;
|
|
Json::Value value;
|
|
cmUVPipeIStream outputStream(chain.GetLoop(), chain.OutputStream());
|
|
if (!reader.parse(outputStream, value)) {
|
|
return cm::nullopt;
|
|
}
|
|
return cm::optional<Json::Value>(value);
|
|
}
|