2013-10-05 20:15:58 +08:00
|
|
|
//===-- Core/ReplacementHandling.h ------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
///
|
|
|
|
/// \file
|
|
|
|
/// \brief This file defines the ReplacementHandling class which abstracts
|
|
|
|
/// serialization and application of serialized replacements.
|
|
|
|
///
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef CLANG_MODERNIZE_REPLACEMENTHANDLING_H
|
|
|
|
#define CLANG_MODERNIZE_REPLACEMENTHANDLING_H
|
|
|
|
|
|
|
|
#include "Core/Transform.h"
|
2014-01-08 04:05:01 +08:00
|
|
|
#include "llvm/ADT/StringRef.h"
|
2013-10-05 20:15:58 +08:00
|
|
|
|
|
|
|
class ReplacementHandling {
|
|
|
|
public:
|
|
|
|
|
2013-10-05 21:31:31 +08:00
|
|
|
ReplacementHandling() : DoFormat(false) {}
|
|
|
|
|
2013-10-05 20:15:58 +08:00
|
|
|
/// \brief Finds the path to the executable 'clang-apply-replacements'.
|
|
|
|
///
|
|
|
|
/// The executable is searched for on the PATH. If not found, looks in the
|
|
|
|
/// same directory as the image used to start the current executable.
|
|
|
|
///
|
|
|
|
/// \param[in] Argv0 argv[0] as passed to main().
|
|
|
|
///
|
|
|
|
/// \returns \li true if clang-apply-replacements was found.
|
|
|
|
/// \li false otherwise.
|
|
|
|
bool findClangApplyReplacements(const char *Argv0);
|
|
|
|
|
|
|
|
/// \brief Set the name of the directory in which replacements will be
|
|
|
|
/// serialized.
|
|
|
|
///
|
|
|
|
/// \param[in] Dir Destination directory name
|
|
|
|
void setDestinationDir(llvm::StringRef Dir) { DestinationDir = Dir; }
|
|
|
|
|
|
|
|
/// \brief Create a new temporary directory to serialize replacements into.
|
|
|
|
///
|
|
|
|
/// \returns The name of the directory createdy.
|
|
|
|
llvm::StringRef useTempDestinationDir();
|
|
|
|
|
|
|
|
/// \brief Enable clang-apply-replacements do code reformatting when applying
|
|
|
|
/// serialized replacements.
|
|
|
|
///
|
|
|
|
/// \param[in] Style Value to pass to clang-apply-replacement's --style
|
|
|
|
/// option.
|
|
|
|
/// \param[in] StyleConfigDir If non-empty, value to pass to
|
|
|
|
/// clang-apply-replacement's --style-config option.
|
|
|
|
void enableFormatting(llvm::StringRef Style,
|
|
|
|
llvm::StringRef StyleConfigDir = "");
|
|
|
|
|
|
|
|
/// \brief Write all TranslationUnitReplacements stored in \c Replacements
|
|
|
|
/// to disk.
|
|
|
|
///
|
|
|
|
/// \pre Destination directory must have been previously set by calling
|
|
|
|
/// setDestiantionDir() or useTempDestinationDir().
|
|
|
|
/// \pre Destination dir must exist.
|
|
|
|
///
|
|
|
|
/// \param[in] Replacements Container of replacements to serialize.
|
|
|
|
///
|
|
|
|
/// \returns \li true if all replacements were serialized successfully to
|
|
|
|
/// disk.
|
|
|
|
/// \li false otherwise.
|
|
|
|
bool serializeReplacements(const TUReplacementsMap &Replacements);
|
|
|
|
|
|
|
|
/// \brief Invoke clang-apply-replacements to apply all serialized
|
|
|
|
/// replacements stored in the destination directory.
|
|
|
|
///
|
|
|
|
/// \pre Destination directory must have been previously set by calling
|
|
|
|
/// setDestiantionDir() or useTempDestinationDir().
|
|
|
|
///
|
|
|
|
/// \returns \li true if clang-apply-replacements was successfully launched
|
|
|
|
/// and successfully completed.
|
|
|
|
/// \li false otherwise.
|
|
|
|
bool applyReplacements();
|
|
|
|
|
|
|
|
/// \brief Generate a unique filename to store the replacements.
|
|
|
|
///
|
|
|
|
/// Generates a unique filename in \c DestinationDir. The filename is generated
|
|
|
|
/// following this pattern:
|
|
|
|
///
|
|
|
|
/// DestinationDir/Prefix_%%_%%_%%_%%_%%_%%.yaml
|
|
|
|
///
|
|
|
|
/// where Prefix := llvm::sys::path::filename(MainSourceFile) and all '%' will
|
|
|
|
/// be replaced by a randomly chosen hex digit.
|
|
|
|
///
|
|
|
|
/// \param[in] DestinationDir Directory the unique file should be placed in.
|
|
|
|
/// \param[in] MainSourceFile Full path to the source file.
|
|
|
|
/// \param[out] Result The resulting unique filename.
|
|
|
|
/// \param[out] Error If an error occurs a description of that error is
|
|
|
|
/// placed in this string.
|
|
|
|
///
|
|
|
|
/// \returns \li true on success
|
|
|
|
/// \li false if a unique file name could not be created.
|
|
|
|
static bool generateReplacementsFileName(llvm::StringRef DestinationDir,
|
|
|
|
llvm::StringRef MainSourceFile,
|
|
|
|
llvm::SmallVectorImpl<char> &Result,
|
|
|
|
llvm::SmallVectorImpl<char> &Error);
|
|
|
|
|
|
|
|
/// \brief Helper to create a temporary directory name.
|
|
|
|
///
|
2013-10-07 21:40:19 +08:00
|
|
|
/// \post The directory named by the returned string exists.
|
|
|
|
///
|
|
|
|
/// \returns A temp directory name.
|
2013-10-05 20:15:58 +08:00
|
|
|
static std::string generateTempDir();
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
std::string CARPath;
|
|
|
|
std::string DestinationDir;
|
|
|
|
bool DoFormat;
|
|
|
|
std::string FormatStyle;
|
|
|
|
std::string StyleConfigDir;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // CLANG_MODERNIZE_REPLACEMENTHANDLING_H
|