2012-07-19 21:17:39 -07:00
|
|
|
// Copyright (C) 2011, 2012 Strahinja Val Markovic <val@markovic.io>
|
|
|
|
//
|
|
|
|
// This file is part of YouCompleteMe.
|
|
|
|
//
|
|
|
|
// YouCompleteMe is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// YouCompleteMe is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with YouCompleteMe. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
#ifndef COMPLETIONDATA_H_2JCTF1NU
|
|
|
|
#define COMPLETIONDATA_H_2JCTF1NU
|
|
|
|
|
2012-08-05 21:43:38 -07:00
|
|
|
#include "standard.h"
|
2012-07-28 15:27:30 -07:00
|
|
|
#include <string>
|
2012-08-05 21:01:42 -07:00
|
|
|
#include <clang-c/Index.h>
|
2012-07-28 15:27:30 -07:00
|
|
|
|
2012-07-19 21:17:39 -07:00
|
|
|
namespace YouCompleteMe
|
|
|
|
{
|
|
|
|
|
2012-08-05 21:01:42 -07:00
|
|
|
std::string CXStringToString( CXString text );
|
|
|
|
|
2012-08-02 21:37:21 -07:00
|
|
|
// This class holds pieces of information about a single completion coming from
|
|
|
|
// clang. These pieces are shown in Vim's UI in different ways.
|
|
|
|
//
|
|
|
|
// Normally, the completion menu looks like this (without square brackets):
|
|
|
|
//
|
|
|
|
// [main completion text] [kind] [extra menu info]
|
|
|
|
// [main completion text] [kind] [extra menu info]
|
|
|
|
// [main completion text] [kind] [extra menu info]
|
|
|
|
// ... (etc.) ...
|
|
|
|
//
|
|
|
|
// The user can also enable a "preview" window that will show extra information
|
|
|
|
// about a completion at the top of the buffer.
|
2012-07-19 21:17:39 -07:00
|
|
|
struct CompletionData
|
|
|
|
{
|
2012-08-05 21:01:42 -07:00
|
|
|
CompletionData() {}
|
|
|
|
CompletionData( const CXCompletionResult &completion_result );
|
|
|
|
|
2012-08-02 21:37:21 -07:00
|
|
|
// What should actually be inserted into the buffer. For a function like
|
|
|
|
// "int foo(int x)", this is just "foo". Same for a data member like "foo_":
|
|
|
|
// we insert just "foo_".
|
2012-07-19 21:17:39 -07:00
|
|
|
std::string TextToInsertInBuffer()
|
|
|
|
{
|
|
|
|
return original_string_;
|
|
|
|
}
|
|
|
|
|
2012-08-02 21:37:21 -07:00
|
|
|
// Currently, here we show the full function signature (without the return
|
|
|
|
// type) if the current completion is a function or just the raw TypedText if
|
|
|
|
// the completion is, say, a data member. So for a function like "int foo(int
|
|
|
|
// x)", this would be "foo(int x)". For a data member like "count_", it would
|
|
|
|
// be just "count_".
|
|
|
|
std::string MainCompletionText()
|
|
|
|
{
|
|
|
|
return everything_except_return_type_;
|
|
|
|
}
|
|
|
|
|
|
|
|
// This is extra info shown in the pop-up completion menu, after the
|
|
|
|
// completion text and the kind. Currently we put the return type of the
|
|
|
|
// function here, if any.
|
|
|
|
std::string ExtraMenuInfo()
|
|
|
|
{
|
|
|
|
return return_type_;
|
|
|
|
}
|
|
|
|
|
|
|
|
// This is used to show extra information in vim's preview window. This is the
|
|
|
|
// window that vim usually shows at the top of the buffer. This should be used
|
|
|
|
// for extra information about the completion.
|
|
|
|
std::string DetailedInfoForPreviewWindow()
|
|
|
|
{
|
|
|
|
return detailed_info_;
|
|
|
|
}
|
2012-07-19 21:17:39 -07:00
|
|
|
|
|
|
|
bool operator== ( const CompletionData &other ) const
|
|
|
|
{
|
|
|
|
return
|
|
|
|
kind_ == other.kind_ &&
|
2012-08-02 21:37:21 -07:00
|
|
|
everything_except_return_type_ == other.everything_except_return_type_ &&
|
|
|
|
return_type_ == other.return_type_ &&
|
|
|
|
original_string_ == other.original_string_;
|
2012-07-19 21:17:39 -07:00
|
|
|
// detailed_info_ doesn't matter
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string detailed_info_;
|
|
|
|
|
2012-08-02 21:37:21 -07:00
|
|
|
std::string return_type_;
|
2012-07-19 21:17:39 -07:00
|
|
|
|
|
|
|
// Vim's completion string "kind"
|
|
|
|
// 'v' -> variable
|
|
|
|
// 'f' -> function or method
|
|
|
|
// 'm' -> member of struct/class (data member)
|
|
|
|
// 't' -> typedef (but we're going to use it for types in general)
|
|
|
|
// 'd' -> #define or macro
|
|
|
|
char kind_;
|
|
|
|
|
|
|
|
// The original, raw completion string. For a function like "int foo(int x)",
|
2012-08-02 21:37:21 -07:00
|
|
|
// the original string is "foo". For a member data variable like "foo_", this
|
|
|
|
// is just "foo_". This corresponds to clang's TypedText chunk of the
|
|
|
|
// completion string.
|
2012-07-19 21:17:39 -07:00
|
|
|
std::string original_string_;
|
2012-08-02 21:37:21 -07:00
|
|
|
|
|
|
|
std::string everything_except_return_type_;
|
2012-08-05 21:43:38 -07:00
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
void ExtractDataFromChunk( CXCompletionString completion_string,
|
|
|
|
uint chunk_num,
|
|
|
|
bool &saw_left_paren,
|
|
|
|
bool &saw_function_params );
|
2012-07-19 21:17:39 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace YouCompleteMe
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* end of include guard: COMPLETIONDATA_H_2JCTF1NU */
|