mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Cursor info for a constructor would previously give the cursor info for the containing type only. It now also adds cursor info for the constructor itself in a "secondary_symbols" field. Refactor `passCursorInfoForDecl` to use a single allocator rather than keeping track of positions in a buffer and assigning everything at the end of the function. Refactor the various available refactoring gathering functions to take a SmallVectorImpl and to not copy strings where they don't need to. Resolves rdar://75385556
159 lines
4.8 KiB
C++
159 lines
4.8 KiB
C++
//===--- Refactoring.h - APIs for refactoring --------*- C++ -*-===//
|
||
//
|
||
// This source file is part of the Swift.org open source project
|
||
//
|
||
// Copyright (c) 2014 - 2017 Apple Inc. and the Swift project authors
|
||
// Licensed under Apache License v2.0 with Runtime Library Exception
|
||
//
|
||
// See https://swift.org/LICENSE.txt for license information
|
||
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
|
||
//
|
||
//===----------------------------------------------------------------------===//
|
||
|
||
#ifndef SWIFT_IDE_REFACTORING_H
|
||
#define SWIFT_IDE_REFACTORING_H
|
||
|
||
#include "llvm/ADT/StringRef.h"
|
||
#include "swift/Basic/LLVM.h"
|
||
#include "swift/AST/DiagnosticConsumer.h"
|
||
#include "swift/IDE/Utils.h"
|
||
|
||
namespace swift {
|
||
class ModuleDecl;
|
||
class SourceLoc;
|
||
class SourceManager;
|
||
|
||
namespace ide {
|
||
struct ResolvedCursorInfo;
|
||
|
||
enum class RefactoringKind : int8_t {
|
||
None,
|
||
#define REFACTORING(KIND, NAME, ID) KIND,
|
||
#include "RefactoringKinds.def"
|
||
};
|
||
|
||
struct RangeConfig {
|
||
unsigned BufferId;
|
||
unsigned Line;
|
||
unsigned Column;
|
||
unsigned Length;
|
||
SourceLoc getStart(SourceManager &SM);
|
||
SourceLoc getEnd(SourceManager &SM);
|
||
};
|
||
|
||
enum class NameUsage {
|
||
Unknown,
|
||
Reference,
|
||
Definition,
|
||
Call
|
||
};
|
||
|
||
struct RenameLoc {
|
||
unsigned Line;
|
||
unsigned Column;
|
||
NameUsage Usage;
|
||
StringRef OldName;
|
||
StringRef NewName; // May be empty.
|
||
const bool IsFunctionLike;
|
||
const bool IsNonProtocolType;
|
||
};
|
||
|
||
struct RefactoringOptions {
|
||
RefactoringKind Kind;
|
||
RangeConfig Range;
|
||
std::string PreferredName;
|
||
RefactoringOptions(RefactoringKind Kind) : Kind(Kind) {}
|
||
};
|
||
|
||
// TODO: Merge with NoteRegion – range needs to change to start/end line/column
|
||
struct RenameRangeDetail {
|
||
CharSourceRange Range;
|
||
RefactoringRangeKind RangeKind;
|
||
Optional<unsigned> Index;
|
||
};
|
||
|
||
enum class RenameAvailableKind {
|
||
Available,
|
||
Unavailable_system_symbol,
|
||
Unavailable_has_no_location,
|
||
Unavailable_has_no_name,
|
||
Unavailable_has_no_accessibility,
|
||
Unavailable_decl_from_clang,
|
||
};
|
||
|
||
struct RenameAvailabilityInfo {
|
||
RefactoringKind Kind;
|
||
RenameAvailableKind AvailableKind;
|
||
RenameAvailabilityInfo(RefactoringKind Kind,
|
||
RenameAvailableKind AvailableKind)
|
||
: Kind(Kind), AvailableKind(AvailableKind) {}
|
||
RenameAvailabilityInfo(RefactoringKind Kind)
|
||
: RenameAvailabilityInfo(Kind, RenameAvailableKind::Available) {}
|
||
};
|
||
|
||
class FindRenameRangesConsumer {
|
||
public:
|
||
virtual void accept(SourceManager &SM, RegionType RegionType,
|
||
ArrayRef<RenameRangeDetail> Ranges) = 0;
|
||
virtual ~FindRenameRangesConsumer() = default;
|
||
};
|
||
|
||
class FindRenameRangesAnnotatingConsumer : public FindRenameRangesConsumer {
|
||
struct Implementation;
|
||
Implementation &Impl;
|
||
|
||
public:
|
||
FindRenameRangesAnnotatingConsumer(SourceManager &SM, unsigned BufferId,
|
||
llvm::raw_ostream &OS);
|
||
~FindRenameRangesAnnotatingConsumer();
|
||
void accept(SourceManager &SM, RegionType RegionType,
|
||
ArrayRef<RenameRangeDetail> Ranges) override;
|
||
};
|
||
|
||
StringRef getDescriptiveRefactoringKindName(RefactoringKind Kind);
|
||
|
||
StringRef getDescriptiveRenameUnavailableReason(RenameAvailableKind Kind);
|
||
|
||
bool refactorSwiftModule(ModuleDecl *M, RefactoringOptions Opts,
|
||
SourceEditConsumer &EditConsumer,
|
||
DiagnosticConsumer &DiagConsumer);
|
||
|
||
int syntacticRename(SourceFile *SF, llvm::ArrayRef<RenameLoc> RenameLocs,
|
||
SourceEditConsumer &EditConsumer,
|
||
DiagnosticConsumer &DiagConsumer);
|
||
|
||
int findSyntacticRenameRanges(SourceFile *SF,
|
||
llvm::ArrayRef<RenameLoc> RenameLocs,
|
||
FindRenameRangesConsumer &RenameConsumer,
|
||
DiagnosticConsumer &DiagConsumer);
|
||
|
||
int findLocalRenameRanges(SourceFile *SF, RangeConfig Range,
|
||
FindRenameRangesConsumer &RenameConsumer,
|
||
DiagnosticConsumer &DiagConsumer);
|
||
|
||
void collectAvailableRefactorings(
|
||
SourceFile *SF, RangeConfig Range, bool &RangeStartMayNeedRename,
|
||
llvm::SmallVectorImpl<RefactoringKind> &Kinds,
|
||
llvm::ArrayRef<DiagnosticConsumer *> DiagConsumers);
|
||
|
||
void collectAvailableRefactorings(const ResolvedCursorInfo &CursorInfo,
|
||
llvm::SmallVectorImpl<RefactoringKind> &Kinds,
|
||
bool ExcludeRename);
|
||
|
||
/// Stores information about the reference that rename availability is being
|
||
/// queried on.
|
||
struct RenameRefInfo {
|
||
SourceFile *SF; ///< The source file containing the reference.
|
||
SourceLoc Loc; ///< The reference's source location.
|
||
bool IsArgLabel; ///< Whether Loc is on an arg label, rather than base name.
|
||
};
|
||
|
||
void collectRenameAvailabilityInfo(
|
||
const ValueDecl *VD, Optional<RenameRefInfo> RefInfo,
|
||
llvm::SmallVectorImpl<RenameAvailabilityInfo> &Infos);
|
||
|
||
} // namespace ide
|
||
} // namespace swift
|
||
|
||
#endif // SWIFT_IDE_REFACTORING_H
|