From fa3cf05f721f6bacf1fde492b64e749e4c6641c1 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:29:59 +0200 Subject: [PATCH 01/12] dragger: initial version --- dragger.cc | 33 +++++++++++++++++++++++++++++++++ dragger.pro | 3 +++ 2 files changed, 36 insertions(+) create mode 100644 dragger.cc create mode 100644 dragger.pro diff --git a/dragger.cc b/dragger.cc new file mode 100644 index 0000000..87c59e4 --- /dev/null +++ b/dragger.cc @@ -0,0 +1,33 @@ +#include +#include +#include +#include +#include +#include +#include +#include + +int main(int argc, char* argv[]) { + QApplication app(argc, argv); + + QList urls; + for (int i = 1; i < argc; ++i) { + QFileInfo file(QFile(argv[i])); + if (file.exists()) { + urls << QUrl("file:" + file.absoluteFilePath()); + } else { + qInfo() << file.filePath() << "does not exist"; + } + } + + if (urls.empty()) { + return 0; + } + + QMimeData* mimeData = new QMimeData(); + mimeData->setUrls(urls); + + QDrag drag(&app); + drag.setMimeData(mimeData); + drag.exec(); +} diff --git a/dragger.pro b/dragger.pro new file mode 100644 index 0000000..6015b89 --- /dev/null +++ b/dragger.pro @@ -0,0 +1,3 @@ +SOURCES = dragger.cc +CONFIG += qt +QT += widgets From 124443bb7c8c965cd300c19d23391b0c17b87878 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:31:25 +0200 Subject: [PATCH 02/12] project: add clang-format --- .clang-format | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 .clang-format diff --git a/.clang-format b/.clang-format new file mode 100644 index 0000000..f47e7d6 --- /dev/null +++ b/.clang-format @@ -0,0 +1,10 @@ +# vim: ft=yaml +--- +BasedOnStyle: LLVM +IndentWidth: 4 +--- +Language: Cpp +# Force pointers to the type for C++. +DerivePointerAlignment: false +PointerAlignment: Left +--- From 6ac136c5e6a10c2a1fea17f8e951f95ac352ad94 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:30:53 +0200 Subject: [PATCH 03/12] nix: add flake --- flake.lock | 69 +++++++++++++++++++++++++++++++++ flake.nix | 112 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 181 insertions(+) create mode 100644 flake.lock create mode 100644 flake.nix diff --git a/flake.lock b/flake.lock new file mode 100644 index 0000000..00c49b4 --- /dev/null +++ b/flake.lock @@ -0,0 +1,69 @@ +{ + "nodes": { + "flake-utils": { + "locked": { + "lastModified": 1631561581, + "narHash": "sha256-3VQMV5zvxaVLvqqUrNz3iJelLw30mIVSfZmAaauM3dA=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "7e5bf3925f6fbdfaf50a2a7ca0be2879c4261d19", + "type": "github" + }, + "original": { + "owner": "numtide", + "ref": "master", + "repo": "flake-utils", + "type": "github" + } + }, + "nixpkgs": { + "locked": { + "lastModified": 1633329294, + "narHash": "sha256-0LpQLS4KMgxslMgmDHmxG/5twFlXDBW9z4Or1iOrCvU=", + "owner": "NixOS", + "repo": "nixpkgs", + "rev": "ee084c02040e864eeeb4cf4f8538d92f7c675671", + "type": "github" + }, + "original": { + "owner": "NixOS", + "ref": "nixpkgs-unstable", + "repo": "nixpkgs", + "type": "github" + } + }, + "pre-commit-hooks": { + "inputs": { + "flake-utils": [ + "flake-utils" + ], + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1631170176, + "narHash": "sha256-RLN/kur2Kpxt0cJp0Fms8ixuGpT8IHX0OpeQ8u8f0X4=", + "owner": "cachix", + "repo": "pre-commit-hooks.nix", + "rev": "3ed0e618cebc1ff291c27b749cf7568959cac028", + "type": "github" + }, + "original": { + "owner": "cachix", + "ref": "master", + "repo": "pre-commit-hooks.nix", + "type": "github" + } + }, + "root": { + "inputs": { + "flake-utils": "flake-utils", + "nixpkgs": "nixpkgs", + "pre-commit-hooks": "pre-commit-hooks" + } + } + }, + "root": "root", + "version": 7 +} diff --git a/flake.nix b/flake.nix new file mode 100644 index 0000000..42cfda1 --- /dev/null +++ b/flake.nix @@ -0,0 +1,112 @@ +{ + description = "A simple calculator"; + + inputs = { + flake-utils = { + type = "github"; + owner = "numtide"; + repo = "flake-utils"; + ref = "master"; + }; + + nixpkgs = { + type = "github"; + owner = "NixOS"; + repo = "nixpkgs"; + ref = "nixpkgs-unstable"; + }; + + pre-commit-hooks = { + type = "github"; + owner = "cachix"; + repo = "pre-commit-hooks.nix"; + ref = "master"; + inputs = { + flake-utils.follows = "flake-utils"; + nixpkgs.follows = "nixpkgs"; + }; + }; + }; + + outputs = + { self + , flake-utils + , nixpkgs + , pre-commit-hooks + }: + flake-utils.lib.eachDefaultSystem + (system: + let + pkgs = import nixpkgs { + inherit system; + overlays = [ self.overlay ]; + }; + in + rec { + apps = { + dragger = flake-utils.lib.mkApp { drv = packages.dragger; }; + }; + + checks = { + pre-commit = pre-commit-hooks.lib.${system}.run { + src = self; + + hooks = { + clang-format = { + enable = true; + name = "clang-format"; + entry = "${pkgs.clang-tools}/bin/clang-format -style=file -i"; + types = [ "text" "c++" ]; + language = "system"; + }; + + nixpkgs-fmt = { + enable = true; + }; + }; + }; + }; + + defaultApp = apps.dragger; + + defaultPackage = packages.dragger; + + devShell = pkgs.mkShell { + nativeBuildInputs = with pkgs; [ ] + ++ defaultPackage.nativeBuildInputs + ++ defaultPackage.buildInputs + ; + + inherit (checks.pre-commit) shellHook; + }; + + packages = { + inherit (pkgs) dragger; + }; + }) // { + overlay = final: prev: { + dragger = with final; stdenv.mkDerivation { + pname = "dragger"; + version = "0.1.0"; + + src = self; + + buildInputs = [ + libsForQt5.qt5.qtbase + ]; + nativeBuildInputs = [ + libsForQt5.qt5.wrapQtAppsHook + ]; + + configurePhase = '' + qmake + ''; + + installPhase = '' + mkdir -p $out/bin + cp dragger $out/bin + ''; + }; + }; + }; +} From 7b10fef4c0d9903de343ea0b7b3835a12b2a138f Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:31:01 +0200 Subject: [PATCH 04/12] nix: add direnv integration --- .envrc | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 .envrc diff --git a/.envrc b/.envrc new file mode 100644 index 0000000..c4f5ea4 --- /dev/null +++ b/.envrc @@ -0,0 +1,7 @@ +use_flake() { + watch_file flake.nix + watch_file flake.lock + eval "$(nix print-dev-env)" +} + +use flake From d7afffbce22e3c81585bd8971a53b62474ebb486 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:31:08 +0200 Subject: [PATCH 05/12] git: add ignore file --- .gitignore | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1e2d53d --- /dev/null +++ b/.gitignore @@ -0,0 +1,7 @@ +# Nix files +/result +/.pre-commit-config.yaml + +# Qt files +/Makefile +/.qmake.stash From 6193170b5e5373ff0a76e6df4b3221117328ef16 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:38:31 +0200 Subject: [PATCH 06/12] project: add README --- README.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..93cc1a8 --- /dev/null +++ b/README.md @@ -0,0 +1,14 @@ +# `dragger` + +Drag files from CLI, without the need to open a GUI. + +## Usage + +Simply issue the command: + +```bash +dragger [FILES...] +``` + +`dragger` will initiate a drag-and-drop operation for all files and directories +provided as arguments. From 853ebeb6f39a691cde147061cd30399958dfa02f Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:29:59 +0200 Subject: [PATCH 07/12] dragger: initial version --- dragger.pro | 3 +++ src/dragger.cc | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+) create mode 100644 dragger.pro create mode 100644 src/dragger.cc diff --git a/dragger.pro b/dragger.pro new file mode 100644 index 0000000..62c7379 --- /dev/null +++ b/dragger.pro @@ -0,0 +1,3 @@ +SOURCES = src/dragger.cc +CONFIG += qt +QT += widgets diff --git a/src/dragger.cc b/src/dragger.cc new file mode 100644 index 0000000..87c59e4 --- /dev/null +++ b/src/dragger.cc @@ -0,0 +1,33 @@ +#include +#include +#include +#include +#include +#include +#include +#include + +int main(int argc, char* argv[]) { + QApplication app(argc, argv); + + QList urls; + for (int i = 1; i < argc; ++i) { + QFileInfo file(QFile(argv[i])); + if (file.exists()) { + urls << QUrl("file:" + file.absoluteFilePath()); + } else { + qInfo() << file.filePath() << "does not exist"; + } + } + + if (urls.empty()) { + return 0; + } + + QMimeData* mimeData = new QMimeData(); + mimeData->setUrls(urls); + + QDrag drag(&app); + drag.setMimeData(mimeData); + drag.exec(); +} From 6a1f55d4204ea78ce10d1cbd857a81df6774e24c Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:31:25 +0200 Subject: [PATCH 08/12] project: add clang-format --- .clang-format | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 .clang-format diff --git a/.clang-format b/.clang-format new file mode 100644 index 0000000..f47e7d6 --- /dev/null +++ b/.clang-format @@ -0,0 +1,10 @@ +# vim: ft=yaml +--- +BasedOnStyle: LLVM +IndentWidth: 4 +--- +Language: Cpp +# Force pointers to the type for C++. +DerivePointerAlignment: false +PointerAlignment: Left +--- From 6a97fade36281346cafc73a52793603da276bc07 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:30:53 +0200 Subject: [PATCH 09/12] nix: add flake --- flake.lock | 69 +++++++++++++++++++++++++++++++++ flake.nix | 112 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 181 insertions(+) create mode 100644 flake.lock create mode 100644 flake.nix diff --git a/flake.lock b/flake.lock new file mode 100644 index 0000000..00c49b4 --- /dev/null +++ b/flake.lock @@ -0,0 +1,69 @@ +{ + "nodes": { + "flake-utils": { + "locked": { + "lastModified": 1631561581, + "narHash": "sha256-3VQMV5zvxaVLvqqUrNz3iJelLw30mIVSfZmAaauM3dA=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "7e5bf3925f6fbdfaf50a2a7ca0be2879c4261d19", + "type": "github" + }, + "original": { + "owner": "numtide", + "ref": "master", + "repo": "flake-utils", + "type": "github" + } + }, + "nixpkgs": { + "locked": { + "lastModified": 1633329294, + "narHash": "sha256-0LpQLS4KMgxslMgmDHmxG/5twFlXDBW9z4Or1iOrCvU=", + "owner": "NixOS", + "repo": "nixpkgs", + "rev": "ee084c02040e864eeeb4cf4f8538d92f7c675671", + "type": "github" + }, + "original": { + "owner": "NixOS", + "ref": "nixpkgs-unstable", + "repo": "nixpkgs", + "type": "github" + } + }, + "pre-commit-hooks": { + "inputs": { + "flake-utils": [ + "flake-utils" + ], + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1631170176, + "narHash": "sha256-RLN/kur2Kpxt0cJp0Fms8ixuGpT8IHX0OpeQ8u8f0X4=", + "owner": "cachix", + "repo": "pre-commit-hooks.nix", + "rev": "3ed0e618cebc1ff291c27b749cf7568959cac028", + "type": "github" + }, + "original": { + "owner": "cachix", + "ref": "master", + "repo": "pre-commit-hooks.nix", + "type": "github" + } + }, + "root": { + "inputs": { + "flake-utils": "flake-utils", + "nixpkgs": "nixpkgs", + "pre-commit-hooks": "pre-commit-hooks" + } + } + }, + "root": "root", + "version": 7 +} diff --git a/flake.nix b/flake.nix new file mode 100644 index 0000000..42cfda1 --- /dev/null +++ b/flake.nix @@ -0,0 +1,112 @@ +{ + description = "A simple calculator"; + + inputs = { + flake-utils = { + type = "github"; + owner = "numtide"; + repo = "flake-utils"; + ref = "master"; + }; + + nixpkgs = { + type = "github"; + owner = "NixOS"; + repo = "nixpkgs"; + ref = "nixpkgs-unstable"; + }; + + pre-commit-hooks = { + type = "github"; + owner = "cachix"; + repo = "pre-commit-hooks.nix"; + ref = "master"; + inputs = { + flake-utils.follows = "flake-utils"; + nixpkgs.follows = "nixpkgs"; + }; + }; + }; + + outputs = + { self + , flake-utils + , nixpkgs + , pre-commit-hooks + }: + flake-utils.lib.eachDefaultSystem + (system: + let + pkgs = import nixpkgs { + inherit system; + overlays = [ self.overlay ]; + }; + in + rec { + apps = { + dragger = flake-utils.lib.mkApp { drv = packages.dragger; }; + }; + + checks = { + pre-commit = pre-commit-hooks.lib.${system}.run { + src = self; + + hooks = { + clang-format = { + enable = true; + name = "clang-format"; + entry = "${pkgs.clang-tools}/bin/clang-format -style=file -i"; + types = [ "text" "c++" ]; + language = "system"; + }; + + nixpkgs-fmt = { + enable = true; + }; + }; + }; + }; + + defaultApp = apps.dragger; + + defaultPackage = packages.dragger; + + devShell = pkgs.mkShell { + nativeBuildInputs = with pkgs; [ ] + ++ defaultPackage.nativeBuildInputs + ++ defaultPackage.buildInputs + ; + + inherit (checks.pre-commit) shellHook; + }; + + packages = { + inherit (pkgs) dragger; + }; + }) // { + overlay = final: prev: { + dragger = with final; stdenv.mkDerivation { + pname = "dragger"; + version = "0.1.0"; + + src = self; + + buildInputs = [ + libsForQt5.qt5.qtbase + ]; + nativeBuildInputs = [ + libsForQt5.qt5.wrapQtAppsHook + ]; + + configurePhase = '' + qmake + ''; + + installPhase = '' + mkdir -p $out/bin + cp dragger $out/bin + ''; + }; + }; + }; +} From ee35d1098c1cbbc568e2e99717203c73bda09aa2 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:31:01 +0200 Subject: [PATCH 10/12] nix: add direnv integration --- .envrc | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 .envrc diff --git a/.envrc b/.envrc new file mode 100644 index 0000000..c4f5ea4 --- /dev/null +++ b/.envrc @@ -0,0 +1,7 @@ +use_flake() { + watch_file flake.nix + watch_file flake.lock + eval "$(nix print-dev-env)" +} + +use flake From c420e3cecf3d5798ac8301827df3314fcb21d638 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:31:08 +0200 Subject: [PATCH 11/12] git: add ignore file --- .gitignore | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1e2d53d --- /dev/null +++ b/.gitignore @@ -0,0 +1,7 @@ +# Nix files +/result +/.pre-commit-config.yaml + +# Qt files +/Makefile +/.qmake.stash From 60bdc7f865ddf4d7c627d8abe787b7fdcbabdd67 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 8 Oct 2021 14:38:31 +0200 Subject: [PATCH 12/12] project: add README --- README.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..93cc1a8 --- /dev/null +++ b/README.md @@ -0,0 +1,14 @@ +# `dragger` + +Drag files from CLI, without the need to open a GUI. + +## Usage + +Simply issue the command: + +```bash +dragger [FILES...] +``` + +`dragger` will initiate a drag-and-drop operation for all files and directories +provided as arguments.