|
|
|
|
#ifndef JUCI_SOURCE_CLANG_H_
|
|
|
|
|
#define JUCI_SOURCE_CLANG_H_
|
|
|
|
|
|
|
|
|
|
#include <thread>
|
|
|
|
|
#include <atomic>
|
|
|
|
|
#include <mutex>
|
|
|
|
|
#include <set>
|
|
|
|
|
#include <boost/regex.hpp>
|
|
|
|
|
#include "clangmm.h"
|
|
|
|
|
#include "source.h"
|
|
|
|
|
#include "terminal.h"
|
|
|
|
|
|
|
|
|
|
namespace Source {
|
|
|
|
|
class ClangViewParse : public View {
|
|
|
|
|
public:
|
|
|
|
|
class TokenRange {
|
|
|
|
|
public:
|
|
|
|
|
TokenRange(std::pair<clang::Offset, clang::Offset> offsets, int kind):
|
|
|
|
|
offsets(offsets), kind(kind) {}
|
|
|
|
|
std::pair<clang::Offset, clang::Offset> offsets;
|
|
|
|
|
int kind;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
ClangViewParse(const boost::filesystem::path &file_path, const boost::filesystem::path& project_path, Glib::RefPtr<Gsv::Language> language);
|
|
|
|
|
virtual void configure();
|
|
|
|
|
|
|
|
|
|
void start_reparse();
|
|
|
|
|
bool reparse_needed=false;
|
|
|
|
|
protected:
|
|
|
|
|
void init_parse();
|
|
|
|
|
bool on_key_press_event(GdkEventKey* key);
|
|
|
|
|
std::unique_ptr<clang::TranslationUnit> clang_tu;
|
|
|
|
|
std::mutex parsing_mutex;
|
|
|
|
|
std::unique_ptr<clang::Tokens> clang_tokens;
|
|
|
|
|
sigc::connection delayed_reparse_connection;
|
|
|
|
|
|
|
|
|
|
std::shared_ptr<Terminal::InProgress> parsing_in_progress;
|
|
|
|
|
std::thread parse_thread;
|
|
|
|
|
std::atomic<bool> parse_thread_stop;
|
|
|
|
|
std::atomic<bool> parse_error;
|
|
|
|
|
|
|
|
|
|
virtual void show_diagnostic_tooltips(const Gdk::Rectangle &rectangle);
|
|
|
|
|
virtual void show_type_tooltips(const Gdk::Rectangle &rectangle);
|
|
|
|
|
|
|
|
|
|
boost::regex bracket_regex;
|
|
|
|
|
boost::regex no_bracket_statement_regex;
|
|
|
|
|
boost::regex no_bracket_no_para_statement_regex;
|
|
|
|
|
|
|
|
|
|
std::set<int> diagnostic_offsets;
|
|
|
|
|
std::vector<FixIt> fix_its;
|
|
|
|
|
|
|
|
|
|
sigc::connection parse_done_connection;
|
|
|
|
|
sigc::connection parse_start_connection;
|
|
|
|
|
sigc::connection parse_fail_connection;
|
|
|
|
|
private:
|
|
|
|
|
std::map<std::string, std::string> get_buffer_map() const;
|
|
|
|
|
void update_syntax();
|
|
|
|
|
std::set<std::string> last_syntax_tags;
|
|
|
|
|
void update_diagnostics();
|
|
|
|
|
|
|
|
|
|
static clang::Index clang_index;
|
|
|
|
|
std::vector<std::string> get_compilation_commands();
|
|
|
|
|
|
|
|
|
|
Glib::Dispatcher parse_done;
|
|
|
|
|
Glib::Dispatcher parse_start;
|
|
|
|
|
Glib::Dispatcher parse_fail;
|
|
|
|
|
std::map<std::string, std::string> parse_thread_buffer_map;
|
|
|
|
|
std::mutex parse_thread_buffer_map_mutex;
|
|
|
|
|
std::atomic<bool> parse_thread_go;
|
|
|
|
|
std::atomic<bool> parse_thread_mapped;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class ClangViewAutocomplete : public ClangViewParse {
|
|
|
|
|
public:
|
|
|
|
|
class AutoCompleteData {
|
|
|
|
|
public:
|
|
|
|
|
explicit AutoCompleteData(const std::vector<clang::CompletionChunk> &chunks) :
|
|
|
|
|
chunks(chunks) { }
|
|
|
|
|
std::vector<clang::CompletionChunk> chunks;
|
|
|
|
|
std::string brief_comments;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
ClangViewAutocomplete(const boost::filesystem::path &file_path, const boost::filesystem::path& project_path, Glib::RefPtr<Gsv::Language> language);
|
|
|
|
|
virtual void async_delete();
|
|
|
|
|
bool restart_parse();
|
|
|
|
|
protected:
|
|
|
|
|
bool on_key_press_event(GdkEventKey* key);
|
|
|
|
|
std::thread autocomplete_thread;
|
|
|
|
|
sigc::connection autocomplete_done_connection;
|
|
|
|
|
sigc::connection autocomplete_fail_connection;
|
|
|
|
|
sigc::connection do_delete_object_connection;
|
|
|
|
|
sigc::connection do_restart_parse_connection;
|
|
|
|
|
private:
|
|
|
|
|
void start_autocomplete();
|
|
|
|
|
void autocomplete();
|
|
|
|
|
std::unique_ptr<CompletionDialog> completion_dialog;
|
|
|
|
|
bool completion_dialog_shown=false;
|
|
|
|
|
std::vector<AutoCompleteData> get_autocomplete_suggestions(int line_number, int column, std::map<std::string, std::string>& buffer_map);
|
|
|
|
|
Glib::Dispatcher autocomplete_done;
|
|
|
|
|
Glib::Dispatcher autocomplete_fail;
|
|
|
|
|
bool autocomplete_starting=false;
|
|
|
|
|
std::atomic<bool> autocomplete_cancel_starting;
|
|
|
|
|
guint last_keyval=0;
|
|
|
|
|
std::string prefix;
|
|
|
|
|
std::mutex prefix_mutex;
|
|
|
|
|
|
|
|
|
|
Glib::Dispatcher do_delete_object;
|
|
|
|
|
Glib::Dispatcher do_restart_parse;
|
|
|
|
|
std::thread delete_thread;
|
|
|
|
|
std::thread restart_parse_thread;
|
|
|
|
|
bool restart_parse_running=false;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class ClangViewRefactor : public ClangViewAutocomplete {
|
|
|
|
|
public:
|
|
|
|
|
ClangViewRefactor(const boost::filesystem::path &file_path, const boost::filesystem::path& project_path, Glib::RefPtr<Gsv::Language> language);
|
|
|
|
|
protected:
|
|
|
|
|
sigc::connection delayed_tag_similar_tokens_connection;
|
|
|
|
|
private:
|
|
|
|
|
std::list<std::pair<Glib::RefPtr<Gtk::TextMark>, Glib::RefPtr<Gtk::TextMark> > > similar_token_marks;
|
|
|
|
|
void tag_similar_tokens(const Token &token);
|
|
|
|
|
Glib::RefPtr<Gtk::TextTag> similar_tokens_tag;
|
|
|
|
|
Token last_tagged_token;
|
|
|
|
|
bool renaming=false;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class ClangView : public ClangViewRefactor {
|
|
|
|
|
public:
|
|
|
|
|
ClangView(const boost::filesystem::path &file_path, const boost::filesystem::path& project_path, Glib::RefPtr<Gsv::Language> language);
|
|
|
|
|
virtual void async_delete();
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif // JUCI_SOURCE_CLANG_H_
|