-
Notifications
You must be signed in to change notification settings - Fork 72
/
usblinktreewidget.h
60 lines (46 loc) · 2.19 KB
/
usblinktreewidget.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#ifndef USBLINKTREEWIDGET_H
#define USBLINKTREEWIDGET_H
#include <atomic>
#include <QTreeWidget>
class USBLinkTreeWidget : public QTreeWidget
{
Q_OBJECT
public:
explicit USBLinkTreeWidget(QWidget *parent = 0);
// usblink callbacks
static void usblink_dirlist_callback_nested(struct usblink_file *file, bool is_error, void *data);
static void usblink_dirlist_callback(struct usblink_file *file, bool is_error, void *data);
static void usblink_delete_callback(int progress, void *data);
static void usblink_upload_callback(int progress, void *data);
static void usblink_download_callback(int progress, void *data);
static void usblink_move_progress(int progress, void *user_data);
// Helper functions for usblink callbacks
static bool usblink_dirlist_nested(QTreeWidgetItem *w);
static QString usblink_path_item(QTreeWidgetItem *w);
protected:
virtual QStringList mimeTypes() const override;
virtual void dragEnterEvent(QDragEnterEvent *e) override;
virtual bool dropMimeData(QTreeWidgetItem *parent, int index, const QMimeData *data, Qt::DropAction action) override;
signals:
void downloadProgress(int progress); // Called by callback from EmuThread. Use Qt::QueuedConnection
void uploadProgress(int progress); // Same as above
void wantToAddTreeItem(QTreeWidgetItem *item, QTreeWidgetItem *parent); // To let it run in the UI thread. Internal
void wantToReload(); // Same as above
public slots:
void reloadFilebrowser();
private slots:
void customContextMenuRequested(QPoint pos); // Internal
void dataChangedHandler(QTreeWidgetItem *item, int column); // Internal
void downloadEntry(); // Internal
void deleteEntry(); // Internal
void newFolder(); // Internal
void addTreeItem(QTreeWidgetItem *item, QTreeWidgetItem *parent); // Has to run in the UI thread. Internal
private:
static QString naturalSize(uint64_t bytes);
static QTreeWidgetItem *itemForUSBLinkFile(usblink_file *file);
// To avoid concurrent dirlisting
std::atomic<bool> doing_dirlist{false};
// The item the context menu was requested on. Only valid in slots.
QTreeWidgetItem *context_menu_item;
};
#endif // USBLINKTREEWIDGET_H