From d5f15b4c9f39e928477435f08d4bd985521b7cbb Mon Sep 17 00:00:00 2001 From: Kevin Kim Date: Wed, 3 Mar 2021 17:59:06 +0900 Subject: [PATCH] Apply albert 0.17.2 --- CHANGELOG.md | 503 ++ CMakeLists.txt | 9 +- HOWTO-BUILD-on-HamoniKR | 11 + README.md | 40 +- albert.png | Bin 0 -> 214448 bytes .../api/v1/query/client-vscode/query.json | 1 + .../reply/cache-v2-28e5adba9cf517f214a6.json | 2827 +++++++++++ .../codemodel-v2-6f44fa020fe1e9d16097.json | 899 ++++ .../reply/index-2021-03-03T07-46-18-0196.json | 87 + ...albert-bin-Debug-7b459d6ec10f68da7772.json | 599 +++ ...in_autogen-Debug-3838f4f70dd823832bb1.json | 73 + ...albert-lib-Debug-8db5dd15c22e3963d38a.json | 445 ++ ...ib_autogen-Debug-7964369b2bfc7ce58464.json | 58 + ...plications-Debug-b6a503d5f7e0da8acd92.json | 353 ++ ...ns_autogen-Debug-cb64350108dd6caadb07.json | 69 + ...calculator-Debug-63f5e9aeb5d7170c34ad.json | 343 ++ ...or_autogen-Debug-e1a7ee154105a90a9598.json | 69 + ...t-chromium-Debug-eb58aca63d326f9cd32a.json | 339 ++ ...um_autogen-Debug-7bef17168f2f1f098d4d.json | 69 + ...rget-files-Debug-e2a0c74573009c6a484c.json | 429 ++ ...es_autogen-Debug-257c34759125ae096081.json | 69 + ...xbookmarks-Debug-cbc31ae4c17d7f085b18.json | 367 ++ ...ks_autogen-Debug-0d3eb7486a6df8f9cb80.json | 69 + ...alshortcut-Debug-badd0b9c45654272e2b3.json | 231 + ...ut_autogen-Debug-e4db85e552bffa8f4e38.json | 58 + ...hgenerator-Debug-f3558c8d8f359af0cad2.json | 326 ++ ...or_autogen-Debug-4107c9cc6744e872a629.json | 65 + ...rget-mpris-Debug-8a4fd6fcff6e8820f881.json | 387 ++ ...is_autogen-Debug-0cc090612bbde4c03453.json | 69 + ...get-python-Debug-f77de8707e8cfe54cf31.json | 387 ++ ...on_autogen-Debug-badd377ce3a43cab4366.json | 69 + ...mlboxmodel-Debug-d1cfef91b55d73c45ca2.json | 377 ++ ...el_autogen-Debug-3b9bb69b44fa2f8899f8.json | 65 + ...t-snippets-Debug-592a4a47608f3fe646a9.json | 360 ++ ...ts_autogen-Debug-2a85aa502105ffa79438.json | 65 + ...target-ssh-Debug-d6ba80dcda563e3c5bbe.json | 339 ++ ...sh_autogen-Debug-897694006d25d5cfae79.json | 69 + ...get-system-Debug-3f993ac8a3518ff720d3.json | 339 ++ ...em_autogen-Debug-df93704b5e5861b87871.json | 69 + ...t-terminal-Debug-0788d0c17b1c71fa7f78.json | 333 ++ ...al_autogen-Debug-4ba46e7bf76893be01e2.json | 69 + ...-websearch-Debug-0d09017a05cb8ea08500.json | 379 ++ ...ch_autogen-Debug-bab073aee85906c1cc90.json | 69 + ...etboxmodel-Debug-ee0344ebcdf0a1121825.json | 406 ++ ...el_autogen-Debug-823c04e1ca30b858ad8f.json | 65 + ...target-xdg-Debug-bae64f9e564c6982ae44.json | 275 ++ ...dg_autogen-Debug-e6ee28ce63fc23da9185.json | 58 + build/CMakeCache.txt | 768 +++ build/CMakeFiles/3.16.3/CMakeCCompiler.cmake | 76 + .../CMakeFiles/3.16.3/CMakeCXXCompiler.cmake | 88 + .../3.16.3/CMakeDetermineCompilerABI_C.bin | Bin 0 -> 16552 bytes .../3.16.3/CMakeDetermineCompilerABI_CXX.bin | Bin 0 -> 16560 bytes build/CMakeFiles/3.16.3/CMakeSystem.cmake | 15 + .../3.16.3/CompilerIdC/CMakeCCompilerId.c | 671 +++ build/CMakeFiles/3.16.3/CompilerIdC/a.out | Bin 0 -> 16712 bytes .../CompilerIdCXX/CMakeCXXCompilerId.cpp | 660 +++ build/CMakeFiles/3.16.3/CompilerIdCXX/a.out | Bin 0 -> 16720 bytes .../CMakeDirectoryInformation.cmake | 16 + build/CMakeFiles/CMakeOutput.log | 478 ++ build/CMakeFiles/CMakeRuleHashes.txt | 34 + build/CMakeFiles/Makefile.cmake | 231 + build/CMakeFiles/Makefile2 | 1562 ++++++ build/CMakeFiles/TargetDirectories.txt | 158 + .../albert-bin.dir/DependInfo.cmake | 70 + build/CMakeFiles/albert-bin.dir/build.make | 334 ++ .../albert-bin.dir/cmake_clean.cmake | 28 + build/CMakeFiles/albert-bin.dir/depend.make | 2 + build/CMakeFiles/albert-bin.dir/flags.make | 10 + build/CMakeFiles/albert-bin.dir/link.txt | 1 + build/CMakeFiles/albert-bin.dir/progress.make | 18 + .../AutoRcc_resources_EWIEGA46WW_Info.json | 27 + .../albert-bin_autogen.dir/AutogenInfo.json | 192 + .../albert-bin_autogen.dir/DependInfo.cmake | 11 + .../albert-bin_autogen.dir/build.make | 77 + .../albert-bin_autogen.dir/cmake_clean.cmake | 9 + .../albert-bin_autogen.dir/progress.make | 2 + .../albert-lib.dir/DependInfo.cmake | 51 + build/CMakeFiles/albert-lib.dir/build.make | 236 + .../albert-lib.dir/cmake_clean.cmake | 22 + build/CMakeFiles/albert-lib.dir/depend.make | 2 + build/CMakeFiles/albert-lib.dir/flags.make | 10 + build/CMakeFiles/albert-lib.dir/link.txt | 1 + build/CMakeFiles/albert-lib.dir/progress.make | 12 + .../albert-lib_autogen.dir/AutogenInfo.json | 211 + .../albert-lib_autogen.dir/DependInfo.cmake | 11 + .../albert-lib_autogen.dir/build.make | 77 + .../albert-lib_autogen.dir/cmake_clean.cmake | 9 + .../albert-lib_autogen.dir/progress.make | 2 + build/CMakeFiles/cmake.check_cache | 1 + build/CMakeFiles/progress.marks | 1 + build/Makefile | 1466 ++++++ build/cmake_install.cmake | 112 + build/compile_commands.json | 532 +++ .../CMakeDirectoryInformation.cmake | 16 + .../globalshortcut.dir/DependInfo.cmake | 42 + .../CMakeFiles/globalshortcut.dir/build.make | 129 + .../globalshortcut.dir/cmake_clean.cmake | 15 + .../cmake_clean_target.cmake | 3 + .../CMakeFiles/globalshortcut.dir/depend.make | 2 + .../CMakeFiles/globalshortcut.dir/flags.make | 10 + .../CMakeFiles/globalshortcut.dir/link.txt | 2 + .../globalshortcut.dir/progress.make | 5 + .../AutogenInfo.json | 101 + .../DependInfo.cmake | 11 + .../globalshortcut_autogen.dir/build.make | 77 + .../cmake_clean.cmake | 9 + .../globalshortcut_autogen.dir/progress.make | 2 + .../globalshortcut/CMakeFiles/progress.marks | 1 + build/lib/globalshortcut/Makefile | 306 ++ build/lib/globalshortcut/cmake_install.cmake | 39 + .../CMakeDirectoryInformation.cmake | 16 + build/lib/xdg/CMakeFiles/progress.marks | 1 + .../xdg/CMakeFiles/xdg.dir/DependInfo.cmake | 41 + build/lib/xdg/CMakeFiles/xdg.dir/build.make | 130 + .../xdg/CMakeFiles/xdg.dir/cmake_clean.cmake | 15 + build/lib/xdg/CMakeFiles/xdg.dir/depend.make | 2 + build/lib/xdg/CMakeFiles/xdg.dir/flags.make | 10 + build/lib/xdg/CMakeFiles/xdg.dir/link.txt | 1 + .../lib/xdg/CMakeFiles/xdg.dir/progress.make | 5 + .../xdg_autogen.dir/AutogenInfo.json | 100 + .../xdg_autogen.dir/DependInfo.cmake | 11 + .../xdg/CMakeFiles/xdg_autogen.dir/build.make | 77 + .../xdg_autogen.dir/cmake_clean.cmake | 9 + .../CMakeFiles/xdg_autogen.dir/progress.make | 2 + build/lib/xdg/Makefile | 306 ++ build/lib/xdg/cmake_install.cmake | 58 + .../CMakeDirectoryInformation.cmake | 16 + build/plugins/CMakeFiles/progress.marks | 1 + build/plugins/Makefile | 184 + .../CMakeDirectoryInformation.cmake | 16 + .../applications.dir/DependInfo.cmake | 47 + .../CMakeFiles/applications.dir/build.make | 156 + .../applications.dir/cmake_clean.cmake | 17 + .../CMakeFiles/applications.dir/depend.make | 2 + .../CMakeFiles/applications.dir/flags.make | 10 + .../CMakeFiles/applications.dir/link.txt | 1 + .../CMakeFiles/applications.dir/progress.make | 7 + .../AutoRcc_applications_EWIEGA46WW_Info.json | 22 + .../applications_autogen.dir/AutogenInfo.json | 98 + .../applications_autogen.dir/DependInfo.cmake | 11 + .../applications_autogen.dir/build.make | 77 + .../cmake_clean.cmake | 9 + .../applications_autogen.dir/progress.make | 2 + .../applications/CMakeFiles/progress.marks | 1 + build/plugins/applications/Makefile | 336 ++ .../plugins/applications/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../calculator.dir/DependInfo.cmake | 45 + .../CMakeFiles/calculator.dir/build.make | 155 + .../calculator.dir/cmake_clean.cmake | 17 + .../CMakeFiles/calculator.dir/depend.make | 2 + .../CMakeFiles/calculator.dir/flags.make | 10 + .../CMakeFiles/calculator.dir/link.txt | 1 + .../CMakeFiles/calculator.dir/progress.make | 7 + .../AutoRcc_calculator_EWIEGA46WW_Info.json | 22 + .../calculator_autogen.dir/AutogenInfo.json | 96 + .../calculator_autogen.dir/DependInfo.cmake | 11 + .../calculator_autogen.dir/build.make | 77 + .../calculator_autogen.dir/cmake_clean.cmake | 9 + .../calculator_autogen.dir/progress.make | 2 + .../calculator/CMakeFiles/progress.marks | 1 + build/plugins/calculator/Makefile | 336 ++ build/plugins/calculator/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../CMakeFiles/chromium.dir/DependInfo.cmake | 46 + .../CMakeFiles/chromium.dir/build.make | 141 + .../CMakeFiles/chromium.dir/cmake_clean.cmake | 16 + .../CMakeFiles/chromium.dir/depend.make | 2 + .../CMakeFiles/chromium.dir/flags.make | 10 + .../chromium/CMakeFiles/chromium.dir/link.txt | 1 + .../CMakeFiles/chromium.dir/progress.make | 6 + .../AutoRcc_chromium_EWIEGA46WW_Info.json | 22 + .../chromium_autogen.dir/AutogenInfo.json | 89 + .../chromium_autogen.dir/DependInfo.cmake | 11 + .../chromium_autogen.dir/build.make | 77 + .../chromium_autogen.dir/cmake_clean.cmake | 9 + .../chromium_autogen.dir/progress.make | 2 + .../chromium/CMakeFiles/progress.marks | 1 + build/plugins/chromium/Makefile | 306 ++ build/plugins/chromium/cmake_install.cmake | 62 + build/plugins/cmake_install.cmake | 59 + .../CMakeDirectoryInformation.cmake | 16 + .../CMakeFiles/files.dir/DependInfo.cmake | 52 + .../files/CMakeFiles/files.dir/build.make | 231 + .../CMakeFiles/files.dir/cmake_clean.cmake | 22 + .../files/CMakeFiles/files.dir/depend.make | 2 + .../files/CMakeFiles/files.dir/flags.make | 10 + .../files/CMakeFiles/files.dir/link.txt | 1 + .../files/CMakeFiles/files.dir/progress.make | 12 + .../AutoRcc_files_EWIEGA46WW_Info.json | 22 + .../files_autogen.dir/AutogenInfo.json | 143 + .../files_autogen.dir/DependInfo.cmake | 11 + .../CMakeFiles/files_autogen.dir/build.make | 77 + .../files_autogen.dir/cmake_clean.cmake | 9 + .../files_autogen.dir/progress.make | 2 + build/plugins/files/CMakeFiles/progress.marks | 1 + build/plugins/files/Makefile | 486 ++ build/plugins/files/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../firefoxbookmarks.dir/DependInfo.cmake | 49 + .../firefoxbookmarks.dir/build.make | 157 + .../firefoxbookmarks.dir/cmake_clean.cmake | 17 + .../firefoxbookmarks.dir/depend.make | 2 + .../firefoxbookmarks.dir/flags.make | 10 + .../CMakeFiles/firefoxbookmarks.dir/link.txt | 1 + .../firefoxbookmarks.dir/progress.make | 7 + ...oRcc_firefoxbookmarks_EWIEGA46WW_Info.json | 22 + .../AutogenInfo.json | 100 + .../DependInfo.cmake | 11 + .../firefoxbookmarks_autogen.dir/build.make | 77 + .../cmake_clean.cmake | 9 + .../progress.make | 2 + .../CMakeFiles/progress.marks | 1 + build/plugins/firefoxbookmarks/Makefile | 336 ++ .../firefoxbookmarks/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../hashgenerator.dir/DependInfo.cmake | 43 + .../CMakeFiles/hashgenerator.dir/build.make | 154 + .../hashgenerator.dir/cmake_clean.cmake | 17 + .../CMakeFiles/hashgenerator.dir/depend.make | 2 + .../CMakeFiles/hashgenerator.dir/flags.make | 10 + .../CMakeFiles/hashgenerator.dir/link.txt | 1 + .../hashgenerator.dir/progress.make | 7 + ...AutoRcc_hashgenerator_EWIEGA46WW_Info.json | 22 + .../AutogenInfo.json | 95 + .../DependInfo.cmake | 11 + .../hashgenerator_autogen.dir/build.make | 77 + .../cmake_clean.cmake | 9 + .../hashgenerator_autogen.dir/progress.make | 2 + .../hashgenerator/CMakeFiles/progress.marks | 1 + build/plugins/hashgenerator/Makefile | 336 ++ .../plugins/hashgenerator/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../CMakeFiles/mpris.dir/DependInfo.cmake | 49 + .../mpris/CMakeFiles/mpris.dir/build.make | 190 + .../CMakeFiles/mpris.dir/cmake_clean.cmake | 19 + .../mpris/CMakeFiles/mpris.dir/depend.make | 2 + .../mpris/CMakeFiles/mpris.dir/flags.make | 10 + .../mpris/CMakeFiles/mpris.dir/link.txt | 1 + .../mpris/CMakeFiles/mpris.dir/progress.make | 9 + .../AutoRcc_mpris_EWIEGA46WW_Info.json | 26 + .../mpris_autogen.dir/AutogenInfo.json | 121 + .../mpris_autogen.dir/DependInfo.cmake | 11 + .../CMakeFiles/mpris_autogen.dir/build.make | 77 + .../mpris_autogen.dir/cmake_clean.cmake | 9 + .../mpris_autogen.dir/progress.make | 2 + build/plugins/mpris/CMakeFiles/progress.marks | 1 + build/plugins/mpris/Makefile | 396 ++ build/plugins/mpris/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../plugins/python/CMakeFiles/progress.marks | 1 + .../CMakeFiles/python.dir/DependInfo.cmake | 49 + .../python/CMakeFiles/python.dir/build.make | 186 + .../CMakeFiles/python.dir/cmake_clean.cmake | 19 + .../python/CMakeFiles/python.dir/depend.make | 2 + .../python/CMakeFiles/python.dir/flags.make | 10 + .../python/CMakeFiles/python.dir/link.txt | 1 + .../CMakeFiles/python.dir/progress.make | 9 + .../AutoRcc_python_EWIEGA46WW_Info.json | 22 + .../python_autogen.dir/AutogenInfo.json | 121 + .../python_autogen.dir/DependInfo.cmake | 11 + .../CMakeFiles/python_autogen.dir/build.make | 77 + .../python_autogen.dir/cmake_clean.cmake | 9 + .../python_autogen.dir/progress.make | 2 + build/plugins/python/Makefile | 396 ++ build/plugins/python/cmake_install.cmake | 72 + .../CMakeDirectoryInformation.cmake | 16 + .../python/pybind11/CMakeFiles/progress.marks | 1 + build/plugins/python/pybind11/Makefile | 184 + .../python/pybind11/cmake_install.cmake | 39 + .../CMakeDirectoryInformation.cmake | 16 + .../qmlboxmodel/CMakeFiles/progress.marks | 1 + .../qmlboxmodel.dir/DependInfo.cmake | 50 + .../CMakeFiles/qmlboxmodel.dir/build.make | 165 + .../qmlboxmodel.dir/cmake_clean.cmake | 17 + .../CMakeFiles/qmlboxmodel.dir/depend.make | 2 + .../CMakeFiles/qmlboxmodel.dir/flags.make | 10 + .../CMakeFiles/qmlboxmodel.dir/link.txt | 1 + .../CMakeFiles/qmlboxmodel.dir/progress.make | 7 + .../qmlboxmodel_autogen.dir/AutogenInfo.json | 124 + .../qmlboxmodel_autogen.dir/DependInfo.cmake | 11 + .../qmlboxmodel_autogen.dir/build.make | 77 + .../qmlboxmodel_autogen.dir/cmake_clean.cmake | 9 + .../qmlboxmodel_autogen.dir/progress.make | 2 + build/plugins/qmlboxmodel/Makefile | 366 ++ build/plugins/qmlboxmodel/cmake_install.cmake | 66 + .../CMakeDirectoryInformation.cmake | 16 + .../snippets/CMakeFiles/progress.marks | 1 + .../CMakeFiles/snippets.dir/DependInfo.cmake | 46 + .../CMakeFiles/snippets.dir/build.make | 170 + .../CMakeFiles/snippets.dir/cmake_clean.cmake | 18 + .../CMakeFiles/snippets.dir/depend.make | 2 + .../CMakeFiles/snippets.dir/flags.make | 10 + .../snippets/CMakeFiles/snippets.dir/link.txt | 1 + .../CMakeFiles/snippets.dir/progress.make | 8 + .../AutoRcc_snippets_EWIEGA46WW_Info.json | 22 + .../snippets_autogen.dir/AutogenInfo.json | 106 + .../snippets_autogen.dir/DependInfo.cmake | 11 + .../snippets_autogen.dir/build.make | 77 + .../snippets_autogen.dir/cmake_clean.cmake | 9 + .../snippets_autogen.dir/progress.make | 2 + build/plugins/snippets/Makefile | 366 ++ build/plugins/snippets/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + build/plugins/ssh/CMakeFiles/progress.marks | 1 + .../ssh/CMakeFiles/ssh.dir/DependInfo.cmake | 45 + .../plugins/ssh/CMakeFiles/ssh.dir/build.make | 155 + .../ssh/CMakeFiles/ssh.dir/cmake_clean.cmake | 17 + .../ssh/CMakeFiles/ssh.dir/depend.make | 2 + .../plugins/ssh/CMakeFiles/ssh.dir/flags.make | 10 + build/plugins/ssh/CMakeFiles/ssh.dir/link.txt | 1 + .../ssh/CMakeFiles/ssh.dir/progress.make | 7 + .../AutoRcc_ssh_EWIEGA46WW_Info.json | 22 + .../ssh_autogen.dir/AutogenInfo.json | 96 + .../ssh_autogen.dir/DependInfo.cmake | 11 + .../ssh/CMakeFiles/ssh_autogen.dir/build.make | 77 + .../ssh_autogen.dir/cmake_clean.cmake | 9 + .../CMakeFiles/ssh_autogen.dir/progress.make | 2 + build/plugins/ssh/Makefile | 336 ++ build/plugins/ssh/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../plugins/system/CMakeFiles/progress.marks | 1 + .../CMakeFiles/system.dir/DependInfo.cmake | 45 + .../system/CMakeFiles/system.dir/build.make | 160 + .../CMakeFiles/system.dir/cmake_clean.cmake | 17 + .../system/CMakeFiles/system.dir/depend.make | 2 + .../system/CMakeFiles/system.dir/flags.make | 10 + .../system/CMakeFiles/system.dir/link.txt | 1 + .../CMakeFiles/system.dir/progress.make | 7 + .../AutoRcc_system_EWIEGA46WW_Info.json | 27 + .../system_autogen.dir/AutogenInfo.json | 96 + .../system_autogen.dir/DependInfo.cmake | 11 + .../CMakeFiles/system_autogen.dir/build.make | 77 + .../system_autogen.dir/cmake_clean.cmake | 9 + .../system_autogen.dir/progress.make | 2 + build/plugins/system/Makefile | 336 ++ build/plugins/system/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../terminal/CMakeFiles/progress.marks | 1 + .../CMakeFiles/terminal.dir/DependInfo.cmake | 46 + .../CMakeFiles/terminal.dir/build.make | 141 + .../CMakeFiles/terminal.dir/cmake_clean.cmake | 16 + .../CMakeFiles/terminal.dir/depend.make | 2 + .../CMakeFiles/terminal.dir/flags.make | 10 + .../terminal/CMakeFiles/terminal.dir/link.txt | 1 + .../CMakeFiles/terminal.dir/progress.make | 6 + .../AutoRcc_terminal_EWIEGA46WW_Info.json | 22 + .../terminal_autogen.dir/AutogenInfo.json | 89 + .../terminal_autogen.dir/DependInfo.cmake | 11 + .../terminal_autogen.dir/build.make | 77 + .../terminal_autogen.dir/cmake_clean.cmake | 9 + .../terminal_autogen.dir/progress.make | 2 + build/plugins/terminal/Makefile | 306 ++ build/plugins/terminal/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../websearch/CMakeFiles/progress.marks | 1 + .../CMakeFiles/websearch.dir/DependInfo.cmake | 47 + .../CMakeFiles/websearch.dir/build.make | 193 + .../websearch.dir/cmake_clean.cmake | 19 + .../CMakeFiles/websearch.dir/depend.make | 2 + .../CMakeFiles/websearch.dir/flags.make | 10 + .../CMakeFiles/websearch.dir/link.txt | 1 + .../CMakeFiles/websearch.dir/progress.make | 9 + .../AutoRcc_websearch_EWIEGA46WW_Info.json | 30 + .../websearch_autogen.dir/AutogenInfo.json | 119 + .../websearch_autogen.dir/DependInfo.cmake | 11 + .../websearch_autogen.dir/build.make | 77 + .../websearch_autogen.dir/cmake_clean.cmake | 9 + .../websearch_autogen.dir/progress.make | 2 + build/plugins/websearch/Makefile | 396 ++ build/plugins/websearch/cmake_install.cmake | 62 + .../CMakeDirectoryInformation.cmake | 16 + .../widgetboxmodel/CMakeFiles/progress.marks | 1 + .../widgetboxmodel.dir/DependInfo.cmake | 51 + .../CMakeFiles/widgetboxmodel.dir/build.make | 209 + .../widgetboxmodel.dir/cmake_clean.cmake | 20 + .../CMakeFiles/widgetboxmodel.dir/depend.make | 2 + .../CMakeFiles/widgetboxmodel.dir/flags.make | 10 + .../CMakeFiles/widgetboxmodel.dir/link.txt | 1 + .../widgetboxmodel.dir/progress.make | 10 + .../AutogenInfo.json | 144 + .../DependInfo.cmake | 11 + .../widgetboxmodel_autogen.dir/build.make | 77 + .../cmake_clean.cmake | 9 + .../widgetboxmodel_autogen.dir/progress.make | 2 + build/plugins/widgetboxmodel/Makefile | 456 ++ .../widgetboxmodel/cmake_install.cmake | 66 + debian/changelog | 15 +- debian/compat | 2 +- debian/control | 19 +- debian/postinst | 11 + debian/rules | 11 +- debian/source/format | 1 + hamonikr/albert.desktop | 13 + hamonikr/etc/skel/.config/albert/albert.conf | 21 + hamonikr/etc/skel/.config/albert/core.db | Bin 0 -> 32768 bytes .../etc/skel/.config/albert/last_used_version | 1 + .../engines.json | 32 + hamonikr/etc/xdg/autostart/albert.desktop | 15 + include/albert/action.h | 2 +- include/albert/indexable.h | 2 + include/albert/item.h | 9 +- include/albert/query.h | 10 +- include/albert/util/shutil.h | 16 - include/albert/util/standardactions.h | 105 +- include/albert/util/standardindexitem.h | 37 +- include/albert/util/standarditem.h | 31 +- lib/globalshortcut/CMakeLists.txt | 13 +- lib/globalshortcut/src/hotkeymanager.cpp | 2 +- lib/xdg/include/xdg/iconlookup.h | 15 +- lib/xdg/src/iconlookup.cpp | 80 +- metatool | 158 + .../externalextensions/CMakeLists.txt | 0 plugins/.archive/externalextensions/README.md | 94 + .../externalextensions/metadata.json | 0 .../externalextensions/src/configwidget.cpp | 0 .../externalextensions/src/configwidget.h | 0 .../externalextensions/src/configwidget.ui | 2 +- .../externalextensions/src/extension.cpp | 6 +- .../externalextensions/src/extension.h | 2 + .../src/externalextension.cpp | 0 .../src/externalextension.h | 0 .../src/externalextensionmodel.cpp | 0 .../src/externalextensionmodel.h | 0 plugins/CMakeLists.txt | 9 +- plugins/README.md | 62 + plugins/applications/README.md | 7 + plugins/applications/metadata.json | 6 +- plugins/applications/src/configwidget.cpp | 4 - plugins/applications/src/extension.cpp | 207 +- plugins/applications/src/extension.h | 5 +- plugins/calculator/README.md | 72 + plugins/calculator/metadata.json | 4 +- plugins/calculator/src/configwidget.ui | 9 +- plugins/calculator/src/extension.cpp | 118 +- plugins/calculator/src/extension.h | 9 +- plugins/chromebookmarks/metadata.json | 10 - plugins/chromebookmarks/src/configwidget.cpp | 25 - plugins/chromebookmarks/src/configwidget.h | 23 - plugins/chromebookmarks/src/configwidget.ui | 95 - plugins/chromebookmarks/src/extension.cpp | 336 -- .../CMakeLists.txt | 2 +- plugins/chromium/README.md | 3 + .../chromium.qrc} | 0 plugins/chromium/metadata.json | 10 + .../resources/favicon.png | Bin .../src/configwidget.ui | 21 +- plugins/chromium/src/extension.cpp | 270 ++ .../src/extension.h | 21 +- plugins/debug/CMakeLists.txt | 2 +- plugins/debug/src/extension.cpp | 17 +- plugins/debug/src/extension.h | 2 + plugins/files/README.md | 64 + plugins/files/src/extension.cpp | 73 +- plugins/files/src/extension.h | 3 +- plugins/files/src/file.cpp | 32 +- plugins/files/src/mimetypedialog.ui | 2 +- plugins/firefoxbookmarks/metadata.json | 2 +- plugins/firefoxbookmarks/src/configwidget.ui | 60 +- plugins/firefoxbookmarks/src/extension.cpp | 188 +- plugins/firefoxbookmarks/src/extension.h | 5 +- plugins/hashgenerator/src/extension.cpp | 19 +- plugins/hashgenerator/src/extension.h | 2 + plugins/mpris/README.md | 18 + plugins/mpris/src/extension.cpp | 11 +- plugins/mpris/src/extension.h | 2 + plugins/mpris/src/item.cpp | 4 +- plugins/python/README.md | 204 + plugins/python/metadata.json | 6 +- plugins/python/pybind11/.appveyor.yml | 52 +- plugins/python/pybind11/.clang-tidy | 13 + plugins/python/pybind11/.cmake-format.yaml | 73 + .../python/pybind11/.github/CONTRIBUTING.md | 319 ++ .../.github/ISSUE_TEMPLATE/bug-report.md | 28 + .../.github/ISSUE_TEMPLATE/config.yml | 5 + .../.github/ISSUE_TEMPLATE/feature-request.md | 16 + .../.github/ISSUE_TEMPLATE/question.md | 21 + .../python/pybind11/.github/dependabot.yml | 11 + plugins/python/pybind11/.github/labeler.yml | 8 + .../pybind11/.github/labeler_merged.yml | 3 + .../pybind11/.github/pull_request_template.md | 14 + .../python/pybind11/.github/workflows/ci.yml | 676 +++ .../pybind11/.github/workflows/configure.yml | 84 + .../pybind11/.github/workflows/format.yml | 46 + .../pybind11/.github/workflows/labeler.yml | 16 + .../python/pybind11/.github/workflows/pip.yml | 103 + plugins/python/pybind11/.gitmodules | 3 - .../python/pybind11/.pre-commit-config.yaml | 100 + plugins/python/pybind11/.travis.yml | 212 - plugins/python/pybind11/CMakeLists.txt | 349 +- plugins/python/pybind11/CONTRIBUTING.md | 47 - plugins/python/pybind11/ISSUE_TEMPLATE.md | 17 - plugins/python/pybind11/LICENSE | 2 +- plugins/python/pybind11/MANIFEST.in | 8 +- plugins/python/pybind11/README.md | 129 - plugins/python/pybind11/README.rst | 175 + plugins/python/pybind11/docs/Doxyfile | 3 + .../pybind11/docs/advanced/cast/chrono.rst | 2 +- .../pybind11/docs/advanced/cast/custom.rst | 6 +- .../pybind11/docs/advanced/cast/eigen.rst | 12 +- .../pybind11/docs/advanced/cast/index.rst | 3 +- .../pybind11/docs/advanced/cast/overview.rst | 2 + .../pybind11/docs/advanced/cast/stl.rst | 7 +- .../python/pybind11/docs/advanced/classes.rst | 354 +- .../pybind11/docs/advanced/embedding.rst | 16 +- .../pybind11/docs/advanced/exceptions.rst | 258 +- .../pybind11/docs/advanced/functions.rst | 75 +- .../python/pybind11/docs/advanced/misc.rst | 105 +- .../pybind11/docs/advanced/pycpp/numpy.rst | 106 +- .../pybind11/docs/advanced/pycpp/object.rst | 95 +- .../docs/advanced/pycpp/utilities.rst | 4 +- plugins/python/pybind11/docs/basics.rst | 22 +- plugins/python/pybind11/docs/benchmark.py | 38 +- plugins/python/pybind11/docs/benchmark.rst | 2 - plugins/python/pybind11/docs/changelog.rst | 511 +- plugins/python/pybind11/docs/classes.rst | 48 +- plugins/python/pybind11/docs/cmake/index.rst | 8 + plugins/python/pybind11/docs/compiling.rst | 463 +- plugins/python/pybind11/docs/conf.py | 243 +- plugins/python/pybind11/docs/faq.rst | 156 +- plugins/python/pybind11/docs/index.rst | 13 +- plugins/python/pybind11/docs/installing.rst | 103 + plugins/python/pybind11/docs/intro.rst | 95 - plugins/python/pybind11/docs/limitations.rst | 62 +- plugins/python/pybind11/docs/reference.rst | 17 +- plugins/python/pybind11/docs/release.rst | 94 +- plugins/python/pybind11/docs/requirements.txt | 8 +- plugins/python/pybind11/docs/upgrade.rst | 108 + .../python/pybind11/include/pybind11/attr.h | 86 +- .../pybind11/include/pybind11/buffer_info.h | 80 +- .../python/pybind11/include/pybind11/cast.h | 410 +- .../python/pybind11/include/pybind11/chrono.h | 63 +- .../pybind11/include/pybind11/complex.h | 12 +- .../pybind11/include/pybind11/detail/class.h | 152 +- .../pybind11/include/pybind11/detail/common.h | 246 +- .../pybind11/include/pybind11/detail/descr.h | 207 +- .../pybind11/include/pybind11/detail/init.h | 15 +- .../include/pybind11/detail/internals.h | 166 +- .../pybind11/include/pybind11/detail/typeid.h | 10 +- .../python/pybind11/include/pybind11/eigen.h | 77 +- .../python/pybind11/include/pybind11/embed.h | 61 +- .../python/pybind11/include/pybind11/eval.h | 41 +- .../pybind11/include/pybind11/functional.h | 45 +- .../pybind11/include/pybind11/iostream.h | 58 +- .../python/pybind11/include/pybind11/numpy.h | 358 +- .../pybind11/include/pybind11/operators.h | 13 +- .../pybind11/include/pybind11/options.h | 4 +- .../pybind11/include/pybind11/pybind11.h | 925 +++- .../pybind11/include/pybind11/pytypes.h | 459 +- .../python/pybind11/include/pybind11/stl.h | 54 +- .../pybind11/include/pybind11/stl_bind.h | 138 +- plugins/python/pybind11/pybind11/__init__.py | 34 +- plugins/python/pybind11/pybind11/__main__.py | 37 +- plugins/python/pybind11/pybind11/_version.py | 14 +- plugins/python/pybind11/pybind11/_version.pyi | 6 + plugins/python/pybind11/pybind11/commands.py | 22 + plugins/python/pybind11/pybind11/py.typed | 0 .../python/pybind11/pybind11/setup_helpers.py | 436 ++ .../pybind11/pybind11/setup_helpers.pyi | 61 + plugins/python/pybind11/pyproject.toml | 3 + plugins/python/pybind11/setup.cfg | 63 +- plugins/python/pybind11/setup.py | 211 +- plugins/python/pybind11/tests/CMakeLists.txt | 389 +- plugins/python/pybind11/tests/conftest.py | 107 +- .../python/pybind11/tests/constructor_stats.h | 5 +- .../pybind11/tests/cross_module_gil_utils.cpp | 73 + plugins/python/pybind11/tests/env.py | 14 + .../tests/extra_python_package/pytest.ini | 0 .../tests/extra_python_package/test_files.py | 262 ++ .../tests/extra_setuptools/pytest.ini | 0 .../extra_setuptools/test_setuphelper.py | 101 + .../python/pybind11/tests/local_bindings.h | 2 +- .../python/pybind11/tests/pybind11_tests.cpp | 12 +- .../python/pybind11/tests/pybind11_tests.h | 20 +- plugins/python/pybind11/tests/pytest.ini | 8 +- .../python/pybind11/tests/requirements.txt | 8 + plugins/python/pybind11/tests/test_async.cpp | 26 + plugins/python/pybind11/tests/test_async.py | 25 + .../python/pybind11/tests/test_buffers.cpp | 73 +- plugins/python/pybind11/tests/test_buffers.py | 113 +- .../pybind11/tests/test_builtin_casters.cpp | 38 +- .../pybind11/tests/test_builtin_casters.py | 226 +- .../pybind11/tests/test_call_policies.cpp | 19 +- .../pybind11/tests/test_call_policies.py | 91 +- .../python/pybind11/tests/test_callbacks.cpp | 25 +- .../python/pybind11/tests/test_callbacks.py | 61 +- plugins/python/pybind11/tests/test_chrono.cpp | 37 + plugins/python/pybind11/tests/test_chrono.py | 129 +- plugins/python/pybind11/tests/test_class.cpp | 165 +- plugins/python/pybind11/tests/test_class.py | 256 +- .../tests/test_cmake_build/CMakeLists.txt | 83 +- .../pybind11/tests/test_cmake_build/embed.cpp | 4 +- .../installed_embed/CMakeLists.txt | 23 +- .../installed_function/CMakeLists.txt | 38 +- .../installed_target/CMakeLists.txt | 45 +- .../subdirectory_embed/CMakeLists.txt | 38 +- .../subdirectory_function/CMakeLists.txt | 38 +- .../subdirectory_target/CMakeLists.txt | 41 +- .../pybind11/tests/test_cmake_build/test.py | 1 + .../tests/test_constants_and_functions.cpp | 16 +- .../tests/test_constants_and_functions.py | 5 +- .../python/pybind11/tests/test_copy_move.cpp | 36 +- .../python/pybind11/tests/test_copy_move.py | 27 +- .../tests/test_custom_type_casters.cpp | 127 + .../tests/test_custom_type_casters.py | 116 + .../pybind11/tests/test_docstring_options.py | 11 +- plugins/python/pybind11/tests/test_eigen.cpp | 15 +- plugins/python/pybind11/tests/test_eigen.py | 316 +- .../pybind11/tests/test_embed/CMakeLists.txt | 44 +- .../tests/test_embed/test_interpreter.cpp | 52 +- .../tests/test_embed/test_interpreter.py | 1 + plugins/python/pybind11/tests/test_enum.cpp | 24 +- plugins/python/pybind11/tests/test_enum.py | 124 +- plugins/python/pybind11/tests/test_eval.cpp | 10 +- plugins/python/pybind11/tests/test_eval.py | 20 +- .../python/pybind11/tests/test_eval_call.py | 3 +- .../python/pybind11/tests/test_exceptions.cpp | 71 +- .../python/pybind11/tests/test_exceptions.py | 60 +- .../tests/test_factory_constructors.cpp | 20 +- .../tests/test_factory_constructors.py | 133 +- .../python/pybind11/tests/test_gil_scoped.cpp | 54 + .../python/pybind11/tests/test_gil_scoped.py | 94 + .../python/pybind11/tests/test_iostream.cpp | 8 +- .../python/pybind11/tests/test_iostream.py | 48 +- .../tests/test_kwargs_and_defaults.cpp | 48 +- .../tests/test_kwargs_and_defaults.py | 192 +- .../pybind11/tests/test_local_bindings.cpp | 2 +- .../pybind11/tests/test_local_bindings.py | 60 +- .../tests/test_methods_and_attributes.cpp | 171 +- .../tests/test_methods_and_attributes.py | 271 +- .../python/pybind11/tests/test_modules.cpp | 5 +- plugins/python/pybind11/tests/test_modules.py | 11 +- .../tests/test_multiple_inheritance.cpp | 8 +- .../tests/test_multiple_inheritance.py | 28 +- .../pybind11/tests/test_numpy_array.cpp | 192 +- .../python/pybind11/tests/test_numpy_array.py | 323 +- .../pybind11/tests/test_numpy_dtypes.cpp | 62 +- .../pybind11/tests/test_numpy_dtypes.py | 323 +- .../pybind11/tests/test_numpy_vectorize.cpp | 14 +- .../pybind11/tests/test_numpy_vectorize.py | 168 +- .../pybind11/tests/test_opaque_types.cpp | 18 +- .../pybind11/tests/test_opaque_types.py | 14 +- .../tests/test_operator_overloading.cpp | 82 +- .../tests/test_operator_overloading.py | 63 +- .../python/pybind11/tests/test_pickling.py | 13 +- .../python/pybind11/tests/test_pytypes.cpp | 151 +- plugins/python/pybind11/tests/test_pytypes.py | 288 +- .../tests/test_sequences_and_iterators.cpp | 26 +- .../tests/test_sequences_and_iterators.py | 65 +- .../python/pybind11/tests/test_smart_ptr.cpp | 46 +- .../python/pybind11/tests/test_smart_ptr.py | 78 +- plugins/python/pybind11/tests/test_stl.cpp | 72 +- plugins/python/pybind11/tests/test_stl.py | 94 +- .../pybind11/tests/test_stl_binders.cpp | 24 +- .../python/pybind11/tests/test_stl_binders.py | 170 +- .../tests/test_tagbased_polymorphic.cpp | 142 + .../tests/test_tagbased_polymorphic.py | 29 + plugins/python/pybind11/tests/test_union.cpp | 22 + plugins/python/pybind11/tests/test_union.py | 9 + .../pybind11/tests/test_virtual_functions.cpp | 102 +- .../pybind11/tests/test_virtual_functions.py | 72 +- plugins/python/pybind11/tools/FindCatch.cmake | 21 +- .../python/pybind11/tools/FindEigen3.cmake | 28 +- .../pybind11/tools/FindPythonLibsNew.cmake | 206 +- plugins/python/pybind11/tools/check-style.sh | 38 +- .../python/pybind11/tools/clang/LICENSE.TXT | 63 - plugins/python/pybind11/tools/clang/README.md | 2 - .../python/pybind11/tools/clang/__init__.py | 24 - plugins/python/pybind11/tools/clang/cindex.py | 3884 --------------- .../pybind11/tools/clang/enumerations.py | 34 - .../pybind11/tools/cmake_uninstall.cmake.in | 23 + plugins/python/pybind11/tools/libsize.py | 6 +- plugins/python/pybind11/tools/mkdoc.py | 304 -- .../pybind11/tools/pybind11Common.cmake | 393 ++ .../pybind11/tools/pybind11Config.cmake.in | 306 +- .../pybind11/tools/pybind11NewTools.cmake | 246 + .../python/pybind11/tools/pybind11Tools.cmake | 291 +- plugins/python/pybind11/tools/pyproject.toml | 3 + .../python/pybind11/tools/setup_global.py.in | 63 + .../python/pybind11/tools/setup_main.py.in | 36 + .../{ => .archive}/bitfinex/Bitfinex.svg | 0 .../{ => .archive}/bitfinex/__init__.py | 26 +- .../{ => .archive}/coinmarketcap/__init__.py | 25 +- .../coinmarketcap/emblem-money.svg | 0 .../{ => .archive}/dango_emoji/__init__.py | 35 +- .../{ => .archive}/dango_emoji/dangoemoji.png | Bin .../{ => .archive}/dango_kao/__init__.py | 27 +- .../{ => .archive}/dango_kao/kaoicon.svg | 0 .../modules/.archive/virtualbox/README.md | 20 + .../virtualbox/__init__.py} | 50 +- plugins/python/share/modules/.gitmodules | 6 + plugins/python/share/modules/README.md | 2 +- .../python/share/modules/api_test/__init__.py | 39 +- .../share/modules/arch_wiki/__init__.py | 31 +- .../__init__.py} | 26 +- plugins/python/share/modules/aur/__init__.py | 53 +- .../python/share/modules/base_converter.py | 61 - .../share/modules/base_converter/__init__.py | 74 + .../python/share/modules/binance/__init__.py | 28 +- .../share/modules/bitwarden/__init__.py | 93 + .../modules/{copyq.py => copyq/__init__.py} | 24 +- .../__init__.py} | 22 +- plugins/python/share/modules/datetime.py | 63 - .../python/share/modules/datetime/__init__.py | 83 + .../python/share/modules/docker/__init__.py | 83 + .../python/share/modules/docker/running.png | Bin 0 -> 1532 bytes .../python/share/modules/docker/stopped.png | Bin 0 -> 1549 bytes .../{fortune.py => fortune/__init__.py} | 26 +- .../python/share/modules/gnome_dictionary.py | 33 - .../modules/gnome_dictionary/__init__.py | 29 + .../modules/{tomboy.py => gnote/__init__.py} | 46 +- plugins/python/share/modules/goldendict.py | 31 - .../share/modules/goldendict/__init__.py | 26 + .../__init__.py} | 27 +- .../share/modules/{ip.py => ip/__init__.py} | 28 +- .../share/modules/jetbrains_projects/LICENSE | 674 +++ .../modules/jetbrains_projects/README.md | 39 + .../modules/jetbrains_projects/__init__.py | 57 +- .../modules/jetbrains_projects/jetbrains.svg | 2 +- .../modules/{kill.py => kill/__init__.py} | 19 +- .../modules/{locate.py => locate/__init__.py} | 43 +- .../python/share/modules/lpass/__init__.py | 102 + .../python/share/modules/lpass/lastpass.svg | 10 + .../__init__.py} | 23 +- .../__init__.py} | 41 +- .../share/modules/node_eval/__init__.py | 38 + .../python/share/modules/node_eval/nodejs.svg | 11 + plugins/python/share/modules/npm/__init__.py | 40 +- .../share/modules/packagist/__init__.py | 33 +- plugins/python/share/modules/pacman.py | 97 - .../python/share/modules/pacman/__init__.py | 107 + .../modules/{pass.py => pass/__init__.py} | 30 +- .../python/share/modules/php_eval/__init__.py | 36 + plugins/python/share/modules/php_eval/php.svg | 1 + .../modules/{pidgin.py => pidgin/__init__.py} | 25 +- .../python/share/modules/pomodoro/__init__.py | 22 +- .../share/modules/python_eval/__init__.py | 18 +- .../modules/{scrot.py => scrot/__init__.py} | 37 +- .../__init__.py} | 19 +- .../python/share/modules/texdoc/__init__.py | 61 + .../share/modules/texdoc/texdoc-logo.svg | 259 + .../python/share/modules/timer/__init__.py | 85 +- .../modules/{gnote.py => tomboy/__init__.py} | 49 +- plugins/python/share/modules/trash.py | 31 - .../python/share/modules/trash/__init__.py | 27 + .../share/modules/unicode_emoji/__init__.py | 114 + .../share/modules/unicode_emoji/emoji.txt | 4173 +++++++++++++++++ plugins/python/share/modules/units.py | 66 - .../python/share/modules/units/__init__.py | 73 + plugins/python/share/modules/vpn/__init__.py | 54 + .../share/modules/wikipedia/__init__.py | 30 +- .../python/share/modules/window_switcher.py | 41 - .../share/modules/window_switcher/__init__.py | 54 + plugins/python/share/modules/xkcd/LICENSE | 18 + plugins/python/share/modules/xkcd/README.md | 54 + plugins/python/share/modules/xkcd/__init__.py | 124 + plugins/python/share/modules/xkcd/image.png | Bin 0 -> 4959 bytes .../share/modules/xkcd/install-plugin.sh | 75 + .../python/share/modules/xkcd/misc/demo.gif | Bin 0 -> 730052 bytes plugins/python/share/modules/youtube.py | 83 - .../python/share/modules/youtube/__init__.py | 110 + plugins/python/share/modules/zeal.py | 33 - plugins/python/share/modules/zeal/__init__.py | 27 + plugins/python/src/cast_specialization.h | 17 + plugins/python/src/extension.cpp | 133 +- plugins/python/src/extension.h | 3 +- plugins/python/src/modulesmodel.cpp | 57 +- plugins/python/src/pythonmodulev1.cpp | 278 +- plugins/python/src/pythonmodulev1.h | 25 +- plugins/qmlboxmodel/README.md | 5 + .../styles/BoxModel/ItemViewDelegate.qml | 23 +- .../share/styles/BoxModel/MainComponent.qml | 6 +- .../share/styles/BoxModel/themes.js | 6 +- plugins/qmlboxmodel/src/mainwindow.cpp | 127 +- plugins/qmlboxmodel/src/mainwindow.h | 3 +- plugins/snippets/src/extension.cpp | 27 +- plugins/snippets/src/extension.h | 2 + plugins/ssh/README.md | 5 + plugins/ssh/metadata.json | 2 +- plugins/ssh/src/extension.cpp | 95 +- plugins/system/src/extension.cpp | 27 +- plugins/system/src/extension.h | 2 + plugins/templateExtension/CMakeLists.txt | 2 +- plugins/templateExtension/src/extension.cpp | 10 +- plugins/templateExtension/src/extension.h | 2 + plugins/terminal/metadata.json | 4 +- plugins/terminal/src/configwidget.cpp | 3 - plugins/terminal/src/configwidget.h | 23 - plugins/terminal/src/extension.cpp | 184 +- plugins/terminal/src/extension.h | 11 +- plugins/virtualbox/README.md | 9 + plugins/virtualbox/src/extension.cpp | 103 +- plugins/virtualbox/src/extension.h | 3 +- plugins/websearch/README.md | 6 + plugins/websearch/resources/naver.svg | 189 + plugins/websearch/src/extension.cpp | 47 +- plugins/websearch/src/extension.h | 2 + plugins/websearch/websearch.qrc | 1 + plugins/widgetboxmodel/CMakeLists.txt | 4 +- plugins/widgetboxmodel/README.md | 34 + plugins/widgetboxmodel/src/frontendwidget.cpp | 153 +- plugins/widgetboxmodel/src/frontendwidget.h | 8 +- resources/albert.desktop | 2 - src/app/extensionmanager.cpp | 18 +- src/app/frontendmanager.cpp | 9 +- src/app/logging.h | 8 + src/app/main.cpp | 504 +- src/app/matchcompare.cpp | 17 - src/app/matchcompare.h | 21 - src/app/pluginspec.cpp | 6 +- src/app/query.cpp | 16 +- src/app/queryexecution.cpp | 33 +- src/app/querymanager.cpp | 21 +- src/app/settingswidget/grabkeybutton.cpp | 4 +- src/app/settingswidget/settingswidget.cpp | 94 +- src/app/settingswidget/settingswidget.h | 3 - src/app/settingswidget/settingswidget.ui | 49 +- src/app/telemetry.cpp | 129 - src/app/telemetry.h | 27 - src/lib/fuzzysearch.cpp | 10 +- src/lib/shutil.cpp | 114 - src/lib/standardactions.cpp | 132 +- src/lib/standardindexitem.cpp | 16 +- src/lib/standarditem.cpp | 12 +- 824 files changed, 62257 insertions(+), 12253 deletions(-) create mode 100644 CHANGELOG.md create mode 100644 albert.png create mode 100644 build/.cmake/api/v1/query/client-vscode/query.json create mode 100644 build/.cmake/api/v1/reply/cache-v2-28e5adba9cf517f214a6.json create mode 100644 build/.cmake/api/v1/reply/codemodel-v2-6f44fa020fe1e9d16097.json create mode 100644 build/.cmake/api/v1/reply/index-2021-03-03T07-46-18-0196.json create mode 100644 build/.cmake/api/v1/reply/target-albert-bin-Debug-7b459d6ec10f68da7772.json create mode 100644 build/.cmake/api/v1/reply/target-albert-bin_autogen-Debug-3838f4f70dd823832bb1.json create mode 100644 build/.cmake/api/v1/reply/target-albert-lib-Debug-8db5dd15c22e3963d38a.json create mode 100644 build/.cmake/api/v1/reply/target-albert-lib_autogen-Debug-7964369b2bfc7ce58464.json create mode 100644 build/.cmake/api/v1/reply/target-applications-Debug-b6a503d5f7e0da8acd92.json create mode 100644 build/.cmake/api/v1/reply/target-applications_autogen-Debug-cb64350108dd6caadb07.json create mode 100644 build/.cmake/api/v1/reply/target-calculator-Debug-63f5e9aeb5d7170c34ad.json create mode 100644 build/.cmake/api/v1/reply/target-calculator_autogen-Debug-e1a7ee154105a90a9598.json create mode 100644 build/.cmake/api/v1/reply/target-chromium-Debug-eb58aca63d326f9cd32a.json create mode 100644 build/.cmake/api/v1/reply/target-chromium_autogen-Debug-7bef17168f2f1f098d4d.json create mode 100644 build/.cmake/api/v1/reply/target-files-Debug-e2a0c74573009c6a484c.json create mode 100644 build/.cmake/api/v1/reply/target-files_autogen-Debug-257c34759125ae096081.json create mode 100644 build/.cmake/api/v1/reply/target-firefoxbookmarks-Debug-cbc31ae4c17d7f085b18.json create mode 100644 build/.cmake/api/v1/reply/target-firefoxbookmarks_autogen-Debug-0d3eb7486a6df8f9cb80.json create mode 100644 build/.cmake/api/v1/reply/target-globalshortcut-Debug-badd0b9c45654272e2b3.json create mode 100644 build/.cmake/api/v1/reply/target-globalshortcut_autogen-Debug-e4db85e552bffa8f4e38.json create mode 100644 build/.cmake/api/v1/reply/target-hashgenerator-Debug-f3558c8d8f359af0cad2.json create mode 100644 build/.cmake/api/v1/reply/target-hashgenerator_autogen-Debug-4107c9cc6744e872a629.json create mode 100644 build/.cmake/api/v1/reply/target-mpris-Debug-8a4fd6fcff6e8820f881.json create mode 100644 build/.cmake/api/v1/reply/target-mpris_autogen-Debug-0cc090612bbde4c03453.json create mode 100644 build/.cmake/api/v1/reply/target-python-Debug-f77de8707e8cfe54cf31.json create mode 100644 build/.cmake/api/v1/reply/target-python_autogen-Debug-badd377ce3a43cab4366.json create mode 100644 build/.cmake/api/v1/reply/target-qmlboxmodel-Debug-d1cfef91b55d73c45ca2.json create mode 100644 build/.cmake/api/v1/reply/target-qmlboxmodel_autogen-Debug-3b9bb69b44fa2f8899f8.json create mode 100644 build/.cmake/api/v1/reply/target-snippets-Debug-592a4a47608f3fe646a9.json create mode 100644 build/.cmake/api/v1/reply/target-snippets_autogen-Debug-2a85aa502105ffa79438.json create mode 100644 build/.cmake/api/v1/reply/target-ssh-Debug-d6ba80dcda563e3c5bbe.json create mode 100644 build/.cmake/api/v1/reply/target-ssh_autogen-Debug-897694006d25d5cfae79.json create mode 100644 build/.cmake/api/v1/reply/target-system-Debug-3f993ac8a3518ff720d3.json create mode 100644 build/.cmake/api/v1/reply/target-system_autogen-Debug-df93704b5e5861b87871.json create mode 100644 build/.cmake/api/v1/reply/target-terminal-Debug-0788d0c17b1c71fa7f78.json create mode 100644 build/.cmake/api/v1/reply/target-terminal_autogen-Debug-4ba46e7bf76893be01e2.json create mode 100644 build/.cmake/api/v1/reply/target-websearch-Debug-0d09017a05cb8ea08500.json create mode 100644 build/.cmake/api/v1/reply/target-websearch_autogen-Debug-bab073aee85906c1cc90.json create mode 100644 build/.cmake/api/v1/reply/target-widgetboxmodel-Debug-ee0344ebcdf0a1121825.json create mode 100644 build/.cmake/api/v1/reply/target-widgetboxmodel_autogen-Debug-823c04e1ca30b858ad8f.json create mode 100644 build/.cmake/api/v1/reply/target-xdg-Debug-bae64f9e564c6982ae44.json create mode 100644 build/.cmake/api/v1/reply/target-xdg_autogen-Debug-e6ee28ce63fc23da9185.json create mode 100644 build/CMakeCache.txt create mode 100644 build/CMakeFiles/3.16.3/CMakeCCompiler.cmake create mode 100644 build/CMakeFiles/3.16.3/CMakeCXXCompiler.cmake create mode 100755 build/CMakeFiles/3.16.3/CMakeDetermineCompilerABI_C.bin create mode 100755 build/CMakeFiles/3.16.3/CMakeDetermineCompilerABI_CXX.bin create mode 100644 build/CMakeFiles/3.16.3/CMakeSystem.cmake create mode 100644 build/CMakeFiles/3.16.3/CompilerIdC/CMakeCCompilerId.c create mode 100755 build/CMakeFiles/3.16.3/CompilerIdC/a.out create mode 100644 build/CMakeFiles/3.16.3/CompilerIdCXX/CMakeCXXCompilerId.cpp create mode 100755 build/CMakeFiles/3.16.3/CompilerIdCXX/a.out create mode 100644 build/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/CMakeFiles/CMakeOutput.log create mode 100644 build/CMakeFiles/CMakeRuleHashes.txt create mode 100644 build/CMakeFiles/Makefile.cmake create mode 100644 build/CMakeFiles/Makefile2 create mode 100644 build/CMakeFiles/TargetDirectories.txt create mode 100644 build/CMakeFiles/albert-bin.dir/DependInfo.cmake create mode 100644 build/CMakeFiles/albert-bin.dir/build.make create mode 100644 build/CMakeFiles/albert-bin.dir/cmake_clean.cmake create mode 100644 build/CMakeFiles/albert-bin.dir/depend.make create mode 100644 build/CMakeFiles/albert-bin.dir/flags.make create mode 100644 build/CMakeFiles/albert-bin.dir/link.txt create mode 100644 build/CMakeFiles/albert-bin.dir/progress.make create mode 100644 build/CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Info.json create mode 100644 build/CMakeFiles/albert-bin_autogen.dir/AutogenInfo.json create mode 100644 build/CMakeFiles/albert-bin_autogen.dir/DependInfo.cmake create mode 100644 build/CMakeFiles/albert-bin_autogen.dir/build.make create mode 100644 build/CMakeFiles/albert-bin_autogen.dir/cmake_clean.cmake create mode 100644 build/CMakeFiles/albert-bin_autogen.dir/progress.make create mode 100644 build/CMakeFiles/albert-lib.dir/DependInfo.cmake create mode 100644 build/CMakeFiles/albert-lib.dir/build.make create mode 100644 build/CMakeFiles/albert-lib.dir/cmake_clean.cmake create mode 100644 build/CMakeFiles/albert-lib.dir/depend.make create mode 100644 build/CMakeFiles/albert-lib.dir/flags.make create mode 100644 build/CMakeFiles/albert-lib.dir/link.txt create mode 100644 build/CMakeFiles/albert-lib.dir/progress.make create mode 100644 build/CMakeFiles/albert-lib_autogen.dir/AutogenInfo.json create mode 100644 build/CMakeFiles/albert-lib_autogen.dir/DependInfo.cmake create mode 100644 build/CMakeFiles/albert-lib_autogen.dir/build.make create mode 100644 build/CMakeFiles/albert-lib_autogen.dir/cmake_clean.cmake create mode 100644 build/CMakeFiles/albert-lib_autogen.dir/progress.make create mode 100644 build/CMakeFiles/cmake.check_cache create mode 100644 build/CMakeFiles/progress.marks create mode 100644 build/Makefile create mode 100644 build/cmake_install.cmake create mode 100644 build/compile_commands.json create mode 100644 build/lib/globalshortcut/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/DependInfo.cmake create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean.cmake create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean_target.cmake create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend.make create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/link.txt create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/progress.make create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/AutogenInfo.json create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/DependInfo.cmake create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/cmake_clean.cmake create mode 100644 build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/progress.make create mode 100644 build/lib/globalshortcut/CMakeFiles/progress.marks create mode 100644 build/lib/globalshortcut/Makefile create mode 100644 build/lib/globalshortcut/cmake_install.cmake create mode 100644 build/lib/xdg/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/lib/xdg/CMakeFiles/progress.marks create mode 100644 build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake create mode 100644 build/lib/xdg/CMakeFiles/xdg.dir/build.make create mode 100644 build/lib/xdg/CMakeFiles/xdg.dir/cmake_clean.cmake create mode 100644 build/lib/xdg/CMakeFiles/xdg.dir/depend.make create mode 100644 build/lib/xdg/CMakeFiles/xdg.dir/flags.make create mode 100644 build/lib/xdg/CMakeFiles/xdg.dir/link.txt create mode 100644 build/lib/xdg/CMakeFiles/xdg.dir/progress.make create mode 100644 build/lib/xdg/CMakeFiles/xdg_autogen.dir/AutogenInfo.json create mode 100644 build/lib/xdg/CMakeFiles/xdg_autogen.dir/DependInfo.cmake create mode 100644 build/lib/xdg/CMakeFiles/xdg_autogen.dir/build.make create mode 100644 build/lib/xdg/CMakeFiles/xdg_autogen.dir/cmake_clean.cmake create mode 100644 build/lib/xdg/CMakeFiles/xdg_autogen.dir/progress.make create mode 100644 build/lib/xdg/Makefile create mode 100644 build/lib/xdg/cmake_install.cmake create mode 100644 build/plugins/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/CMakeFiles/progress.marks create mode 100644 build/plugins/Makefile create mode 100644 build/plugins/applications/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/applications/CMakeFiles/applications.dir/DependInfo.cmake create mode 100644 build/plugins/applications/CMakeFiles/applications.dir/build.make create mode 100644 build/plugins/applications/CMakeFiles/applications.dir/cmake_clean.cmake create mode 100644 build/plugins/applications/CMakeFiles/applications.dir/depend.make create mode 100644 build/plugins/applications/CMakeFiles/applications.dir/flags.make create mode 100644 build/plugins/applications/CMakeFiles/applications.dir/link.txt create mode 100644 build/plugins/applications/CMakeFiles/applications.dir/progress.make create mode 100644 build/plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Info.json create mode 100644 build/plugins/applications/CMakeFiles/applications_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/applications/CMakeFiles/applications_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/applications/CMakeFiles/applications_autogen.dir/build.make create mode 100644 build/plugins/applications/CMakeFiles/applications_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/applications/CMakeFiles/applications_autogen.dir/progress.make create mode 100644 build/plugins/applications/CMakeFiles/progress.marks create mode 100644 build/plugins/applications/Makefile create mode 100644 build/plugins/applications/cmake_install.cmake create mode 100644 build/plugins/calculator/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/calculator/CMakeFiles/calculator.dir/DependInfo.cmake create mode 100644 build/plugins/calculator/CMakeFiles/calculator.dir/build.make create mode 100644 build/plugins/calculator/CMakeFiles/calculator.dir/cmake_clean.cmake create mode 100644 build/plugins/calculator/CMakeFiles/calculator.dir/depend.make create mode 100644 build/plugins/calculator/CMakeFiles/calculator.dir/flags.make create mode 100644 build/plugins/calculator/CMakeFiles/calculator.dir/link.txt create mode 100644 build/plugins/calculator/CMakeFiles/calculator.dir/progress.make create mode 100644 build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Info.json create mode 100644 build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/calculator/CMakeFiles/calculator_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make create mode 100644 build/plugins/calculator/CMakeFiles/calculator_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/calculator/CMakeFiles/calculator_autogen.dir/progress.make create mode 100644 build/plugins/calculator/CMakeFiles/progress.marks create mode 100644 build/plugins/calculator/Makefile create mode 100644 build/plugins/calculator/cmake_install.cmake create mode 100644 build/plugins/chromium/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/chromium/CMakeFiles/chromium.dir/DependInfo.cmake create mode 100644 build/plugins/chromium/CMakeFiles/chromium.dir/build.make create mode 100644 build/plugins/chromium/CMakeFiles/chromium.dir/cmake_clean.cmake create mode 100644 build/plugins/chromium/CMakeFiles/chromium.dir/depend.make create mode 100644 build/plugins/chromium/CMakeFiles/chromium.dir/flags.make create mode 100644 build/plugins/chromium/CMakeFiles/chromium.dir/link.txt create mode 100644 build/plugins/chromium/CMakeFiles/chromium.dir/progress.make create mode 100644 build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Info.json create mode 100644 build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/chromium/CMakeFiles/chromium_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make create mode 100644 build/plugins/chromium/CMakeFiles/chromium_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/chromium/CMakeFiles/chromium_autogen.dir/progress.make create mode 100644 build/plugins/chromium/CMakeFiles/progress.marks create mode 100644 build/plugins/chromium/Makefile create mode 100644 build/plugins/chromium/cmake_install.cmake create mode 100644 build/plugins/cmake_install.cmake create mode 100644 build/plugins/files/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/files/CMakeFiles/files.dir/DependInfo.cmake create mode 100644 build/plugins/files/CMakeFiles/files.dir/build.make create mode 100644 build/plugins/files/CMakeFiles/files.dir/cmake_clean.cmake create mode 100644 build/plugins/files/CMakeFiles/files.dir/depend.make create mode 100644 build/plugins/files/CMakeFiles/files.dir/flags.make create mode 100644 build/plugins/files/CMakeFiles/files.dir/link.txt create mode 100644 build/plugins/files/CMakeFiles/files.dir/progress.make create mode 100644 build/plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Info.json create mode 100644 build/plugins/files/CMakeFiles/files_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/files/CMakeFiles/files_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/files/CMakeFiles/files_autogen.dir/build.make create mode 100644 build/plugins/files/CMakeFiles/files_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/files/CMakeFiles/files_autogen.dir/progress.make create mode 100644 build/plugins/files/CMakeFiles/progress.marks create mode 100644 build/plugins/files/Makefile create mode 100644 build/plugins/files/cmake_install.cmake create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/DependInfo.cmake create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/cmake_clean.cmake create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend.make create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/link.txt create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/progress.make create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Info.json create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/progress.make create mode 100644 build/plugins/firefoxbookmarks/CMakeFiles/progress.marks create mode 100644 build/plugins/firefoxbookmarks/Makefile create mode 100644 build/plugins/firefoxbookmarks/cmake_install.cmake create mode 100644 build/plugins/hashgenerator/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/DependInfo.cmake create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/cmake_clean.cmake create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend.make create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/link.txt create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/progress.make create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Info.json create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/progress.make create mode 100644 build/plugins/hashgenerator/CMakeFiles/progress.marks create mode 100644 build/plugins/hashgenerator/Makefile create mode 100644 build/plugins/hashgenerator/cmake_install.cmake create mode 100644 build/plugins/mpris/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/mpris/CMakeFiles/mpris.dir/DependInfo.cmake create mode 100644 build/plugins/mpris/CMakeFiles/mpris.dir/build.make create mode 100644 build/plugins/mpris/CMakeFiles/mpris.dir/cmake_clean.cmake create mode 100644 build/plugins/mpris/CMakeFiles/mpris.dir/depend.make create mode 100644 build/plugins/mpris/CMakeFiles/mpris.dir/flags.make create mode 100644 build/plugins/mpris/CMakeFiles/mpris.dir/link.txt create mode 100644 build/plugins/mpris/CMakeFiles/mpris.dir/progress.make create mode 100644 build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Info.json create mode 100644 build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/mpris/CMakeFiles/mpris_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make create mode 100644 build/plugins/mpris/CMakeFiles/mpris_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/mpris/CMakeFiles/mpris_autogen.dir/progress.make create mode 100644 build/plugins/mpris/CMakeFiles/progress.marks create mode 100644 build/plugins/mpris/Makefile create mode 100644 build/plugins/mpris/cmake_install.cmake create mode 100644 build/plugins/python/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/python/CMakeFiles/progress.marks create mode 100644 build/plugins/python/CMakeFiles/python.dir/DependInfo.cmake create mode 100644 build/plugins/python/CMakeFiles/python.dir/build.make create mode 100644 build/plugins/python/CMakeFiles/python.dir/cmake_clean.cmake create mode 100644 build/plugins/python/CMakeFiles/python.dir/depend.make create mode 100644 build/plugins/python/CMakeFiles/python.dir/flags.make create mode 100644 build/plugins/python/CMakeFiles/python.dir/link.txt create mode 100644 build/plugins/python/CMakeFiles/python.dir/progress.make create mode 100644 build/plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Info.json create mode 100644 build/plugins/python/CMakeFiles/python_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/python/CMakeFiles/python_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/python/CMakeFiles/python_autogen.dir/build.make create mode 100644 build/plugins/python/CMakeFiles/python_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/python/CMakeFiles/python_autogen.dir/progress.make create mode 100644 build/plugins/python/Makefile create mode 100644 build/plugins/python/cmake_install.cmake create mode 100644 build/plugins/python/pybind11/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/python/pybind11/CMakeFiles/progress.marks create mode 100644 build/plugins/python/pybind11/Makefile create mode 100644 build/plugins/python/pybind11/cmake_install.cmake create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/progress.marks create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/DependInfo.cmake create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/cmake_clean.cmake create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend.make create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/link.txt create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/progress.make create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/progress.make create mode 100644 build/plugins/qmlboxmodel/Makefile create mode 100644 build/plugins/qmlboxmodel/cmake_install.cmake create mode 100644 build/plugins/snippets/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/snippets/CMakeFiles/progress.marks create mode 100644 build/plugins/snippets/CMakeFiles/snippets.dir/DependInfo.cmake create mode 100644 build/plugins/snippets/CMakeFiles/snippets.dir/build.make create mode 100644 build/plugins/snippets/CMakeFiles/snippets.dir/cmake_clean.cmake create mode 100644 build/plugins/snippets/CMakeFiles/snippets.dir/depend.make create mode 100644 build/plugins/snippets/CMakeFiles/snippets.dir/flags.make create mode 100644 build/plugins/snippets/CMakeFiles/snippets.dir/link.txt create mode 100644 build/plugins/snippets/CMakeFiles/snippets.dir/progress.make create mode 100644 build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Info.json create mode 100644 build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/snippets/CMakeFiles/snippets_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make create mode 100644 build/plugins/snippets/CMakeFiles/snippets_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/snippets/CMakeFiles/snippets_autogen.dir/progress.make create mode 100644 build/plugins/snippets/Makefile create mode 100644 build/plugins/snippets/cmake_install.cmake create mode 100644 build/plugins/ssh/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/ssh/CMakeFiles/progress.marks create mode 100644 build/plugins/ssh/CMakeFiles/ssh.dir/DependInfo.cmake create mode 100644 build/plugins/ssh/CMakeFiles/ssh.dir/build.make create mode 100644 build/plugins/ssh/CMakeFiles/ssh.dir/cmake_clean.cmake create mode 100644 build/plugins/ssh/CMakeFiles/ssh.dir/depend.make create mode 100644 build/plugins/ssh/CMakeFiles/ssh.dir/flags.make create mode 100644 build/plugins/ssh/CMakeFiles/ssh.dir/link.txt create mode 100644 build/plugins/ssh/CMakeFiles/ssh.dir/progress.make create mode 100644 build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Info.json create mode 100644 build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/ssh/CMakeFiles/ssh_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make create mode 100644 build/plugins/ssh/CMakeFiles/ssh_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/ssh/CMakeFiles/ssh_autogen.dir/progress.make create mode 100644 build/plugins/ssh/Makefile create mode 100644 build/plugins/ssh/cmake_install.cmake create mode 100644 build/plugins/system/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/system/CMakeFiles/progress.marks create mode 100644 build/plugins/system/CMakeFiles/system.dir/DependInfo.cmake create mode 100644 build/plugins/system/CMakeFiles/system.dir/build.make create mode 100644 build/plugins/system/CMakeFiles/system.dir/cmake_clean.cmake create mode 100644 build/plugins/system/CMakeFiles/system.dir/depend.make create mode 100644 build/plugins/system/CMakeFiles/system.dir/flags.make create mode 100644 build/plugins/system/CMakeFiles/system.dir/link.txt create mode 100644 build/plugins/system/CMakeFiles/system.dir/progress.make create mode 100644 build/plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Info.json create mode 100644 build/plugins/system/CMakeFiles/system_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/system/CMakeFiles/system_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/system/CMakeFiles/system_autogen.dir/build.make create mode 100644 build/plugins/system/CMakeFiles/system_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/system/CMakeFiles/system_autogen.dir/progress.make create mode 100644 build/plugins/system/Makefile create mode 100644 build/plugins/system/cmake_install.cmake create mode 100644 build/plugins/terminal/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/terminal/CMakeFiles/progress.marks create mode 100644 build/plugins/terminal/CMakeFiles/terminal.dir/DependInfo.cmake create mode 100644 build/plugins/terminal/CMakeFiles/terminal.dir/build.make create mode 100644 build/plugins/terminal/CMakeFiles/terminal.dir/cmake_clean.cmake create mode 100644 build/plugins/terminal/CMakeFiles/terminal.dir/depend.make create mode 100644 build/plugins/terminal/CMakeFiles/terminal.dir/flags.make create mode 100644 build/plugins/terminal/CMakeFiles/terminal.dir/link.txt create mode 100644 build/plugins/terminal/CMakeFiles/terminal.dir/progress.make create mode 100644 build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Info.json create mode 100644 build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/terminal/CMakeFiles/terminal_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make create mode 100644 build/plugins/terminal/CMakeFiles/terminal_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/terminal/CMakeFiles/terminal_autogen.dir/progress.make create mode 100644 build/plugins/terminal/Makefile create mode 100644 build/plugins/terminal/cmake_install.cmake create mode 100644 build/plugins/websearch/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/websearch/CMakeFiles/progress.marks create mode 100644 build/plugins/websearch/CMakeFiles/websearch.dir/DependInfo.cmake create mode 100644 build/plugins/websearch/CMakeFiles/websearch.dir/build.make create mode 100644 build/plugins/websearch/CMakeFiles/websearch.dir/cmake_clean.cmake create mode 100644 build/plugins/websearch/CMakeFiles/websearch.dir/depend.make create mode 100644 build/plugins/websearch/CMakeFiles/websearch.dir/flags.make create mode 100644 build/plugins/websearch/CMakeFiles/websearch.dir/link.txt create mode 100644 build/plugins/websearch/CMakeFiles/websearch.dir/progress.make create mode 100644 build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Info.json create mode 100644 build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/websearch/CMakeFiles/websearch_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make create mode 100644 build/plugins/websearch/CMakeFiles/websearch_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/websearch/CMakeFiles/websearch_autogen.dir/progress.make create mode 100644 build/plugins/websearch/Makefile create mode 100644 build/plugins/websearch/cmake_install.cmake create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/progress.marks create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/DependInfo.cmake create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/cmake_clean.cmake create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend.make create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/link.txt create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/progress.make create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/AutogenInfo.json create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/DependInfo.cmake create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/cmake_clean.cmake create mode 100644 build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/progress.make create mode 100644 build/plugins/widgetboxmodel/Makefile create mode 100644 build/plugins/widgetboxmodel/cmake_install.cmake create mode 100755 debian/postinst create mode 100644 debian/source/format create mode 100755 hamonikr/albert.desktop create mode 100644 hamonikr/etc/skel/.config/albert/albert.conf create mode 100644 hamonikr/etc/skel/.config/albert/core.db create mode 100644 hamonikr/etc/skel/.config/albert/last_used_version create mode 100644 hamonikr/etc/skel/.config/albert/org.albert.extension.websearch/engines.json create mode 100644 hamonikr/etc/xdg/autostart/albert.desktop delete mode 100644 include/albert/util/shutil.h create mode 100755 metatool rename plugins/{ => .archive}/externalextensions/CMakeLists.txt (100%) create mode 100644 plugins/.archive/externalextensions/README.md rename plugins/{ => .archive}/externalextensions/metadata.json (100%) rename plugins/{ => .archive}/externalextensions/src/configwidget.cpp (100%) rename plugins/{ => .archive}/externalextensions/src/configwidget.h (100%) rename plugins/{ => .archive}/externalextensions/src/configwidget.ui (88%) rename plugins/{ => .archive}/externalextensions/src/extension.cpp (96%) rename plugins/{ => .archive}/externalextensions/src/extension.h (91%) rename plugins/{ => .archive}/externalextensions/src/externalextension.cpp (100%) rename plugins/{ => .archive}/externalextensions/src/externalextension.h (100%) rename plugins/{ => .archive}/externalextensions/src/externalextensionmodel.cpp (100%) rename plugins/{ => .archive}/externalextensions/src/externalextensionmodel.h (100%) create mode 100644 plugins/README.md create mode 100644 plugins/applications/README.md create mode 100644 plugins/calculator/README.md delete mode 100644 plugins/chromebookmarks/metadata.json delete mode 100644 plugins/chromebookmarks/src/configwidget.cpp delete mode 100644 plugins/chromebookmarks/src/configwidget.h delete mode 100644 plugins/chromebookmarks/src/configwidget.ui delete mode 100644 plugins/chromebookmarks/src/extension.cpp rename plugins/{chromebookmarks => chromium}/CMakeLists.txt (95%) create mode 100644 plugins/chromium/README.md rename plugins/{chromebookmarks/chromebookmarks.qrc => chromium/chromium.qrc} (100%) create mode 100644 plugins/chromium/metadata.json rename plugins/{chromebookmarks => chromium}/resources/favicon.png (100%) rename plugins/{terminal => chromium}/src/configwidget.ui (64%) create mode 100644 plugins/chromium/src/extension.cpp rename plugins/{chromebookmarks => chromium}/src/extension.h (50%) create mode 100644 plugins/files/README.md create mode 100644 plugins/mpris/README.md create mode 100644 plugins/python/README.md create mode 100644 plugins/python/pybind11/.clang-tidy create mode 100644 plugins/python/pybind11/.cmake-format.yaml create mode 100644 plugins/python/pybind11/.github/CONTRIBUTING.md create mode 100644 plugins/python/pybind11/.github/ISSUE_TEMPLATE/bug-report.md create mode 100644 plugins/python/pybind11/.github/ISSUE_TEMPLATE/config.yml create mode 100644 plugins/python/pybind11/.github/ISSUE_TEMPLATE/feature-request.md create mode 100644 plugins/python/pybind11/.github/ISSUE_TEMPLATE/question.md create mode 100644 plugins/python/pybind11/.github/dependabot.yml create mode 100644 plugins/python/pybind11/.github/labeler.yml create mode 100644 plugins/python/pybind11/.github/labeler_merged.yml create mode 100644 plugins/python/pybind11/.github/pull_request_template.md create mode 100644 plugins/python/pybind11/.github/workflows/ci.yml create mode 100644 plugins/python/pybind11/.github/workflows/configure.yml create mode 100644 plugins/python/pybind11/.github/workflows/format.yml create mode 100644 plugins/python/pybind11/.github/workflows/labeler.yml create mode 100644 plugins/python/pybind11/.github/workflows/pip.yml delete mode 100644 plugins/python/pybind11/.gitmodules create mode 100644 plugins/python/pybind11/.pre-commit-config.yaml delete mode 100644 plugins/python/pybind11/.travis.yml delete mode 100644 plugins/python/pybind11/CONTRIBUTING.md delete mode 100644 plugins/python/pybind11/ISSUE_TEMPLATE.md delete mode 100644 plugins/python/pybind11/README.md create mode 100644 plugins/python/pybind11/README.rst create mode 100644 plugins/python/pybind11/docs/cmake/index.rst create mode 100644 plugins/python/pybind11/docs/installing.rst delete mode 100644 plugins/python/pybind11/docs/intro.rst create mode 100644 plugins/python/pybind11/pybind11/_version.pyi create mode 100644 plugins/python/pybind11/pybind11/commands.py create mode 100644 plugins/python/pybind11/pybind11/py.typed create mode 100644 plugins/python/pybind11/pybind11/setup_helpers.py create mode 100644 plugins/python/pybind11/pybind11/setup_helpers.pyi create mode 100644 plugins/python/pybind11/pyproject.toml create mode 100644 plugins/python/pybind11/tests/cross_module_gil_utils.cpp create mode 100644 plugins/python/pybind11/tests/env.py create mode 100644 plugins/python/pybind11/tests/extra_python_package/pytest.ini create mode 100644 plugins/python/pybind11/tests/extra_python_package/test_files.py create mode 100644 plugins/python/pybind11/tests/extra_setuptools/pytest.ini create mode 100644 plugins/python/pybind11/tests/extra_setuptools/test_setuphelper.py create mode 100644 plugins/python/pybind11/tests/requirements.txt create mode 100644 plugins/python/pybind11/tests/test_async.cpp create mode 100644 plugins/python/pybind11/tests/test_async.py create mode 100644 plugins/python/pybind11/tests/test_custom_type_casters.cpp create mode 100644 plugins/python/pybind11/tests/test_custom_type_casters.py create mode 100644 plugins/python/pybind11/tests/test_gil_scoped.cpp create mode 100644 plugins/python/pybind11/tests/test_gil_scoped.py create mode 100644 plugins/python/pybind11/tests/test_tagbased_polymorphic.cpp create mode 100644 plugins/python/pybind11/tests/test_tagbased_polymorphic.py create mode 100644 plugins/python/pybind11/tests/test_union.cpp create mode 100644 plugins/python/pybind11/tests/test_union.py delete mode 100644 plugins/python/pybind11/tools/clang/LICENSE.TXT delete mode 100644 plugins/python/pybind11/tools/clang/README.md delete mode 100644 plugins/python/pybind11/tools/clang/__init__.py delete mode 100644 plugins/python/pybind11/tools/clang/cindex.py delete mode 100644 plugins/python/pybind11/tools/clang/enumerations.py create mode 100644 plugins/python/pybind11/tools/cmake_uninstall.cmake.in delete mode 100644 plugins/python/pybind11/tools/mkdoc.py create mode 100644 plugins/python/pybind11/tools/pybind11Common.cmake create mode 100644 plugins/python/pybind11/tools/pybind11NewTools.cmake create mode 100644 plugins/python/pybind11/tools/pyproject.toml create mode 100644 plugins/python/pybind11/tools/setup_global.py.in create mode 100644 plugins/python/pybind11/tools/setup_main.py.in rename plugins/python/share/modules/{ => .archive}/bitfinex/Bitfinex.svg (100%) rename plugins/python/share/modules/{ => .archive}/bitfinex/__init__.py (81%) rename plugins/python/share/modules/{ => .archive}/coinmarketcap/__init__.py (90%) rename plugins/python/share/modules/{ => .archive}/coinmarketcap/emblem-money.svg (100%) rename plugins/python/share/modules/{ => .archive}/dango_emoji/__init__.py (77%) rename plugins/python/share/modules/{ => .archive}/dango_emoji/dangoemoji.png (100%) rename plugins/python/share/modules/{ => .archive}/dango_kao/__init__.py (75%) rename plugins/python/share/modules/{ => .archive}/dango_kao/kaoicon.svg (100%) create mode 100644 plugins/python/share/modules/.archive/virtualbox/README.md rename plugins/python/share/modules/{virtualbox.py => .archive/virtualbox/__init__.py} (77%) create mode 100644 plugins/python/share/modules/.gitmodules rename plugins/python/share/modules/{atom_projects.py => atom_projects/__init__.py} (73%) delete mode 100644 plugins/python/share/modules/base_converter.py create mode 100644 plugins/python/share/modules/base_converter/__init__.py create mode 100644 plugins/python/share/modules/bitwarden/__init__.py rename plugins/python/share/modules/{copyq.py => copyq/__init__.py} (86%) rename plugins/python/share/modules/{currency_converter.py => currency_converter/__init__.py} (85%) delete mode 100644 plugins/python/share/modules/datetime.py create mode 100644 plugins/python/share/modules/datetime/__init__.py create mode 100644 plugins/python/share/modules/docker/__init__.py create mode 100644 plugins/python/share/modules/docker/running.png create mode 100644 plugins/python/share/modules/docker/stopped.png rename plugins/python/share/modules/{fortune.py => fortune/__init__.py} (61%) delete mode 100644 plugins/python/share/modules/gnome_dictionary.py create mode 100644 plugins/python/share/modules/gnome_dictionary/__init__.py rename plugins/python/share/modules/{tomboy.py => gnote/__init__.py} (65%) delete mode 100644 plugins/python/share/modules/goldendict.py create mode 100644 plugins/python/share/modules/goldendict/__init__.py rename plugins/python/share/modules/{google_translate.py => google_translate/__init__.py} (73%) rename plugins/python/share/modules/{ip.py => ip/__init__.py} (60%) create mode 100644 plugins/python/share/modules/jetbrains_projects/LICENSE create mode 100644 plugins/python/share/modules/jetbrains_projects/README.md rename plugins/python/share/modules/{kill.py => kill/__init__.py} (83%) rename plugins/python/share/modules/{locate.py => locate/__init__.py} (51%) create mode 100644 plugins/python/share/modules/lpass/__init__.py create mode 100644 plugins/python/share/modules/lpass/lastpass.svg rename plugins/python/share/modules/{mathematica_eval.py => mathematica_eval/__init__.py} (63%) rename plugins/python/share/modules/{multi_google_translate.py => multi_google_translate/__init__.py} (82%) create mode 100644 plugins/python/share/modules/node_eval/__init__.py create mode 100644 plugins/python/share/modules/node_eval/nodejs.svg delete mode 100644 plugins/python/share/modules/pacman.py create mode 100644 plugins/python/share/modules/pacman/__init__.py rename plugins/python/share/modules/{pass.py => pass/__init__.py} (86%) create mode 100644 plugins/python/share/modules/php_eval/__init__.py create mode 100644 plugins/python/share/modules/php_eval/php.svg rename plugins/python/share/modules/{pidgin.py => pidgin/__init__.py} (87%) rename plugins/python/share/modules/{scrot.py => scrot/__init__.py} (71%) rename plugins/python/share/modules/{tex_to_unicode.py => tex_to_unicode/__init__.py} (81%) create mode 100644 plugins/python/share/modules/texdoc/__init__.py create mode 100644 plugins/python/share/modules/texdoc/texdoc-logo.svg rename plugins/python/share/modules/{gnote.py => tomboy/__init__.py} (65%) delete mode 100644 plugins/python/share/modules/trash.py create mode 100644 plugins/python/share/modules/trash/__init__.py create mode 100644 plugins/python/share/modules/unicode_emoji/__init__.py create mode 100644 plugins/python/share/modules/unicode_emoji/emoji.txt delete mode 100644 plugins/python/share/modules/units.py create mode 100644 plugins/python/share/modules/units/__init__.py create mode 100644 plugins/python/share/modules/vpn/__init__.py delete mode 100644 plugins/python/share/modules/window_switcher.py create mode 100644 plugins/python/share/modules/window_switcher/__init__.py create mode 100644 plugins/python/share/modules/xkcd/LICENSE create mode 100644 plugins/python/share/modules/xkcd/README.md create mode 100644 plugins/python/share/modules/xkcd/__init__.py create mode 100644 plugins/python/share/modules/xkcd/image.png create mode 100755 plugins/python/share/modules/xkcd/install-plugin.sh create mode 100644 plugins/python/share/modules/xkcd/misc/demo.gif delete mode 100644 plugins/python/share/modules/youtube.py create mode 100644 plugins/python/share/modules/youtube/__init__.py delete mode 100644 plugins/python/share/modules/zeal.py create mode 100644 plugins/python/share/modules/zeal/__init__.py create mode 100644 plugins/qmlboxmodel/README.md create mode 100644 plugins/ssh/README.md delete mode 100644 plugins/terminal/src/configwidget.cpp delete mode 100644 plugins/terminal/src/configwidget.h create mode 100644 plugins/virtualbox/README.md create mode 100644 plugins/websearch/README.md create mode 100644 plugins/websearch/resources/naver.svg create mode 100644 plugins/widgetboxmodel/README.md create mode 100644 src/app/logging.h delete mode 100644 src/app/matchcompare.cpp delete mode 100644 src/app/matchcompare.h delete mode 100644 src/app/telemetry.cpp delete mode 100644 src/app/telemetry.h delete mode 100644 src/lib/shutil.cpp diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..f43a8d1 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,503 @@ +v0.17.2 (2020-12-24) + +[albert] +* Drop telemetry + +[plugins] +* [wbm] Fix completion + +v0.17.1 (2020-12-21) + +[albert] +* Fix OBS builds +* Several fixes +* Archive virtualbox python extension + +Copyright (c) 2018 Copyright Holder All Rights Reserved.v0.17.0 (2020-12-17) + +[albert] +* Again break init order of Item for the sake of less boilerplate. Presumed this frequency indexStrings > actions > completion > urgency. +* Let shells handle splitting/quoting +* Add core as QueryHandler. Add restart, quit, settings action. Also to tray and cli. +* Drop shutil:: and let shells handle lexing + +[plugins] +* FINALLY ARCHIVE EXTERNAL EXTENSIONS. +* New extension state : MissingDependencies +* Disable settings items of exts in this new state +* Use pybind v2.6.1 +* [term] v1.1 Let shells handle lexing +* [calc] Add muparserInt option for hex calculations +* Use QLoggingCategory in all extensions +* Implicit dependency check for executables and Python modules +* [Pyv1.3] Adopt core changes. PyAPIv0.4. Changes to the API: + * embedded module is called 'albert' now + * Reflect core api changes: + * Positional arguments of the standard item changes + * New semantics of the term action constructors + * String commandline will be executed in a shell + * StringList commandline will be executed without shell + * Add core version of iconLookup(StringList) + * New metadata labels: + * __version__: new versioning scheme iid_maj.iid_min.ext_version + * __title__: former __prettyname__ + * __authors__: string or list + * __exec_deps__: string or list + * __py_deps__: string or list + * __triggers__: string or list + * Allow multiple triggers + * Allow multiple authors + +[python] +* Adpot APIv0.4 changes +* [locate] ' for basename '' for full path lookups +* [timer] Make notification stay. +* [baseconv] Python-style base prefixes to detect source base +* [texdoc] Add texdoc plugin +* [aur] add yay helper + +Check the GitHub repositories for details. +https://github.com/albertlauncher/albert/commits/v0.17.0 + +v0.16.4 (2020-12-10) + +Hotfix for #959 + +[albert] +* Fix tab order. Closes #866 +* Update stale.yml + +[plugins] +* [chromium] Chromium v1.1 + +[python] +* [docker] New extension prototype +* [timer] Use dbus instead of notify-send +* [units] v1.2 including to time conversion + +v0.16.3 (2020-12-03) + +* Hotfix for #955 +* Archive defunct CoinMarketCap and Bitfinex extensions + +v0.16.2 (2020-11-26) + +[albert] +* Allow multiple instances of albert on different X sessions +* Fix super key not registering +* Add terms: Elementary, Tilix, QTerminal, Termite +* Fix build on FreeBSD +* Dont show fallbacks on triggered queries + +[plugins] +* [Applications] Index desktop files on desktop +* [firefox] Rework v2 +* [ssh] Respect the Include keyword +* [ssh] Allow hyphens to be part of hostnames +* [chromium] Add brave-browser to list of chromium based browsers. + +[python] +* Add an offline emoji picker +* Add bitwarden extension +* Add xkcd plugin as submodule +* Add new extension: node.js evaluator +* Add new extension: php evaluator + +v0.16.1 (2018-12-31) + +* [albert] Fix default plugin lookup path +* [albert] Fix flicker when changing frontends +* [albert] Fix "Terminal option resets after a restart" +* [albert] Link libglobalshortcut statically +* [albert] Add a build flag for QtCharts +* [albert] Drop debug options if favor of QLoggingCategory env vars +* [plugins:ssh] Fix input regex. Sort by length then lexically. +* [plugins:ssh] Use backward compatible ssh url syntax +* [plugins:qml] Consistent form layout +* [modules:aur] Sort items by length first + +v0.16.0 (2018-12-28) + +* Add jekyll website as submodule +* New project structure (minimal shared lib) +* Let travis build against Ubuntu 18.04 and 16.04 +* Backward compatibility for Ubuntu 16.04 +* Let fuzzy require an additional character. Tolerance: floor((wordlen - 1)/3)) +* Print logging category to stdout QT_LOGGING_RULES="*debug=false;driver.usb.debug=true" +* [Term] Change terminal action order: Let "Run w/o term" be the last one +* [VBox] Set default build switch for VirtualBox to OFF +* [Files] Add fancy icons to mime dialog +* [Py] Use ast to read metadata without loading the modules +* [Py] Additional constraint: Metadata have to be string literals (for ast) +* [Py] Additional constraint: Name modules according PEP8 +* [Py/WinSwitch] Add close win action +* [Py/VBox] Add VirtualBox extension + +v0.15.0 (2018-12-16) + +* Usage graph in the settings (QtCharts (>=5.6)) +* [QML] Frontend plugin requires ()5.9 +* [QML] History search of the input now allows substring matching (Type and navigate) +* [QML] Store user input of every session +* New Python extension: Fortune +* New Python extension: Window switcher + +v0.14.22 (2018-09-21) + +* Telemetry is now opt-in. +* New Python extension: Pidgin +* New themes + +v0.14.21 (2018-06-08) + +* Bugfix release + +v0.14.20 (2018-06-04) + +* Bugfix release + +v0.14.19 (2018-05-15) + +* New Python extension: Datetime. (Time display and conversion. Supersedes the external extension) +* New Python extension: Bitfinex. (Quickly access Bitfinex markets) +* The file browse mode finally mimics bash completion behavior. + +v0.14.18 (2018-03-23) + +* Hotfix release + +v0.14.17 (2018-03-23) + +* New Python extension: Arch Wiki +* New option in applications extension: Use keywords for lookup +* New option in applications extension: Use generic name for lookup +* The _kvstore_ extension was renamed to _Snippets_ and got an improved config UI. + +v0.14.16 (2018-03-09) + +* New Python extension: Gnome dictionary (nikhilwanpal) +* New Python extension: Mathematica (Asger Hautop Drewsen) +* New Python extension: TeX to unicode (Asger Hautop Drewsen) +* New Python extension: IP address (Benedict Dudel) +* New Python extension: Multi Translate (David Britt) +* New Python extension: Emoji lookup (David Britt) +* New Python extension: Kaomoji lookup (David Britt) +* New Python extension: Timer +* New Python extension: Binance + +v0.14.15 (2018-01-26) + +* New Python extensions: CoinMarketCap, Trash, Pomodoro, Epoch, Packagist. +* New Python API PythonInterface/v0.2 (`configLocation()`, `dataLocation()`,`cacheLocation()`). + +v0.14.14 (2017-12-06) + +* New Python extension: npm (Benedict Dudel) + +v0.14.13 (2017-11-25) + +* Rich text support +* New AUR Python extension +* New `scrot` Python extension + +v0.14.12 (2017-11-23) + +* New CopyQ Python extension (Ported from external extension) + +v0.14.11 (2017-11-19) + +* New `locate` Python extension + +v0.14.10 (2017-11-16) + +* Bugfixes + +v0.14.9 (2017-11-16) + +* Better HiDPI support +* New commandline option for debug output (-d) + +v0.14.8 (2017-11-14) + +* New Gnote Python extension (Ported from external extension) +* New Tomboy Python extension (Ported from external extension) +* New Pacman Python extension +* New Pass Python extension +* New Kill Python extension + +v0.14.7 (2017-11-03) + +* Bugfixes + +v0.14.6 (2017-10-31) + +* New Wikipedia Python extension + +v0.14.5 (2017-10-30) + +* Bugfixes + +v0.14.4 (2017-10-25) + +* New base converter Python extension + +v0.14.3 (2017-10-21) + +* New Google Translate Python extension + +v0.14.2 (2017-10-20) + +* Bugfixes + +v0.14.1 (2017-10-19) + +* Bugfixes + +v0.14.0 (2017-10-18) + +* New Python Embedding extension +* New Python Eval Python extension +* New Debugging Python extension +* New Zeal Python extension +* New GoldenDict Python extension +* New Unit Converter Python extension (Gnu units) +* New Currency Converter Python extension (Google finance) + +v0.13.1 (2017-00-30) + +* Bugfixes + +v0.13.0 (2017-09-28) + +* Modular frontends +* QML frontend +* Tree structure in file index and "smart" indexing +* New KeyValue extension +* New Hash Generator extension +* Shell like completion for terminal extension + +v0.12.0 (2017-06-09) + +* Git-like ignore files +* Dedicated dialog for websearch editing. + +v0.11.3 (2017-05-28) + +* Bugfixes + +v0.11.2 (2017-05-13) + +* Home and End now work for the results list holding Ctrl. + +v0.11.1 (2017-04-16) + +* Bugfixes + +v0.11.0 (2017-04-16) + +* Fine-grained control of the MIME types to be indexed. +* Extensions can now have multiple triggers. +* The sorting algorithm is now stable. +* Browse mode now lists the results in lexicographical order with directories before the files. +* The use of fallbacks has been disabled for triggered queries. +* Further the websearch extension now contains an URL handler. +* The qss property `selection-color` works as expected now. + +v0.10.4 (2017-04-14) + +* Bugfixes + +v0.10.3 (2017-04-02) + +* Terminal extension does no more show suggestions. +* Any shell querying dropped. +* Bugfixes + +v0.10.2 (2017-03-24) + +* Bugfixes + +v0.10.1 (2017-03-20) + +* Bugfixes + +v0.10.0 (2017-03-19) + +* Tab completion. +* Hovering over the input box the mouse wheel can now be used to browse the history. +* Spotlight themes (Bright, Dark and Space). +* New native extension: MPRIS +* New native extension: Secure Shell +* The terminal extension now provides the shell aliases too. +* File browse mode. +* The application extension allows to ignore the `OnlyShowIn`/`NotShowIn` keys. +* The bash script to clone the template extension is now deprecated and replaced by a Python script. + +v0.9.5 (2017-03-13) + +* Bugfixes + +v0.9.4 (2017-03-01) + +* Bugfixes + +v0.9.3 (2017-02-05) + +* Bugfixes + +v0.9.2 (2017-01-30) + +* Bugfixes + +v0.9.1 (2017-01-23) + +* Chooseable terminal command of a list of installed terminals. +* The app icon now uses a theme icon +* _Open terminal here_ action. +* Mostly fixes + +v0.9.0 (2017-01-17) + +* New extension system architecture +* New native extension: External extensions +* New native extension: Firefox +* Improved VirtualBox extension + +v0.8.11 (2016-09-29) + +* Plugin abstraction architecture +* New plugin support: Native C++ QPlugins +* New plugin support: Executables +* Single click activation of items +* Action modifiers +* Multithreading +* Core is now responsible for usage counting (obsoletes most serialization) +* Asynchronous query "live" results +* Tray icon +* New option: Show tray icon +* New extension: Debug + +v0.8.10 (2016-06-23) + +* New extension: Virtual Box +* Basic IPC +* Graceful termination on SIGHUP + +v0.8.9 (2016-05-12) + +* New option: Hide on close +* New option: Display shadow +* Graceful termination on SIGINT + +v0.8.8 (2016-04-28) + +* Single instance + +v0.8.7.3 (2016-04-27), v0.8.7.2 (2016-04-03), v0.8.7.1 (2016-03-31) + +* Hotfixes + +v0.8.7 (2016-03-31) + +* New extension: Terminal +* Project structure: Use libraries + +v0.8.6 (2016-03-28) + +* Restructured settings widget + +v0.8.5 (2016-03-25) + +* Custom icon lookup +* Make main window movable +* Show alternative actions o Tab +* New option: Always on top +* New option: Hide on focus out +* New option: Display icons +* New option: Display scrollbar +* Dozens of new themes: Dark, Bright, SolarizedDark, SolarizedBright in several colors. + +v0.8.4 (2016-03-15) + +* Show message box after ungraceful termination + +v0.8.3 (2016-03-13) + +* Restructured settings widget + +v0.8.2 (2016-03-09) + +* New option: Group separators for calculator +* New themes: Arc +* New theme: Numix + +v0.8.1 (2016-03-04) + +* Minor tasks and improvements + +v0.8.0 (2015-10-27) + +* New extension: System control + +v0.7.7 (2015-10-16) + +* Bring settings window to front if it is already open. + +v0.7.6 (2015-10-15) + +* Reorderable websearches +* Allow exclusive queries by trigger + +v0.7.5 (2015-10-12) + +* Graceful termination on SIGINT + +v0.7.1 (2015-10-06), v0.7.2 (2015-10-07), v0.7.3 (2015-10-07), v0.7.4 (2015-10-08) + +* Tasks, Hotfixes, minor changes + +v0.7.0 (2015-10-05) + +* Implement plugin architecture +* Port the modules +* Ignore file (".albertignore") +* Actions +* Threaded background indexing +* New themes + +v0.6.0 (2014-11-12) + +* Make action modifications configurable +* Command history + +v0.5.0 (2014-11-06) + +* Add configuration widget to configure the modules +* Make user interface themable +* Provide proof-of-concept themes +* Make actions modifiable +* Show action modifications in the list +* Use CMake build system + +v0.4.0 (2014-10-16) + +* Add settings widget +* Implement indexing and search algorithms 'prefixmatch' and 'fuzzy' + +v0.3.0 (2014-09-12) + +* Implement serialization of indexes +* New module: Applications +* New module: Bookmarks +* New module: Calculator +* New module: Web search + +v0.2.0 (2014-09-08) + +* Abstract module architecture +* New module: Files + +v0.1.0 (2014-09-01) + +* Basic user interface +* Hotkeymanager diff --git a/CMakeLists.txt b/CMakeLists.txt index 0dbc12d..ba70dc0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,7 +1,7 @@ cmake_minimum_required(VERSION 3.1.3) # Least supporting CMAKE_CXX_STANDARD ############################################################################### -project(albert VERSION 0.16.1) +project(albert VERSION 0.17.2) ############################################################################### @@ -88,6 +88,7 @@ find_package(Qt5 5.5.0 Network Sql Widgets + X11Extras OPTIONAL_COMPONENTS Charts ) @@ -118,6 +119,7 @@ target_link_libraries(${TARGET_NAME_BIN} Qt5::Network Qt5::Sql Qt5::Widgets + Qt5::X11Extras albert::lib globalshortcut xdg @@ -137,6 +139,9 @@ install(TARGETS ${TARGET_NAME_LIB} ${TARGET_NAME_BIN} # Do platform specific post target stuff if(${CMAKE_SYSTEM_NAME} MATCHES "Linux") # Install desktop entry and icon - install(FILES resources/albert.desktop DESTINATION ${CMAKE_INSTALL_DATADIR}/applications ) + # install(FILES resources/albert.desktop DESTINATION ${CMAKE_INSTALL_DATADIR}/applications ) install(FILES resources/icons/albert.svg DESTINATION ${CMAKE_INSTALL_DATADIR}/icons/hicolor/scalable/apps) + # Add HamoniKR Default Settings + install(DIRECTORY "hamonikr/etc/" DESTINATION ${CMAKE_INSTALL_SYSCONFDIR}) + install(FILES hamonikr/albert.desktop DESTINATION ${CMAKE_INSTALL_DATADIR}/applications ) endif (${CMAKE_SYSTEM_NAME} MATCHES "Linux") diff --git a/HOWTO-BUILD-on-HamoniKR b/HOWTO-BUILD-on-HamoniKR index f280dae..1a0b66c 100644 --- a/HOWTO-BUILD-on-HamoniKR +++ b/HOWTO-BUILD-on-HamoniKR @@ -10,3 +10,14 @@ dpkg-buildpackage --sign-key=9FA298A1E42665B8 # 설치 확인 sudo dpkg -i ../*.deb + + +# Compile on linuxmint 20.1 from UPSTREAM +sudo apt-get install libqt5x11extras5-dev qtbase5-dev libmuparser-dev python3-dev + +git clone --recursive https://github.com/albertlauncher/albert.git +mkdir albert-build +cd albert-build +cmake ../albert -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Debug +make +sudo make install diff --git a/README.md b/README.md index c814630..e1d3a7f 100644 --- a/README.md +++ b/README.md @@ -1,36 +1,24 @@ -# Albert launcher [![Build Status](https://api.travis-ci.org/albertlauncher/albert.svg?branch=dev)](https://travis-ci.org/albertlauncher/albert) +# 하모니카 런처 -[![Telegram news channel](https://img.shields.io/badge/news%20channel-telegram-0088cc.svg?style=flat)](https://telegram.me/albertlauncher) -[![Telegram community chat](https://img.shields.io/badge/chat-telegram-0088cc.svg?style=flat)](https://telegram.me/albert_launcher_community) -[![Discord](https://img.shields.io/badge/chat-discord-7289da.svg?style=flat)](https://discord.gg/enGMWUG) -[![IRC](https://img.shields.io/badge/chat-IRC-brightgreen.svg)](http://webchat.freenode.net/?channels=%23albertlauncher) +하모니카에서 사용하는 런처 프로젝트 -## Albert in a nutshell +단축키 Alt+Space 키를 눌러 PC에 설치된 프로그램과 웹에서 바로 검색할 수 있습니다. -Albert is a unified and efficient access to your machine. Technically it is a keyboard launcher written in C++/Qt. The plugin based architecture makes it extremely flexible and powerful. Plugins can be used to create modular frontends or native extensions. Extensions can also be implemented using embedded Python modules or via a CGI approach in any language you want. The frontends shipped heavily focus on customizability. +![screenshot](./albert.png) -## Getting started -Check the section [*Installing Albert*](https://albertlauncher.github.io/docs/installing/) in the docs for setup instructions. When you are set up take a look at the section [*Using Albert*](https://albertlauncher.github.io/docs/using/). If you have problems check the [*Troubleshooting*](https://albertlauncher.github.io/docs/faq/) section. If it does not cover your problems seek for [*help*](https://albertlauncher.github.io/help/) in one of the chats. Developers may want to check the [*Extending Albert*](https://albertlauncher.github.io/docs/extending/) section. +upstream : https://github.com/albertlauncher/albert.git -## Albert at a glance -

-

-

-

-

-

-

-

-

-

-

-

-

+# Install -# Support +## HamoniKR (>=3.0), Ubuntu (>=18.04) +``` +wget -qO- https://pkg.hamonikr.org/add-hamonikr.apt | sudo -E bash - + +sudo apt install albert +``` -If you like this software consider [donating](https://albertlauncher.github.io/docs/donation/) a :beer:. :+1: +# Support -Have fun with albert, if you do not, [tell me why](https://telegram.me/albert_launcher_community). +* [HamoniKR Community](https://hamonikr.org/) diff --git a/albert.png b/albert.png new file mode 100644 index 0000000000000000000000000000000000000000..d573ed7fcad57db56b63258daae8f6ac24c8ac1c GIT binary patch literal 214448 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 Bn2hSK(w6q%XplG=|G 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

W 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

r1Hj0K^=hqdyAD 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 z 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 z zB`5@M9CvEYFu zU5H8SIj-9(@|JQ)9aWW#n_oXipn5qMKD3l|)lDod0_t}!EIv>#5F!$4;ic5-enQK> zT4`P)wK_K0Xa-o@-L~@~?Jq4JYDcT$$;GqQ=C1N)k%s#vG+7C7~$Ldbmxo{fDm~aD9mpW-F%bZ4-ZcVftzx6+QxiE}ViQUm98TnBI}5{%l!vQl z>ATl=!@or~Eb;%+pe1M*&S}nkNIB&^CrNo6rs3VQf8XC0E532>Zg!#>zDD@fBO74` zT$m0t3iK`o|n8K+xCNUUpWNxh}FN}9M(i(h6XRzAkFHcUEb z2cbuC1*KDE?6a5Y1;?T-&36*85T#}ir>2d$`eVG6!(Dex<8D85p{puPpl(7_RoO)` zdgz5K%*Y}QSY90aTQ}61=rvoZlWBn&L=e6C%$v8Th zwoJ8XE6(b;`cub&4Mq-d|8oQsT6|s3#DX9BTj`1}xiiV4m9X48RZqOMXrT&EH5i*9 zF{W9zQU0_3z+weU&Z{zUfi71km4$mYu&+ zx2X9+sw&pfoG&;vim6S)z%Qy7HGmPCfGa_R?0Yy%Kdq)T)Mgdv%Ge^iXezE?!$q@F zVN^uytxrse6A>{*M0YWPH}@7bt7;pRICu!8*bdqL%L3ud(>A~P-N(}h<%Vm`%Z@CW zxm*pCv(O-qzs#rCX!Px{^p_zN2HuMJmk5;Taa?9Sf?JN`a$*pjfAegAJ&d=10?#qF zXEBA1B4T5APPw&YD)F}uGNyYGHsU&_Eepx0g16x zWBzM;X&U+**}PVAMOH}rx9jh-J6b8YhVYKb)uHR#wtF{v{ig;S8?OB?Rtdc4#Zhhl zUC_0x=F_%~Iw<4Y#rH38=0V<=huDesE&`Bn^rx~esbX*?p#d}sjTiGu+!b%W$(%a%-W0W_P8n1Z6M31l$wEwI}UjpGJr zD}}gN5akfWHYH?B%)= z9u23;WSvwMo`T1ck)0EBV$(%rJlkLX_T_f?2_OCv4#IGZg>8w9x?qSfx$(8FB!dJL zZY5gL29^@2>$yrUf)91^oBxf=dI_()7VFbV@x{0+M+R(4M7#3I?{pKRI_EUCy(40> zfBr+Vc{vJizL(PV4=qbC;Gy=jlAxiWPV^c>vV{~X9D}QY80$~y2qxJ-{nR^>y3T`& z5PDV~tiPEcqcEIWMSPS3&6HDec@>u_1H-^HfJiXXKthuY8w{fiBhe&87)GH9!w4EN zjK$zVHH#9cBnFWv+BNXK7+WlSC4r}lsSf(3Q#gm1z}fLh_5MiJENk+ zNL_%M?J`)OmB%zkObX8_XK|S&C*)MpmLSi=#iRVqi<|xT5cmx{uG&=2TW;`VkyKKX zrF=-7GS8V)+U-x}{gb~;H?}jA7-mBPu7QH)g9nIcq=7V#If;!U>7v)bg+AeSKw6}~ z<+BnOVy3R3@fr6Ts)i9K$-8wfrFyz4A5MyfX#q$s$Nj}vR1m837A#nC$`#ig&ms-t ziD9Y>iv`fya{fQk-n>bU9M=;B+~bbCm6A$l*U_)fo%f!t&G-K-Yc^{$)BU=;y1GF{&x*H+XvU0;vLE!oaipWG#NTvef{hQn4yNlKIU-ao0>Jwp_s|CP_GgD?mBmLC|g)d)U zC2o_XUDQBks=(~EUQw9c`y!xy+lZaqIo3o~8#~v@f`_yAP=&=;fYUzw^jj`^7BrAp z-%GFO`@!+L2SYpQZM;1y&M*hNz05Rvpcc>z^gma?lzLrtKw=aA0P+Wq#)#c?mAuNK z!2_v@Vi+;5Or;3x#V`=7hB1URw4OX#9<@7@@enNwR^ikt>}&-FK}869D2zaW{b73j z;`HLS>{le8)dFHHyXqPCp=BlriDmj^smeA{n%p7cXH9XaA*g|M75Z8lS_+D=XkApH zX`*4x-@N<$_IO(Ti^Kv3;4zVk&l*~1zT+aLl+#I0WjYm^go<+H}6>(1Gw(- z`o!JL?yKfeH8hPRPOt?x@s!sJTvr%DPux}b6f9Qh&h8`XH3DD1ULZeVh-~VZ$Sh46 zFZMWG`EuEs!d_EbMh1tW%Y=(_vT%vQTJ7UkN~Pt`x7^SlHOJAv}70|XRLDhfUS zr*;}Uz%aXcMwRKWrH7wTau%V;4}T>CUK|`b139Nih12va8a<&ByOgJ}tnc7BQ-xiQGNp>cz8gVh%Lc^FCmL*ldnw2Si8YkV-KljS)14vEBK z^whbe)IP9;<~Jb06Lv)lVt1KPGW5*0Cn*sL@Fbt#G?%%)f8Oy z5_Z^aY}z9{5EU8-BG96!r_X%2DL=gZbo~JO;PNfnsIwvfTU4Fyn(Ua|aw;fAPSfH3 z`KLD*ABIotq%*2d#aKF14d!4XNTQP@m5goHmEp|G&J*!xI!=3Tt>`t+)Frrd1~s)q z!WWY^?nxP}|H3IGv=-m)l9BUa+{VHI&bEif0<91gyU2quN1SZn zF-Kq4COQO}b`oXQ;HS;oa{}7kB%}H+67b=q%#bUq z(3Iw?Dy7?+))aqJBLuE+2oXR-ue`X!OT+(WEGY!P zX1zp)GO`M^==3oy1x)1UZU;lDJcc?U5mS|!P}^t^-W>Dn^;#n6l^s5<1e-Ej9D>wR zB^S0xo?vh~ZF*WxHH5%vf#OeAuqu)rDMS>St%V*5!7|yU6d0cnDHnIAcYpk}+V~MI z0u=H<5D@{9+`N&SSD+-i&ndG0DdcWL8Hu~WkfmCWCc;emL1-8b-`^izY=%$&lcxt7 zyfRLrLNpY$aHV+UKu_QU001BWNklyX2Eu@0 z#O_e;?xttA<*+8giWug6V8?SHyc=!DCi}h*vxWXz}MKC%Z%!CBXNP!f9ij=iLkFyd&8OCA#_SwIlji2bT z75DH(Hbt;g)+f z8chWtw#co@(@40p*kFo6t`X>91G1BNnev9SvDZ-2C<0+2ALH;CS7w;09&*Q&8eNi( zp!B=5G_QK<2h?d+S-E=t`2NqIc+_|@_)?N$RuC}D{daQl44Eu_vY%2!h$u6^y4K)M zS%?U07OoVH?IM{lY&VyGe6`zsqK|*^k}BF*?e#0Kx%)KXZ|U(CgUND{6^Zk`<#(&b z<6JEL)J@};fMFM_vvp{HvCzy6)Vg`lmJmR zz-o(eMZ?O-vIDiYk|0O^Y~%2o239yLDqAsAhZZu2ZhXMZ!$9MX#x*Gz!-|GA(Fiaw zfCekdzS~dF?xw3f#)_?k3FVwE+Eiqnr;RyU9ac({M%86ygMwkz(^yFCXc$bEkvrVJ zE8kswKKx8H4ZOC4RrBn^F=h5-K|z@yh2#-sDrFKmO(XI8{qw)wl!DKl)0&uwz?dy$ zu7Uh{Q@1*Lf|(m`P2R(Qp{F$ui9=nc@2shrSBNNc?JZvmI6htLSb* z(*V!W3s8Fx_dexrFa}GrTQL2*hHd0m;Z0L35)vm&?P|yXb4?ej?54&$hXDZQ5v4)c zJvpf05wWN9fQZv!Z~m*QP#G1JqJ0xw3EgRUQBaj5xRgM|EQCR#5?p3z9_GzNL8lfe z!O>Hm6?O;&>Y755js%F;pA8{HP6_Uhsg4*CtA7rWa`Ei+?$4i?AwmQZGl7WK3KJ0; zG>Kz@rR#i80yR{ zT)m&Anb?_-Xeljg7Tri@GO{YDXQXw5fo_o|=9nJfI$^yOJ2RH^`0m=DcRp+0XR;AG zebZBk6AfB;RO$@_&qk zGRW;`1Yk($hEy{r$k*<-aOt0L-e_8q3-S0WXyY$o=sBK zx2_J7GFE0DS2T`TZFsf8dc(sS!y3FcF(V9%{1D535r7!GeR+91-5fB8Ij$)adPD#H z%+zgYeYkt7es@;a2rR=kyZ&J&CaVQvr&IXpxFR%;{O!xn?}iip!5Dn&h!6o)KO=G5 ztyNAclgO!vCgo0LwO((({pRn7hXN1XpUJQ)erjZ!LEUkRFJ0W#rTkUb6SffBxw*FF zfK`p5$&_g1q?55~1155bpRF%;yaLjRE$mXPHdo~YE%A&6r%e4RP+OBc=1e;AkGifC z3r?Ic!zF%3Yzoe7{;6$3h?Ig-9nv6FV{^%8lTha*vIKaBs;;6GL0jD-pjtoGr;*}5 zJlLbfFKCW0M}}z{TAQ`b(?Uc@GV=HB=qeOHcn&DV^J6aWPjCP5X&BU6DG)-@q!ldU z@wfo{PrTw6V;C`RvE5>|!+M9+);uh%b#=j}Da@{#lv-hGj2hSikx9xVIF)IdWGZ-^wwIUk=IXEe2cSgY+!8ODr)fP!lIM9{$g&w`me+lAEkvhw zAi={Txf%d7FvjJR6gT|n2SrzbJYQd440}Z0XCDX7R5#U;ZDOQZYL8B4-Oq&|uc^lPKpwA>Qte|R(^_a_Ox%bXc^fkNm&A~!y zn_!Ki$Jf^NQWO3IDsXOmE>CJ)Z9D>>_OPR;Lv< ze|Z`{{J+G_M6+APvOPQX*SXKAr826RZr}A`QCegjqx5IdJ^qAWCMN5gG(DqF^gwq@ zr<1i$>moDYW}1!x3R+Mjc-~a=Ow~q+mLk@kdiTleOV9V3n}1k%BlM*1Mem`N+jAHY zi*gaF%qoa|=~ewB>z#r)J0q6~qlB z-ZjDz;T8difTR$JhJlBHHb>fQX}zQM4#OHeLIx0O=?-;|*v?j5^Kfs69@`+y(}Zy? zcekh8tFmR{LL?UO(Gm;Q@BP)@KSK%Vf9~7yiLl?jY`h(frKjT-K`AtyXjsz^Zy#Pf zPW*F?Q)&2oII=*Z%!^79h{z;r|0vTWli+c>yu175?cwL~Gf|DG&G4Ng>uwZJd<|>{ zv30B@F#d${5!bRUBql(^5Jk^yX)+~*X^?Q$5RuNd(in^S5MhtX)v&)=9qe(HAuguo zp0_l=dRC0d_MwW*o?|I_GDve{YQza)V2(gMa_C!}G9}5Oa~97GM4?y^1|o4!1yW1; zk2ao+4-SYBxMrhO7#u31M*GQXQz$ZxBEmiV32m-7rNI%12O(jsIC5=5MW{?Jae^1^Xu*E13vt{=F{X=Tv6Xp z&Uuvfq>|pR!lDk!tc_U+&AEs#i#(YN9Q$3l^v|o4up8MJz>=E-;&BsWjJFEp6$Urxlk@^rgot2xuOJG%u!yyO+&A z5d}+On?V1CbnTJu1L9n0Fb!i_ZLvMb_5#}@k82P!Jln+?QC>#gMVc4WGstK)v>>}z zLq|h!@wlSxn$}z1YGlb4Gzi#sE0aDKC!w;bAl|-8;xH`$u+!;QtLeqFa&tB921aR) zfTe~b&L^zJvTMcpPB0H5>USD3>nT#$6P*nwb{s`vS440sRD=P(zLoFpK3)DS^2jNA zBLEA=K~5rN((3Fiba?gRU$3_x`H0n7vw8kGC)mfSANiS5@x}r%ISabiOivLecDQ zx`{d^4H$6%VKXo$E})UJ^XuFN#DWN&f)m8;WPx;KSvP|R)9VA~zSQbtA^@Qjxw=2S z`{To~Qa3cTR;jr;MWo378ZW-bdXpwNb!h}rgKP5u8k~8axDu#B0}+x5mXtdQCfU8Z zz54cYHT@TT_?YdtoUEbx*DK8~ElHcBxlv@{F{+d8gK5mg^<{2e(z`y5G1wHR{S~qk z`N>viIVY0y%2;f6>3&tZ&ViKtlZiCbU!}sDw$L=KOo%%I(1wy6${Cqwhj4BbPvi4f zKGra)2JtP1k^<1R+Bpis_2K`a`Jm;n2+SBZSnseo$YxJkx`PK>KCVP4gdF6}oX#P& z-fcMrd#-ASSt)dx5it!Tt+uq@&}vKTEryL~+0&S#$zX-&MnX{p&yPUp9GVfVML`Gx z5~6V>7sqmSoQ_*rD}OG!Tq}F5izl0D8x+nI5u-WJlZ+XQz`og47Y8V#!lG4*1%gb1 zsn9g>@d9tIAMa%ve{3Xd0?9mJEGjQkWdkWE(bI8dl5(2XtIhc4?#EktkWWK0ft;h} z^s#Xv%q32=a9&_=P!2ci_^Yn7aUr!=-G7)Ah;2C|$xqLv$|gCRr!}vhtuIyiP`qTT zMrP|l8sXh^Tgl+Weh#I*PDd2YvZs+Qyu$5=7;)}Gh(}uxe@vS04PO|%oSWeKYjP_AC+(*BzBA))Y6Da_Sbm%1IASycADByfSqkNn86%R!Iwp& zQ3_;|Qne6V{_fSqH=E(Z|JG9bt)QC`UNa$`6ra=E*C+>H;EXLJh&9uVwTrYnFZFA$ zVKewjK|2Q<=f8H(@{F3&8~JbZN(**M?=n_v%`7;%Qx8nN@Zi))YG?tnjvGIH^*p49 zzk=UDxAcO~W&SPTMa3B4NAP;Ihf%u}3({Qe(P6Sd|gpz zntm1%VGzcV*E`-FX?u{>4!qL5mhi~T`|JiszFPIn4-j#U{2(nphSjD#yPa+?WgAwA zo(;|=`wnrJkCC#P}LRT;OcM8Rx}-*IVjsbr>Iu${L? z0CO%kYHz7D9omNGoJK7kZVq7rymqPcwV9R!N0dj(I>DNoqh@^022%T1e`YEiXSSF0 zboS0PLO1hVP_?zOEh~xOseXenV=O*%OoP$U*Y8s7}pJIOfiBZSpRntsyrreQJET(rRC_+Fd`?E0+}F_ z44c*MA735ri2n7zvZ!cdZx^=mz7(BDrEK7o=#wdoE_fZ5D{HunHe)8!)LoU>LEvEZYn0FKD%+ zVQ{Q83#BgX1_7wl;O1?62A=Iw-6E_9yU=D&y8||RtarjIV9>?S0L8fvOmQ$$hYMFE zq9d|WU_zuxZR%GVM(p?H`l?**%X$C`Cw)Vuihgtv;&WeV+w|9FiqDZPlgApQ>5nkn zNJUnt!*b(MARY@c(WGCAFOGPB`^()!k)JiAuv3gc;mk&)*8~SGlbJxuRAee7*xXz_ zzPbEy^~*qE{K$LHo|1ESL8D2H=&_PWB|mQ@p1P={HOJ)>>c|)Bg|N%B3Qpp6lBmi3 zFS?k72u#C^_2r(|NXdq z#KoPPEpmcz&#{e`R7O{0QcHG-7ZWC`qR}*tdnK92)mmOu&BzsvMcGtguzT14HpZ-}j$~53~`J8m}h4UvPyV-AF zmPthI0?Br|y9-4Lk`DUj)ueXb#=1^Y*tE z<1^JFVX2*@4%%#{UYtAUj`c>DZN0==mVQW#og&C8uOj_`fXib$oVLM25Dh;YvEIq% zi0u)Z9gS<>x!C)apUmbws~yIZ5Q~QZkIxs;qg$B=T5oB+qs>n1vV&Jd3}RB32#Ix8 z(<~dEuc|^(3Dkuzfk-?PM-$m-z-A{G$LVq}yS0q^WbtA6WOR$Mng31%RBE?`f_`55 z+46N3>n`WfI?_b696MVguAYu7mQYIZf-IA*J0L=N_w?=bX#DFfxgpq?964 z!D$+Yar5f#!`=9C_^e03_(0L?SZOpZ+wML$k97fsSSW5Pskk5{){Q1boicpSH|s`ng(7%k?+8%mpc>cOo_8~pG#A@(qh8K;Y&J#;gX z{SNi^xzLPu=;VB#h$786{8OQoWNe!_al)`r-!Mxgb%&V*G_tEtX*;s@{iC}$wKO|v zMvS1830KeM#djWix|p)uz+9C*!%b6%FQ>cf>A3c?A4@dG z`AcT7XOKPz?Ck1o3BZS0U}|f`eAn zShE_$uSZ;zlZfgcla$kGv)QfQKmY6TK~N$IqppMVdUc%?y3`{zHMKNDk5=H z^#naNpt|~!N-+nxsyB%PxSAC`GZ9Fr3^JHjB;3H`Mfp;I55@j3ydM+7mlSj2!DZUi3miiygk zrO8kV_OEVkf4CWb{C}vN?B#9`;S}2QGUpYU(Ru)t-N;M*O9VE*pOdz#R0gFvB=RYM zhv&}OPZrGG0Oo9`4hFNQ7fgN4;BpJR^izK3j9}>AUVN}oV|<-QoI(G5yB3#WwoB?{ zb|}NbC#SO+I?iFEwQpgWtg1+E2-qcblGCOZ3~Ow5vcJUc5}O_INHxQS$PWbfK~?9u z^-?$84oj5ZP%S_q0b>|=v!%_Rb{DeVgI6M~=hGU0P_EFTVR`n_OsPi2HSNV*FaVJ- zhCz1Qa(SGtk7YX&386#?T0-%1G`Iid7`2m214uI^vzzQ9%l9^@tdQJhqY#UbKt!k% z^TL!ulQ1#gT;tu%hwF!eA2t0g)=~v2EMB3GxC&w>kV&MJX`1LHB-mYCm3Pg=c?gl<{Suf=*H@TdZA8}Z)F zR0(jzFhc-h0kHu4VST^8%w!qB)%~2Uie&Z-m8M~L4J3)?w0c&3v{y%x!s3aK$RQ?~ zLu>gES;AL_h!VqN9Z+**UdDOfL>z4!p&XI8nzeWI z06Q~xCSEvo7P<>L)`^JBk>#uZ7yc*a0iJHG{^u1A(8?NSZ!o~ zlxtSpvi?5CpBm0Unq(JK7#-bHKR8umT46w!o-m zXmGPkB!N)3Pq*p2TE$pZDq`BvRzq9o_k*M*0*O|XD9(=az8EK*>qG& zs@$eZV_Ov=s)<1C^JJbQS3Wcl6;mOh;rhC~IzC>XrtzOF;)!*+n{eYLLeE~9$s93d zDkw!BPpfggetrAP-T2G!z?8egxh|`1deE5!e#l!2(b;Hjs@StJg?6H=v6`Zxar|}B8orW4rA;p-Y!BNr% z!8L&XOM+ja4CGjH#*AW;+?SIC%C$yv52Xpy})+#aas%P*S0 zRzxtJaCI;D@4;CSNYhX^b4$Iuaz$ajR&xsgnMBo{aw3@^LLk2V^V`GqiT?FhVx}5w zd|q(R8gXj=NtI!5KVIeool_Ju$?yEFNhBm$L=@Jv59ERr8>*Js9;W&x04d z0*_^TEf>#ZcS+-lOmSEMCuudUl?dKFRPBI8d#E;`0hLU=J@E00_E&}15T-&JdScX_ z*zRnQNlQ?7G{`}S%zfCF}i8HduFJ&pw zEUuub){>C$2tyqKrgng|5IY1k6`UT2&4Isr`S9}eNI$tWti;+1uP{kz50+LVQq*f) zrb&v(ROE5mZuYBh@BeoAEI2i2XNBCjJ$>mqBWXD%Prqi&e8o~{4G^IvEI-l6Vq8dG z`n@-w4lM_{Av`TnN|?g9@Oa*)FngCbdmUQhB?@8zVOm55D~&CSiAA< z@lxVY(_@}Y!$Sz&vPv!hepd?wMtQ-n^kth2^-t+iz_uMJ`<_3eEnht1k^K znM}Ri!0l`bl6N?u!+f|I()z(Hhq{0OjmIP_3F-&aV_3`fLUvcOyQKBj4YEpPZ0|

lF-~Hpj;o1|Ykr*LquD8SO(8vh?((LxFkN=aoVyl0GKt?bYue|aay+mR8F(O~ zf^xUMJdRtL6<~2t0goz;TS7c!RJ6){D--lzGka(lRnok=NIk117#5HSbx6e(bkRS-dhqY6ZD^-R9`9yt~yS4`ukuMAl` zYSWCB)42*Vg(C)K!sh09_s17&`H?<-ps@z`w9PFF)cM6h3+X*>2!v-3fB8DY-~HE4 z@YEY-q|NBMtCEz=U?X(;)BdqjB zgdHulGJ9ITBdH@TZ9x4UEflU6s1rmhEWu151tdj=6*dRiUt@d3YD2>qJvGqOI0@8W zz1WwFd;_BDI%f7@UT2wYON zYsdhX001BWNkld z6&&3extoGiXDCI_zCjU|f&wkaK5TaU>iY5d@VNgB{-~tr3S&!7=2J+89fic(Y}0WC z)3jM_hgUa0U(*Bs!Y*BN-dv~xd7Ymd<4j&~`vx^!e(CjD;~`HL6rU#`(QBrKSdA+r z8S0WYWUHATSfC0m6QKZC$s;CJ+s2 ztKSk@1fD2ws>NF47AS2M=NRmSAJ-TQQ%F=lXM+e{BGp%48rHz90lWh-NH`1@ZUb`G zr<55sm8u>@7)G9(Zpmd7^f^IHLKrJL4a&Mc>x46<*=kzl7_>cLoQ~9RTP*7ZRvBax z`Toxj&t9LViG*M(h?*M^+ zKL*O5W^dr!0NEdcw@EFIM*_uP0ev2{<7{z3Ea=QQ^EiWPCMy~G5#T{*Sy4PEt zFtndwZ4!}N8a!kHHD7)kqK^hU65t2v` zvb9f?yg#4<7RYLY%fobYbvkZkO(atw-(&!4_Jbl%kvPQsNB!Jbx~%Y2X1_pv)dbQA zS6C#zEf_Wy5;9L&rm?xOe7GT`&?F+D(}`&uU%z^Mzx}xW2T2(;oxq3C+ak?*U~xD^ zOr?l9VpQ!w(R1kp@_0Jl-c9eX{>mR1#B50(a}!7ive=ndIp?sPE7aW(z4Iq+Ip>ga z+h*{UCj4T7xdpbDuLWC(s8%nwAfc(i>O4?C0=d|65e|~wuz9h*R`kLWQk!1GD(65) zUKfKf#C+HSc)~AJaimxats*0_GNGuC<|Yy6-NB8J1#xOQaqsk%+^GZxt2x9v;D|g; z0Fgj$zq)+Yf}Ecd5DCtDXS(o2hb0%fJM=16sj*%2w2{H|M2Y9>2zYv%(av1CQXZ>{Uu&~hhdnbxe{3W zVI~LsD@+Bka8$K_$Rwoz1^aKVZ-09;{_?+=3V3j=2LhJ(*5bwO`mR&4_$))I!$a-U zW~H0iJfKBX#OS$wfkDzBCqJCL1d0EmYv;^3gRKXSD@=(;EvgP3?7U~|{?XMC?Rlhj_7VdN3=NX?ryf;8sT?8*9JSYf{} z`y1>pY1|OR%aym(SiwXrgp|*cKkHY~5D;Rfan1V!4j0%QPqc!7K7+VaY&n@2oA(jh zOsLZ}S1=}x&Hk%E%oZZh&JsFPR~5D1k*MW}$*YkqZ8UhO{}K2P|Wg|#An zwN2&~7+_Mh4_Pu{5fn||6Pz>}Kv)T=VEuQ-N!|Er$^do`Ar@3cS1aXn4LpR@`v2aJd1Iok_%a z67fToh8R_Mg#?IpOvJYBS4;(7glX*YgHQzeyGx&`oeX3AtS9>U60SfruX@iJnAR@? zBDaVn+K5_hJs6oF_#C!cYRig<%xea#Vn}-KZi?v5O);gO^=CM&x|r0LZ99c&qUUcP zU%o#{A<|rxNeck#88LKmE3bZwVW^08-IXg?skF0Z>M6F+NRq@4}5dtvcfq{pfa&G%Z~obMW)xu-?(m6uXz zJLwHAT5Exq`~i1l;rq%{!}lt=IcjLrIwr97jJOqKDXeXGF)rV|ibNQ4?Z zU}v(E=DhGI+haN0%Jza*>ly>ru2~8(8{*V?p>{*=(+T}U&HDuA?UoOhvOQw86O2Tl zVmd+_6rfVB?g7)#*azfy;5&K1Z6yRi&uah=*lf#TR}Q2pJ_@pu3+ zU8XL3;usHBlEWX!5q%BgE;*omnYdC0gkGmcM~Ilcg4 z8Y8TS34x=Tr_fLDR&%nKK-CXGDY&{jefx*cRwqOt#p1pN0-^0*zWLs)t5Ko5k)6#r z^keT!h%K%`AX=1NLIo)gr|aLnx_-UopZ=#ER?b8%sq~9zVZy0>05#XNJ{WwlX~*)S z)sje{hN2P`ovobLu^OcN(LJZN;;dbz0uQbz>TRGQ38Eg=Xg^Rlo``|>hr;OCH5HG{ zhqL%hXH($>W2geT$>4a7$UMs2ZP-++$$6fV*}@hAY=~erZV^u8n>80+-WZY)gqe_4 z;Xo(~n)6Z$XegJ@rmGjUIgp%~p?fiDfdr08Cl>%TzYv>R$|OT+8k>~_hs88HqNu+Pa?1xGG>JT( zhG8?jdv$uV`ndX$q%aMZR8e_t5_icy?$hX25ZjZXOoB3oZndupv}tXXANP{Ou)~!0+#pwfGeb?x$Dh>36uIgvM2j`#Ug~FV zl@GWyw`v^LxK4wWNb6zl$yjW(sIYn$>Da&AKvtj2T(wHi$C&d)?JVTDR({KO%6GSvh zqZCMyQi|FtHhaAOH$SGXLaTradhN<-F_DpPy(~>jLt(`asMES+G!A$F@$TY|>F2+Y znOq{EhZD6_i95SPv!BxEepv?(3K?l#68WCE`oS_~bc$DZ<)6;U`}o;s#<^i$4-s9H z*!Y}Sx{i2O{?JsXlx_$c!rti5g=R{Ssqb$$noB z`*N`>R$E;dCn^bDo+}WsesvBKy#`8MWuMtZ5~XC6lM}PA%sT7wP||gho?yD2s~}n{ zMFaw^f68hLnF@h;zvDOer|0X(?WcmzB+TxA(LasSUwMGif}>aLTskSGOu%FnQDvG2 z9=5kP<>kd+wvUsQcqdoA5D4f@!p-7n`BZvfSz(LUTb7&K>%$P|3%iwxhTyD`WO(M+ z*$VC{Xn>v7QwRw$!G-;>dA_+wi#-?sQwwekAWk*#`c;a*WG+OI2Mv>kyEk%t$1mlPU;ZXa%OhR%^@**+a~(xDj#n(ogVm% zsr)q$M+kbdZn$9-IInCQ1e~R}VoghfR5wU`fXI43z5BP%JXkqFmuO`z=`aurEQd@eMQ9jqfB*7$`N$uBs@x|Cq++a@$unX;6U`jQ z-PIDFe@mK6(>E{l*pcoRG!K6U3t!stIW{Z108!fV$J2}C-`oiwdL&V_V_tlH-p=Bn z5~|J)`s^;aHower&s>!jGQZ95HQgcOH&~Pt#KV4%!zH$t!Yj}Kke=tlb84!{sO-p@N&vxDhXF(Y z10rO?RINL!l^hS#<$gMBWIbS1HYF(yA(1Yer3bb9#hkkR>;k*8k904WUwWZ$*WM!;xNHeZDED%>&5tU%Z9+5oI7^3ELI9mI^y!M$gQW zsc1!1DS}hk?Dzcg>ca&-4-a~(cjbf&9A$wk1s*a&5b+h%H*!|M&c>2I>wFI(fVbeaV@WYi%>!G*4KbsI^n6=VEBfRKwctVO&}r@ikdfp=l}8c zu>VNE{39w$&J@CsH@$tLUC#3h^_LhxBl(wFGAnx(v6(Q!qR&LL(xQtiJwejnj4z-J zl&cLOB6G)8fkTx%V!dHLsxnDm;#S zc|+IF%4%Ou1d)yuOj2g}^Jp?Y{a{3ZVQP8!T=3SqAgmY%wX$`NC?kY z7du|T0(qFI9*~;`-*Iy!fvV4>Oex|p|2N3)9}O-^!M{SYp%}mt(*cqB>LS*$pPGv0 zc7oeR+OO<&PhzmaKRZ>YiU;?{qzh;Ul zs(heKK#_5`zWu{Dhuuf|<;SSrwX9A&^;;HZonU)Xm@U6zH~fz zg~9+gffN9Q0s_D**&fT`M)p^u+~Mx3bIWfo~$135SKLWqJzz zsBd@PqPg(vgi9Kh%ir`$XjXP{___w7q7*93`yIWxczn5j+TaaKMI!Ut^1H8F@^EKBwkBnl%7MhQMW9b2OyV~EZj#|$X@UZ3zZ>xD5J@w)n zNyQ@@MkJ4zO=PZ0Iq79xB+IO-iiRBId85Zn+p0q5)0w>6Vl~K& zH45YHx1aBxPkuU#>IWi|2!uzx`<)!FY6;i?wJ|8TILUlY;Z5huPQEbl=QUvpMtChu-$|Ma2TMJE`@BH<)VHAf*(j zSR;<_b1j^OgwQGo3o_x$&Bg;sIrtSYWJP3I9-Z%WF}o=1TFxMl0CRr`h_qsoGDH-R zkbqeIgX6kf+?C@Et@m}|)~>yK1mqy{uyc6+yMSv>FRYhRc)J^}uCcqEcmoo1$5O@-UG3PGk zB35#YZSFl$E-gq%FjWQJxY-*NrZF$BWKzzLx#`XuLBwC!0J?d~4OY~0`kQV#H@8Hh zYy<7g6+Q8UW)z5X!;&fi9@=QLQL{-LE9wCvw;^TSt1)8^ZO2Z>W)gCXNaa?k;!8Mr zJY0<=g@cGl5yDh(_ww}3+ef{n)!Qu=1OVaHdpTUiVLOVT>Us!8L{Y|77T7;wqSnvm z=$VSwMU_&7*TemPyxq#*>ERdhI!Fy~B+9h0bo1ObUv8NRKB?r)-msa2Frh&n95<8=MJTt3HY!*d8L{{5?R8X=I|8QuP&x$i`TLK;%Q zn=L=Tm&4U0BZ|bzuforuZDxdP&+%7P7g%jE|KR!uQ2|z~a(8>WyL#NO-0jlXt%(|O znYl*{jM_z*vEEIQKi%lHekRupgU%X=nl3{@up4j=qOIEi1wvMK-Qqv296L@E(=fh% z{rGPEY5gNa1|Dj-GE)O}Y?!mbgnco> zKea+9SYflV&4@a`@?EyIod3*K+m9XtwToOSdXKrQA~wy@)7Rpex)c+KN|@@R0TB%} z+^>(ER9aX-NK?7pN0PLw)VMzo_%YP$ctQgSB1}>J)V9NDPPvOo%JTxpuXSg$*o28# zLP&?TtbEXHGH8CELuMP^xat*4E6PGdK=2BzmaA41s~kr<&2esDzvlC<+~KK;$fA_X zi1N&!oJd#o#KDezpy~z@05YlhS>)<=`tJ7+;Od^y<)%u?^S8LVXOX3Bg9LPEcnKIi z{tslLbE%(Kn^`$oC(w(1Y_MP z2#RMdwp8#1V(flJtG?JTHFuyL(TvyFf?5W?d9n+Xe){?v)1T z4o=nyHtNZ#Bh)3!ZrW4S$HbnY1^aA%Zm|A3&x;V*uoW)YeSuebc_rhK#g zbbOfPX9ib)Zbq*{G?%bQ{Rzkt_lgwAq=6us2vgSU?fUKIhuhUJ!v{tjoyD^jDNYRf0Ot zMu_%h2q_b2LS($d&}yn(OhwE_-!if)F$*=U=yGL;O^dZDO4+`1v+kFs+Mj2y;b95{ zdAx2mOw1dv?9TpH1%m2EGp}uFu~0|Xo>v!5o+SnSp%zDD)8>q`RT>1qg@g&}3ikiB zG)NI(cPQWg;b9oPXjswIT(#-q?j`PDJFx7US=E68#}+8l+7IhlT|~(aGfB~;+ya@( z>ae~0{qs%v8=XFp8$r&}%kmYFM0Z~)O&3*@ju$5od}5vE?IwsQN5wb2bTs(1dh`|d z%`2Gz@E_3V%Au?zF>$8r^w`r3ioOD|UxGh=bs=;1suFtE^%5)~YQmJrebO)y2B=*? z{V$**0GGpcxxB~r;HSOJWt27Liz|6Z)CvOeYVM|jND&h7cFR|Hvb&gQtzBE=%kql* zu46exP`8D(5}CIER7lTuDTm|f=5o5&mbGRZAfeAEqC1GIhUsRsq9bER&|Im7gtb-H-9Z#8^i?$cfr zl(j_v$AN*OcBEcqkd%peb-@4JFHRKR_q_P-XO#9Cp})gV=wO5hDVP!vmN1|Mq#a zmtsjW8WEy-xpMW4UVRIRYA9%6@FAtmd8(Vj#{5lIicm_*MVY8fkRq$&_Qij`TRr}T zP7lT9XWL)AGv_Vbf9PR| zTr33cnb-dmBr|>$*9tYsoGNz{@2;l9N~jQ|i>I$FePIslzVWt-OAh>H zUTTWWd|J|-(07vXYYnvZCHBo-i{HGkJgZ2(Fep^ifrE2q_Lvz^1^x;Uv93*MHIDKB58^j z*=Ym5=DVp}P)FF}5`uZTIEuG|q*ISA3iO+mAS=Yfa^gk3G*PA=_k{*eEh(T&z?nVJ z^aN7PgNV#$+pfI@8i-khEjS}`6{fHNotWB4UP;=GOFvguRIuknp#>(ACLcBR}A7odRC1_;8?$o3cI>8t4&JBh9R3=4>ELOh4li z1ehDblTqF8qw3T+%3*uDI-V}}Wjla~Wg;eW?`vjxbK%q@u;C$bHB&q%>3M7I*FJaj zoF0Twg_;LcPlUyMD94(FM2~%+a=k-sJ!aUYli~zR0v|78NGbf)|I}w*O z|D~J+Q;}(sNmyumc_}ZC|2Rx1ISmm^X(F<52*glk%ap>Xe$Gicm$EdQmsZdZgtr3I5YAyksn9s)gChQLLDQ=3o`&2_e0tXoTiuo=*K?Q4)}=lZi@~@SEn_hr?Qj-5&m6F-~HkZF!Q&r;J;L7SO{ZIo#^@9|VZ{9t= z`OTx6J+u^$ex3@(HQxLn>rI}5I@+GU%oag%$7|gY)q12%A}5rBaw_Y~?cE=ruRs5V z%A>0wfz5Nnq<+#CuAaP?o|!j4@05)a7u)wAUGVvDb&lue*-mo*AHX>WJZq|b3&^l8 zU2PD0HrFjZdsY{T-stSxJy1d93BwCLG)cUTJdC(tm!iR~T=Pi5AB6x=Dd5#~c_)|m zSZ$mWoI!itcEVNwO!qM9=*owthVptn-rdUa_Cza)MXIvL@N-%wiKCLU4Bt!z`>`Ms zck#e{NmK;u&FSvy@%AunN4ExRlNFEQZ0`gywWFPBe8da)$kCl2TWD}`8t0OAE}{LO z6mugU0W%e736M#5Fu-XVht=@*n}=8YdHsv2T%72(r52csK{MWJqGdoxNKf#zT-=ja zBs)zb4ZFAZKi$#;e~u^+-*xwkD=P<-K6ga6sG~e_%@voq{E8l1Y;y?lr(_CD3;+Ni z07*naR2JDX0LZfPiEDnEof0ft*b?an7Q*GYz8ZHP4pMFW6>ALG(Ft%OXaH#p zrU0aTnR-)b7|bH#UBpt0ziGroP`6GSVwrS|cE0@h8Rz#N^UPGGVn+=_d#8J#!;1z* zF{@8S%)MGecq7TSA_HEvjH>;>P@a#Nam~X9n~(|e%v%sA36WVqqeZm{tOO>6IRDQh z@Wi)*mZE!kQ{MmZSPBHNO6{Ur2!;{A`8{?AjYwrjNM6}i!%M%WNGPWe+iS2@JJz}& zlgNarh)go>*DwC_?dtPisXS8BNs0V$^)uo+jrbgAOH*?8>NJ4a+6;25?5oqWB1Xok zm3;)2ID&mI5b)PQyL5BT)tuz#icjK|>FI^WIIp$rw@&{q;b9rnCp4-K`gso>o|l@d z31J+&THU^w1H*`(o%)H0%Hg)$e1q+wO1s$=*%F2ngx|&MaOg>LLMT>;l!tM6c8`m@ zM_S7y*-B4!=|%W2DyiQr7hSWbsu%;u}n zNR}2?>j<4-b{6LL_CpzQXsv!?^5{@)f zu2a>Zy_r=Z8aNJzXdkYhuTR;Tf9q2+Uf2>tI@mcSgrK{|z=lI=R=xTBCnyL~1Atd9fTpXsW!{fzH)G0$0%T!bz^ff+4>J584d{VJp%zgS2&N*ZG7xW{-#xt8{$usY zB-p~RtnWOtf%h3=TflzJ8tAafX)2!-WDEQ=emw`FKlUqD=u&hln3y$wnmx(%o6W_V z$Fz^nT0jE{)Mp8pyR`A1oV(0e;(C)!Sdy<v%?EzMyt3 zh@glaL#@SqPzrwd;qiD?iW^Ca28jqwCwlQtZteq`0H)Ckdm%%1A5ucSRXE8v-W^e-%(bU*1WNrU@Ux>3g^ zx}LI`Y~iJ(*EJTqO3m%q+7bAyJ4c$?MQDc7r-yb1t6y+4LR;$zP_2b>ev>Sy*?XxX58OytDX0PDf(QYfdo{)y!6m!f5mY#S*LRdUR z=i78Iv{|%t{xmDk5^*OKa4B*sOfYQDX1Yr#xG2e{?QfF|E zrlg2?7=?>qGrWY(03r|%;pEAihM18t$UQl#&4$q_BB7fMI>JZ`AyCjy6F{UNDt_xe z!kVm})~-H`F6mZJ22x)R#5Tmp$DB{?*@XIC!$Q8P|YWGTH5Q!A%+>?8H>V zqD>if2aLtfK_IW*KiJFF&;)jq^b)_jHh>S^DN$07k z2}DZaBE$YbzkTuZ&4)=og#9Bl?X+NwDRV-!aVsC9(T)HxZBiy!6iAumB$%e{#Rb2+ z{mbqn355xy3(xPCT3RLx>pJ7*iHAGuX?`U?AAX;6YZ<1{RMzTG_WS7h(oIr^&pfbj z%}=vqSVV|T^=25Ktqu_m68@JY3%Ma>HdVrZOM$(0c|GMRXte|;uMOJDP9^uicE|UH z{Rna)jj7;9^H{>ZMGVz|bR8Od&T(CAK2KSe_Dm{-4-vvg#g>)BX*QpT=1T?{G$;UR zrWev}&M#G~#*A9i((4>#?l1KE(O_M1nqrUQyNsJ>)7x)D1(9NZMFfXydHvgJlkrTU zKo$3Zq$%Va9vGEb)e3S#DO3tphwc5JUT)Yo&+LutAV$2_<0v!v)<=VCMlEGaF2taw7%CR?WcjEOA%jq;>lk-7{2_J_u35> zAqj)VEM${3W>c~Y2E(+!ELYF4yHs`XEPye6@Lu4d7_dUqelCeH4a5F`%NyBVOc*hV z3l6t9c$58(Jojbro42Kguz*O^k2jS4?sRoLUG2+e01I`-53WJz=TY5{Q13f)&Oa|O z^RJxKb0UyBN^=7WyE0&=Zg<&w3XB&5DFXd_D#K<&?`|Gm4v*^}A%)v2WZjytvIIoI zzzCibp=4tTM|uifnSe=Tn&ebuDgzI@7xy1utUr#Qnz~i9lStaJ=a|R}iGIwRc4WJ^ z(TPOFL-+7GB)6*9!o}_9q*yG>*U~I^e5T5pb0jgVTE-$y=Bi`guaE0tY-cR5%bAKs z7SKv@xQq>^5e{?q6z&o&ACj&VS`sqFbTgOoeTqecWnb&sh}o_hvCg)OmGHBjku$_o-rGx{bGfa#tid$vQA#NMX^HHa@6SQ;OwN#u* z3$<%!7F>S`I1~>;AXPg^3Qht|#66YO{j<||7a#XOgC`)&62wX8%P>X8R5xZb;hP2| zC}f9IoJ6KlPDP5~aayg`n|Jp=UQZ{SGFOTugL90ky~!D?y!>F^ul*`EFqe`Gug~P& z`DE#IKRP(qOy}9j*GvoXNGi>czg_RIRy&Olab{#j{t%J*Z`eJEAk2e>{lZVMU6}uN zeOvpvPM7j*As#ez3yCdw=TP~U#*dl|1(Q(#DQ6pLeoi_Fl2+`R$XWjLG*o%= zTZN(OM$1EQ&8<~DEa?l`?bHL8-{blP{xM1O<4d@q-`)$-`UU&xR}R|#lP_2RQcPH+xKEySzg*`Hn=_7C*Szj{e=AZ}yK-?`F7Ieu(;0X|hjBI$ zL7+rHm_SfqnT5cx+tcN(>@EwBn4l=BNbSZnA3`~JtU@8n6@2;nJ z$6qcU3OzE1Rh{$vc~d+@Di?{-XVkFsNe%qfhz?cH*(&ljaWmA+mg`0YH>7BHVDgli;KNLq8CipID5t0o zcTzbr$uyo;NURbuMEUmB&Gh!W$H{|KEiYH76x_bR{cB1p$ZQl#B#t&6RFAiS*y(hB z7!AoJ_kVbOad@DgfArI@*=+X9jYn(l2%PRl0~ilZpOmwXRn*J1!aQDXAc$b-?8RqwP(*B*}3EF~HnC z?#tuOt17d)s=DV`jo#D$|1Ww^tKHe@>ALcYa3cYIAOHd+%`<8wSyxAzo6$%R#6lc}}(?|FCDZ zt@_hTIx%sGxopj;d%0$22D-fXdVe_|tr)Y_qqDb&Rc}(NF5h!45EE(@p2tMk`%fE^ z=|z2210aGNrIKLrsuXb`2*OL)g&~(mOSgzu#XzUWR zFXy7bBrILVow_(^+co3;lC|a0M|HPkT`p3atqyC=uQqE5)z~z@h&An_Gj-ml%qsho zAT!tG>Qcb#em`s;&ln3!vsk*t0J`IcPqWqh-$ol$lF^wv8xGJ-SZx!LhVp8kqJ$FF zUHqL)k`6*tPAMlz`5-`g_u(0lGZST?8i?V;W4?bY1JaD7Sy&An8(MUVT7)c6rko+m zF)>7mDbdwW_ZK&SfBeRi?OSh%QQRBP_F7LzRQg{r%if-S8ILXLczeFb+}ZzaA0}#r zg03(#&y7=Ht#0dET(ASYt3DJr7E$yLuoH0IHQ*_2sFjAb!Je@k2v_$xdq7ACi&=I- ztxI6C_!aW;McTgNqm!WLD&Qf1Nj&;Rr`v`c>bfiYRsl1v)_C_o7dJDlV5S57=lkvM?0`5S=SGiUFl@Zng%y@6yCBd`YcO;S z+n8tIM;~hu29r{*HvfS)4pd5X%7875rvFH)Z!RGiDp{zBFw=B?PCwoLe)b2^uI35a zIvCLecAAE!dz3LX!7cw6Y?U}M5mU}wH)YRx&YWnoJ~;T{?w9l3Oi2&MwG+dFr?9kX zvbQ1QCC&r^!aBb%3)rt-iI!HqaV6zbRo@k;D5R=d=b&N+mBZ+#k@+~eO0Ry635V0SIO9S$_5Q)Jn2Ii z3FqCh>A8}k3X8DouGbrT)@rvn0{|rEsT%&810q?fG0QIkRGxbF4!}4nsr7j2pdB#t z5o;#_KvIg!qI(j5N4X*X@bmNOMV3iOS+<**GEFOZ^B3M6xQv2tD|6Gg3?PCPm~&<- ziKsK@MCC}{%OCHzZ#MYx?=J7halw*y6eKws^CcY}yukPv(rQokV@8OwVowtofh`2A3Q`*IN1+xmnnE}#dCK|(O>l20=+ArLWP zK0eDAcXWL2!%ZEI+yf?Nl}1qN%yP0_S-hTU+HBzRnocfg+E9X^QLB^^CO3S0-Nz<& zG{j@ukjv&J(<)t_J#WwFlQm5MoB(t?gf=@kiahO&GYlP8nZX>bt`2r}l)F)WlL(gh z94)eKy;e;Yt{&7{hV?8PD5J^D3`x(zwJea7aJ9krcVAz@)A|=+QWr>=g;xlq%K~M9 zL!vL*UtNw%lsPfY#rP<>AnEAxGQB?ikE181+9Eh*D^gvCb590>!+_$`o_LP*9nqpT zMR0xW@Y*BXNl$hL6UIs!2tBg8xYM{#A>gp5|AW0#0pRZ7bc3tv2wAvPpLxAr4YI23 z%H9WV%-skr)o(N-Lf1ZFz~T{!Hktd(gfsxu$j+puN%NV>1gE5&mNpXw0qV9E15}Kl zi9-tpTb<1o0b=nO%Omb;QoCBXwwk1e3GOZqVbsgt-YQbIv4tuoC2%&fi^My*b3+ z{wL^(qA*DL0woX~YV;`DqYk~kWf&mcaM_oKg_`>omtZifv}t%yUO-e5nZRXaefw&= zxm<>!ogOS%7}!gh*a3vaZtq7RD9dzJ29~Y$`+&1-03tg&Sp0<{mq13QX`OCgr?V|| zqK$(iRNG}yf*@gCCT7UYT#ktc%ESQc>l?bfooQ8AsPC)izK(kJwm{BgN7%^Hn*_|1 z&(EJ9u6D=kTs9x`6;@;hMdF91a3_?A#^lY%`o0MqjZ{%>4BN-7?GANDt0`N}%CRU* zHk_=NAO#)7BieKdPT0pby?FSwTUdjEC9t?p-m!p30H>scPLnhAmo)?U}W*E z=rp<(dN>XBYygK&ElU?;!q!!>A0VT7B_pR_)`QA$h%mWcXzyZhnf^X5Nec0)BPoD!8ctof~Ou($$W zM55*zQ_fVD!|W2JOes%*$8R5gd)$1^PZLOlM@18ZQ)KAyuQ0SaqM`ZTfG7i0k)uC5 z^fClPu0Cu=!5VUlNSHfdpk+pINd+Rl9c-a~aG$%5mPQ9TE6`gZh;Y3=)>a4gI%#Lh z)t;LwFrqd3EVedFriHJmb>9sx7d}86aB#jBFWZb3*uiNa#RZ*VFhI4uNL>cdlVEBB zhRX@8%>kE^t7SD7^HD?;s0&Xti&Atb8EP|gs6g%_nx#yWf$K*qcC!K?j*wyx)a<>o zD25p5^>_37fT-*SL}G>H%*SVR^BT*sJ=PEhTfhNcbq3q&dnh8eYyh7qCrY|B=4g9* z|KA?gU;meF#nAZWWSn~a<_!u*2Vp3rKvl!BT)@@0t|eP!)Z+N(s4zP4oZwo9X$VFm zNq8T$gQ`c5#OO778}<_TlNW}6>J^lC<%QM;u^TSzr;6MTq65wVCBArcK40GR(J53$ zu60zsSQ!w&*7urmkaZPqCMKRvPVw?OAD$8;I}=2LtB$XKe zPmg!k=g;Ryv;yV~!u9(cVU2PaS^!=(S=`e3ZQ7AkBX8gtkM&nVbqrPYTmwSU2(B_a z-jbzJW+dX0g-XP!Y)ZzI@^o;B@2@}Irg{1U!!$OSKpwo#HjxLU+f<6jtHi@(ISfe@ zX3muI8dvML*S~IICniXPP4MQ;Xms|;iiS%gVmz*?dD)BKQNK%7Y0vL?|vkcm%x>-dX zvYPzDHEm$aCQ%QLxor^S`s}_&e zrX(6tY~0{zlP-a`YSsudE8^Hg#&&9M@rf|a2_9ajyT@4rG36cQ3^4J#AK~Djh<)2) zzmYiBeTjJs0@V)T;&mpX48{1M#FTk+dUW?M51Y^b11Jf==xL)t`?B>=n#5SDCo~yl zA6YjWdWoU1tC7dV`;B^hnLl^=#?(pI+hu#KlNUoW>{iu;wb4f6+poqQvcG!l9yXa9 z8q_PpT1*hu6cAuy$WYF5hm?7>neX1_)2oH%oF)-YP(KMVLD}}h4oziXrbN?fwSM)O zjxXoLcJimf$XzSkj*0tg&JWfo5)i_i_~78__1)L2LxMaY9u#xdVy=Q zFG!s#|3kgve~IeL%yn9-2uk&BGe;obdpy`Mu zAfq^mLCOb^5Of#00unG&E{D=_p3A1FL@6C?4iA2Q{QKr}+15xC6^ke_hmqPn0bSL4!Qq)fIcm#=GgM zd|dWjLrFafemhSkj(`H!H{#Wyg%L1BqIJ`Gv(iRMIcSE65`RenHv0|$fr8>C5O0N} zUU5YrN%WP){@28hvP1F7Y5wrjbIH(R*&m3B0FYjP;KSpR4kEB)#kXh63braNQ6!QC zn_2cH)1|)vc=Na0&HN8cv+OkERGq+W4LM054VkB{;y^-Hfhh~#qBqG8ndO@-aGig+ zpnP9?MLr(}C*2bpd~mL0Ki(1MC6O@_S)OVIi-CpY%Mim?it^{Pwvr2=T6is^L5DsM z0ybY5Z!t2|h#rs}qzV#(VJ2pr(#3VUdVuvolUNz(vi4iTB4~SoNc@GktisKNIIS+X zyuEvd1DeU^XlfPMKUj7XYf)|fRnYpG%g*b1$_&tYnjdeU?k?vwL7AmE^my^(8tyc& zVGk>g`b0d`S~*4V~Bsh5!H{07*naRO1yqRMdF0 zfk6h82{MN)kdlkayng-o^p~SA>tE3VIL>TBoq{P_$a6Azi!QrQO&$U{g-5n#OjP$p zO_}GsIX#AV+kfADEQuhND(I98TW6y&(JFAq2tiBuVi2kY({~taj$imjfFX|TNDw$# zs!Sz~c0Abj10-Hn<*bcf1EIy~_GOrM5gF^!=&Ph=1 zI4~YdNdj1jouDH*>Z@C1A{Z%E>G3os(t|I`S0*ImkCz56RR5!S!>X1#^v zRg)*bS^)|Jv|$S!qaZ~Jge4tMRvlVWs;tN7X`SEy^t@V;>!O4Li1Fd+p8uW(YclYsNj= zFaPB$Ryi)vy&BUqipAg{?1b3=M^{^!G71EYb=Mwrg>FXi8Kj@-v0ACAdeKz~s<2!N zh@@`h}Iv6U&3SSRQ2yRL%r|)A=P_T&L9`5dzR;F2{fi6?M@A z5*~XKr(}VYF09w{_Tp)Knhqz%Tvawe6pSd7JBP?fyp`S5nO)F{4Kr010@a_Y>YTVN z*%WqHo9S`cJRAx0@XBU&`h;~m5Q35mk`ia)L_E*a;Sv0B^T%zP;g6Wj%C$lkFvme{ zXYr6N4=bm@n+Y-}nwe70bK*I3rjzZ})0^W@>t}QmL%%B{%JCqr0MwtA_j}X9kT&9f zf3>ryWlndAkxgR@m#@x)(U}y3Dwmd+yo5aL8n2Q0vlokQTTD|G7N~)Nn(^7dJd~!U z`F-dI>hO13#DSn1+NurmB671tRD$t=(l_;@Sf&=o$z#1MwG4Qm?VsM;R%WiO8YGUv zd_7*&2!U#!ZLU*uh|1S>2isDG$R=5u%fxaZOlHnRuU@CCZAx|bFj=#9a76d70kHSf zAOrgq%WAqs=!+26_9&5Lyk=sCn}2$JdYkxI4I@L`c$8 zXM#XA&a}CZg~!@fS?f{Gf6?>vfEW_xtBWtMub+&~9Fzob$il z{eJQrbSl=+(|3$R0YMi4pssf;kPs6PlWa=HWi2je=0qoV*B`$-`a)kPU0LLp#l%(y zgR)?*;jkBbZH1PAhy4Xp0G&y+P`Qq*mTHOxWjUy%tr+WQ*7Dz!CjG8u<1vo4c{`}w zRL4sPyo1Cd2SS8pRNH;b8l~=g$L;C37GZG_7)!ZAuRsd_Nj8G4F{w=qCllzqM_3QR zE90fx-Jl;o)w$^L(_iNB7e@x_>9b-QMOsqG970Ojax@$Rpfi9QLj?4V9ebzTsE%j0 z4N~QNY(74v*Wc~ROCq97%$zgh#Bcusn*&GX2wu=>8`_E@K&P7wtcTT=MY$y%HFHjM z@$UNKn&J2VWnK^$ZK#CdZ4nG3WoR@kd(~L`-OgKDOnct)WLBGg@r9KlS{5EkhRCp9 zsYfit^%#|shgMW~aa+U~+G`_rB}3h%7Cr-0N?Ou^P%MQKxG$$}k}bq# z0?5pO`S^0)KJwv74NJCN_2dr)k&=+Xnut&`ONf~Wr}gS)%U8G0dBurqILc+^M(L%b zs8USwTft160>7l70$@Hle!jhWx;V;^(bBcRf?R@}fk}nveIkw>prNin9xNKzbZM>G zNL=SymM*GUXaHV<7eUtnHquzNS%tIuRb;(f*)LO;=@aKvHf0Bf_3QiHk0+m3zcMpI zSwt8j6s0{kFT~oY140PMOOWCMVdk833B=5aQsP9A_~`NamJ*D#qi09Y z>?YxR4264@^{v*7qRIrUv^CnHDrh2uhaDJ>65MD@7se996l)ZKGWwmslvZ3{P={$T zIc#{2Ocf-9m+mH3YHHq@0B!dWG!USPnHPUNKt@Zrcn{ zr-Bp@u~Zfw4#ZS_oO%`1$Yk)S-&v+RqV^qs36?IIe=;#Fy-#>Wydy(JShaYhgI%{lg``!{xVKM@Q77 zVk?*|+(EF%68V37H9Tod&_nwt>O!#HLw)7IRh_HV?9YPXM09YJF7NZ{B}}UY6UjH` zGQ3zlAG!)g;v>wfvopTBomYpHRKm0X1DM@ASX!c-#xC+Az82t2yg7KjyL!4jP8$Hu zs43FiDxcP*sMMpKDFe>}<`UH@D)lA^%GgZh;;34oQSAE~s>oshZ?{=ylO?5C{%W?7srFm13W?Q2RfC!)l8CZ1E-7j*(WdUyB7 zEj+_Kp{{)#=WNw3x}VmZQz9as80$|%6l2UZT)wKFiw1|O2I}SAH!p{<0D|vWr+QjY z?MsX_^UY3;^FsPX$vCKyA>h6^Dkim?7^>nf_!0}OuGh8o3(5jDPo(P%IJ1lWSu6ku zKrpG8a5jNwQSF^NA<7C|X_qyxR?D{CH8V+R%5(sl^4HQOYaV=Yhquzu#O*KvBQo&B zij;cRuGcRn2h2PwIa?W~-5XYZ z94qzd@J-d?Xl6m)T0tFi)T~-%XD<|d&l-zw(CNh|osDT_tk5MHb8zK`iCI17;o}#i{SjpP}$SIv& z&v);N{ow>d*S;Da!Wd#4)DR43W(JrutXJz-Z|38x^qdMmJINrwYDQ7*iy%cZKNvLh z2tWX3pFi2ZmFJu5&u_LfCM*YZ*8E1zwyMM92-7JTTaH(yOfz`sLH2 z_rV0&Rte}>iHFlS-jJ9=&dtLj)yhnWftgc=%o6>b6J+3&ruD)4-#+|u_8&xP!iiN? zYl=`uT?U9m%*6z8qO+2f1Y)vo3NjPTndS_ckl^UU{ol7U69blAu8MKjPW_{XGJXvC z9}Pd4Y;!l@u->6CauaGbQPH$~+X%e=GL>k?s89I9kR+ssJ(3~dy$h8W0;59f4l(&w%a=mM z8j#~@Vxmf*oJubY)e~5AU99aIO7T{Px?5B`tJnrWN#3^VvDg(lzA{;m@4TAq;o~|W zP6X@82?D(=lLZ#3sClAH#YJ&)mS4S{cRL`aa$asGCgN$u_iwn$NQV^z3Pqfui9D2a zywV&{Sp=LpWy-V2oYm3h{+}PF-~Kz~84*o_gfXwf=||k&qQi+c9Rvb9sb%-hRpdy` zJJuXA^_M}_r+4_PF)x<5a%dkcRN&u7i_P;|CxaIH5rEb9Yz1DA6@pi%XC*q_RYoAm`P^ zS^jbR>*>D(5dspk>s##yVr4%^TQ&34P-w=7WC{Ph#_s zp;>`IXt}|Q8}svr@rt$xcuisQ$k*9$Tf@iOz`%*v^fy_L;oWpe)|I-pCYS7#10?jrg7nxxKNQ;Tu#5! zToB5|3!3l#<<-&V6MX$zM^9P0slTI%R0J-P# z)%S&aGT+zMP{iytq`nEB|K4L#xiB>K?JC00_)*AnP(9`M0%3815HY6n+xhaA*9XCk z98g#|-wcFOakUIA1r>;SPSe>LZg122gxJEwu2Q#(#DR_#73C^HM+Q9$#xiF!9UeYC zY@aTUXvOMO)Lx?xMfC$%e<=HlCNB^ApnfH$%9CximL}QDNM0t6K#X1mnP#ns;qDu6 zf`F!g$TB>h2{J*-o5%YvA2wePKK0=R=Xo0d1`cdX;i-KQ2N=li1Br4mK~m;9(VRD% zgY}2o-%jSlRF^0(!ixqw4!D|*n6rT zSRvjN^6I&7&j>eSmdkdUY6^wC7_G9b*2EQPxTe^uSe5K>36Mn-eD;acd{`FE)Yb9b z@&<1WFtCPZglMPg=?EDEU~Uq1m{2*50YRv|&%w~nmOWLW5)inhD_(}F&_LF`$I#v= zdHHb(2{(QnyyRqH#XK?);>6-yE^E`|sEsls0G=~!uhZRK%B1_L%W{3#-t+Av<|N3} zV-ANr6NM&AnPSQ?0j07FGv^Fx&fA|K&#w{w_(K-KwON>mZm&5vbr9satS<9o)%{}` z0D$UR#X>CJDi&5!OT$Rkz^@&&6+n%lu*6wIb{Q6SywXbRo&^l}AaI5rRQ<_Zi6|1? z_=^TeU%2a(2f1<@$JY=$)wNrbG}LB=vIPhOGnG^8i7CmsDx8R>&F1lPB+`nudnARmq4KI$l(p03NqH34IGYdgDQ+zu9AptyQ;mypryDk{ zv-(y&wpj&h^;6bqk8?4XG+IbD58l81_ya%Xk5kE$vr|8;39c|h zbX7Wm2&Ns>siqw+Hb_deW12JN#3dI5SL+YA|8e?t;t5RC0!*qPyxz55HCR$*0XWKM zcVkyU=Gu#1-}OUaR8fPYe#HG3F_z~6=o`b%ryDrmD{&vj=9;ZD{-kNH7mF~;PL&2U z7Z=U*(|Zd%F?hBqaT(Pa7%5)qUj39M+@^DO$4w(ML|YUa0vwkbkR`Cp#Y)gcHTJQN zcHrLfngOXbT0C0Wgk8B6_2@EP+6+Y`Z1IzdM%ORyanf|EZP$Ha z!Da1<&Q`1cqwWa844BTgY5T~VL!j)e#8L;hbRcR^h+bS2WiR$DN7qiLr?99^3XIBZ0s)wRAt{Q2bM>EY_>d_$a&!KtS}8_G~MYZ?RMD#4hnjCx2Z z*v)dBZV8{qI^_W=k^9~oGc@Yd;iQYqRN)0R0sNrK%js@%np4WFEfiW{Sk zp&_EkSCm=>f?FT{qFFH=2^E;E!nEfcduY`0HIT?5gX<2ugUjdA?zvhi*}X5b+2BOXXMHb?XJfle=lnY>sV zK_Px165Sy#kdlSKz=?3RUftfLlgrE#_RZ6VEdMw5L{l5vOp14E#auVf)8>022|G%k*_d<)vQaY3R7G35SJ7jzbSj> z#GLYUbO=A)|8ey>!HhW7>TE%Pt^xFlLKifc5*=9DYJxyHsIwdp!*fn^;*>e%gTrI| zu>JLTM|GK@ADKEeMd`0MFB*{%v{HvlvtV5J7Rof2sV}pK7L=nE=Xg^=?JpOGs8*O2 zUzT_Q&cs{#=Dl)i3CvbNBQa4UWxDHFJ`y_)z4ktHcASEM1a9%R;m#pj~aq@ z7Xe^3n?Q$j|U*7Qb zo$b@6JSI$!ny}t@fHc*IWshnqi~kenlu5%qw|{#$$iK4gQQZp3zUV#gT@tWO;L9n&PC@U|3BQtQa$+*mqUQ=7&E$CgK;iKZ^K?rTu=9&skN=Apd zls0y5A&8%kCD*tw=n&WdRh#K7rV51?td5Z4O8|!8{GhUKB~d=U*gbp)tF<*?b4FLA zl8X9M%0IRQMzcVGbDEA%r^h$XaKKsDeOW4j^f4O1Y|YgSY7N1Zg}B5F<=|V+lrGLc zzqxrn)ZLTM zqP@9d4NPVzYoSv)AU9K4lsl)@@e%*a!!M`5Ogy24l50~c>_otZd_d(>lfVX$Jm+#R z4zQdvC!#s0xoiwi>-8c0aQ%(-hsQ{osh- zz6XH7G)tGt8rc@8#(zux8F9{(b6FV-_y6|p;S^%v;8>fARP&cz@SdAH`YZc+FxE>wIxKRk3ZbsiG|7>Wc727h#yxhY6)Gu zL;i9}1Oai=Wl2P3VwyJT_C8M*>qf<~66G1X1f=uhHi}|OEk0-xdLWb!a4|XRuTU9Cr zJZ1~FWw8=b%9NO9%5&y9^PD$_htr4a-;Q?Z=6oZBIkmEYRl7$ABs#erM0WgyNBwFp zb~Sq)*$;n&87v1`5rP<->o1Ol1A3!;8VZ)-sQGW3>)SiHM@L8t`GV4@W2UQSj3gUH zi~ZPCOQ2Uf;3=#iSEvr1vB9=f2TkV5+_LL|8KLZ@yi<%#+{9@D-OQb!v86ob!NfDF zJH+Ie;mYgIwu)*cV=L%GOVN+#1{?uPUSH`UOGZf9AcRxqhu8DXO)8#IafA>c@~d|s z>kpi&K>!YEPnQ1WfMP5%T6Q2woD-2GrSkSKcULz6zyAW7X@(8N-Q~osr^AMFRMhVk z-`l(5CElMhx@K<=6X*-3BbT#yDE(9C$nmAX3XwvU|O6fZB~j z9j;(u{5(A09C2T$Q3j^uT&o(bwLu|9Jsp=b!JMgV5R&rd;pX#?2T!Yy4j=^dnK6cn znycio;pC==919iLV(hXhh#gSJDQ`}W;luWqgXdBo>deEF?Z_;M$|_ESgIEuQG!Cx0 zx~fR>sP4;ypS0@))7Rv`+Rwe6Nz}$T7XWBKFUr>p(B%fl*KqGtkecO*MGz|O?Qe(c zjeJWLzGetjA=Kla#I{hb?6O{*;8&=a0tU?x;gb3)X`>_tVYi&X%okf;5oT+y`6lKn zE8At)f0+zRDlCJS!%K9 z>|SIH#CHo}-=qD4v4Iv2C={l~%6q;i^6>uCLrsxo6p^oyY@ZpUDh(r~Mcf}+v-qUn)AH5nMjNEI833P1WX zMpKWO3Ulz?j+nXTyI3oAO!OzJ7IUAsB^#3bqWP7P2haNwnNd@Emdy%J->4r+7h z3o;z~mEfNkCuD~!uS6iU;NK{1l#^b}9fGnKnOOiq+w`c>+SxH=0no!ULMckyMw_vw z`nkRI$KAPFhN!jox@bwfKT6WeN|3v|5*8O1a#T6YPg)oO-Rn3e zN4NoM#zmrxl2=s|P2@N_Vw`q2S6}Wg<^wFt$%5FfovxiQHim9oJkAE>xM+)jF(-u4 zGUgoB6&k7q_71bjXyqdwPV^aoftWNXTLLkZh!Y{e=Kbr>@24mDR85d!V^P5mV5{mt zw}jXK7Y7)nOf%6;<%Uz<92`#XZ+<=6)npRauW0D>TD6S?4##N!H4rdOXJXkswL7ED zZUVI0oC(z+cdcd{(5R^wb>*ld_A+X|D)PqHHzG35Qu85?F;@f-v>OPhDXy&yjOhU4 zg>ySVITmJr2flUB*i9->y~p~_n;5>Mu7g&8?;`K zamK}>D>IK872)8n==B?`5aqh&fCz|)&o9!=ZIX2{q63JC-@b+8lR@0QR$Mj$sr*-+ zM+|y2cV^0vbJ?Senc>y{{_bS+8Ncl8+vRKNbt`#Wf`}z`j>ZF0YJM)N=z@Efeiut9 z84sf=JxCtjVR@g7YvLkWFn{jy(&w8x=$lP+kfQ^2KrzEhJQiYtWR^^6by}pe?R@hH ztBp12)wy7#F5nDN65UpnIhPY*2pHDaH~IW#=7}@w;w}z~G!jM-pw+%%%>pUso)qUz z&PRt|-`qZ(ZAkfF^ud^f!;Eu;(xC(xtfrB^15WLDp)(YQ*k4jDwg#mE7_7ox`m;a! zr@BJL1cA(DYck3SQszXQGZ0TdJbrwgW_SwcW;<0pX3_vv%#$lp(LS(sfSD*UrJPgd zM3nMob1?mI^Xt)b%`b(%fwAuYrmYdRLiMpR=$X90!_l;UsWHKgdC>!)wnb@(nlcqF z%KMF?@joC|8+*jy3b-##mxkxDl~H@$wI?Fe{u~-2LuuNGD6A{d5yIy}*cKRvves0* zYS{L}Q>kB;fwo%3uQDpESb{+$r#_T4F$U!~^=<$FAOJ~3K~z8>RzVFQHF~vzI{N_LrD=MMCke;5>obRl{jok(94uFr*dR20TEojzdb+C z@XN0-P1QUIwAm19Wm^BrWgoP*h_AxNu}gTC`4T#_Nk=WVAGuRMvtO38yQF#-jEw#7 zLFo=Ue6;fNMJivVVH0`UFHFB_>$D`%!&A)U)+{lnf}E>Twhm)TU|G}i_Ay;Qcp+K^ zIVhLe?^2&0ipxZhfr$!<12N)i_3G8`@SIZFhg-9b169d0-3A0aWw7~I*!&-MiZ7?_ z<)=5-yEW-vS|$5s5Il1TZ`K!;x1QRo=%=b{*%gaO?G~vSbNaP2jlh8seKn7r>OzQv z$tr`~;5(rw7GYTqlOYi&qD+u75O02Z^ZV;v;$3we$FKud40y(`8bPR9Q;jNzGY}xk zc1Xl2=b3rVIc1s?Cz__!>ie6296!}m)GnLO{VnykI$K8sy$)8<-LI|ie%VTL97YrM z3Fz3NlkQ=p7Bo6yBob#d_X}L3wotiX}I_`DT(2kE|2VB1d^V~>Vr-2Ybw-z)*p? zIy?1PS>B~Oh1~1VV58;+hKGj}G>^NY&f!8UMnQ3HmEGC7nPq2#ocZ=HZLc%sVkMM4 z%3yQAk8kUgCTiwr7N{9vB9%)vdI{@fro@z(h;rhi?aB7_G5`8MVVV@E{_6O5d<_ug zQQGrWhtmOX$8TKmChM1(p{CQv=3e3s`BtC&Bi35~E44H=qWkMb=aM-RO8(jQ2dPfQ zTqw_qFM*jeKn9YftxSi!s!v zVbm563Wu@{kMym$0<|fQR*9FBsCm1P%ht4+Q-+i|6Qqo*_4L>K-|u%bKcgFwB1*6s zjR-)?+C{!9!HIf8Ksz2NQBF`cXs5C}>a;p|fA{-&b^+xe#=WR-m6*emYJryJ3n(M6 zRj^mQDd0>i)F-jNI%>`Ont{mZVO@ICJm!VbFAo-ox$5+nU11T1zg}X6gv*;F@wvd& zJd6^f+U(9R;>#ielr7KMRG^MU7@?l+j5MU4sy#SRTVq%(U49)%`Lr5(tX9t=Gz@^c zghu=8`##i^9uK{g)V(4tVD+q{kE*pfv-D@~G z#l}#NSCk1X`lU2fX18T`)LagWO3VOvKi_WBFDSdy!@fB1VvFI40uf2fSq8oI?73El z&8$y^_A4tFCm4**n)OuqGDD>L%RB2xRatz=T>;-NcQ?@W)n9uojNW$H-R|<4sX}#1cW6377#g=@uivL_n~5xKAfniDXBg z&~<>;0$>|WOLQ(KPT5^p5AvmQE*;I+SD#*8&Km$Ga8pGirlCR5V6BWX*H7in#-7I` zwPbP(U(^7QZ@ubq%`}`M*iA1YHwnkrGIec%IHe#n5kV@Ol9in~GU9|k-~W31h3Y9S zqJ^hedFVj&F?1j~j|hvLW?h;`bEcdri5KMP!~H)lW@19$&srg(=@8#j0A3bZOM}tS zz=9$N?yQz7SQQ4nlQ#|VELjiSVzXK~Js21utc?y!?&+hQ^KAc?GQDZ#uWv+Tnx+XD zfo)%XZ$=E|ACJK1iqM*DLd&_yQzYkZO)`w;kGtfG+)nEmM`L^zixty z0!0AZM1u*dYOm;$8Nkj|7e@v67Lr?K=P6_?-%&d1L{-6ZHLnD>B*LOBRgpkUSr@~= zuU^kb$MpOpJ9!lU<$A+655S;@Novw~C)v>J2D_Jp^sH7$S(;0H|F3UO4xaeq6JXR%_-AHEL0a$`F}$?y_^|C%~pey z>I)W7yoSQirS5JCOVanqr051WvTWOorvdJSPi?)m81(;=S5eeCL(YsP7o^w?jPv!I zbp2TN2sD&qt-=sq{0t;kFX>)kr0F1;IrFq$uin0SULWV|WUdR6IBWvQG`jYv#Bm91 zJ2KW2am(f<)6;kNpYBd5XA@fp{^%+OH&q)(Qmj4OUY%7GxpF32Mffx^_#tQN5VCt! zCt#6wg5dR9#}Ppv>w!X(LYF?KS$bP6woD}{jEf&46Edv+`Ry;apIGfSzl_MuYy}+0 za@HgCzeQErW|1oE%3>T!nPTD4zbbFN6Vn$fs>*??v@IFsL2Tzcz6~VLV2UQlT{&-$1h!!K#F0C!#tW+7b!% z6fMhvK|L`lh=g_RE`Te-z-B20YO}%d4-3fQ)az;?LC`^qlWC8&(TWFo3r^gyhTv_@ ze2JGHpXP^$w0o}S#grpszWWPrHfR=8thi~;^u3`&GD~EGvP5Nfkjr=1S9dG^{qI(z zM?xo`_goFB??dE?=AJ68zbyx zKrVr?fEbQQ30fF{7#Ju^B1o1*RL%!S^Y)QWF9XU$KdP;Opx%D2Sx!Ji8DvE+!|Lja zu5P}<8nVwP4w9KY4t;wr5mj)PSv3iqld%pT+4!OFWKNPDh7XN71u#t(_l zvXEAn#sI_+vCKXXu($FG3)%3y?<;e~&a$ZhDNevOvjafk#HkLgCU{yM!6RZ-nH!~a z))^LYSnDe@M9Rt^v`m;rwY46R&goYfJbYFS5eI5D#k7zh9ArgIN%04o6Tg2*n*+*O zjPUXM!?O(!|wPZlY?f@ zz;OGM8FeENO*APBVF;M<>G9_C-DyS&GB4`Mz4XalgRL#Nmlu{Oq@T?XTkjifsLpBk zXtlW}y&dCHc*O!>pv<~cvaN{0)rx<<`+fVl1Y*j!-hsI!3cO}%^lSZ5(W)-rvO8HO znlmKg%%`vK{&<|8IaL*dg9;rmZNJMab&&h97geN7I|t(3@afsYM=nhFJ9$$L)}e7z z^_**OuN*0ZYa-o?)2g+~lYy?OQ6Y#U;5`MMDsn1$zb*2jh>TNk?3A$>A{Y&kURUV5 znw{DmMHR}bglB(Vq6>8BB8}(_to{*g#`$byfLRQK;+K%|C3MS!D-D_&W~YxNIOOjk zP>GgQuMPpAp0@%3z;%0ftqL8;rB!eL_BzMC!{|+x8Z}d^_$NgEmxv7I%tt5m@Gui| z&Y6fPGZAez@c5>#i%~Pj`eDu5W~T*(3}sOa>lt{7De0n{lyCprt3&z-kkvO;WS3OT zVOF$XPdBLO%Xu7tS6=8#$!Pi>ayyUyg zKZJO(Rw!vrLg5yFA>zcG0hp)5!|CDG({#+49K8g&s7z2~S)gKDllYIl`I^Z+XO*qtt#uf`wO?@rH4;?dC|qfVDUqI3 zS60Mi;zUPxSARUNzVb7cZ4xV0prS?m+*576ssKMs1M06872xaax?dz>#*O>gaGb9@ zXo0Hmd>S+W0FW%z_KuSvx1c^kjCKQfoh7vycGzRXcP+~58X;0DM6VXzP%mDKyOu$q z58tFk+}qGQxN-7V9NHqCn)INM>eSRQ1+pM9L@MKX`yn)0oVb%`GQVS(YtRY81{n;o zE#LRjNQYewwV;l01dc^t)kKcInf~H#XmqGcvZ`li)D9IdvL2sXtOevBf84FsoaEp- zCIZTE_sFtGwrj#_^WZxwt;HnYFv$X4%1nv2f4RHZBL4B&bd1Mpn`?{>8k$jn(W@6; zbr7KPlGRxb{Ikl(w7>vpBdX6FwPUT5LGy=kQE<5&g+I|J)j0wDm!hQ?o?5}+RnNiQ zN5fZ626C|*s3d}bZXgCsM7Wx-AM?evV#%onRhQUQ$VG6}bLlJ#1c+A`7qq>5!VQo& zK?W!QXC2g^ELKjjmcWu{iJ4)(I{*CYYIk6q9dvt?W3i!eQbqII6K5kQZD>n_Era{J zJwn6OPt^DI<(M)C)pcYbQ4nAT&H%bEnf#aYba)6q-Tk)xNR%U{+BUmhU|*(Bh;STR z_Gr&#YqGL62+#TG{OtMF(N~zu#%Ntk3M;{l=F(Up@bbYItF)j94U1d`ODUtQZgPj? z=zoK?8&dHix*?1ReQ1r9w4zcTK;@D_r9lsTGlF)bW{qjg!S$ku47R_VB(5RneG5+% z1=v8t3ZGWm@O4QPfH8pzl(k1Cm4Qs_gQe zi~6*GqJ&|x)vw*{slSsuf<2#3SlbZihlcJnCxpdGT9QGCnThE7X1>3lch4k-33Fy% zAHw}B1Xa(`I-@nuR3=8oFi zVU;u5X_n1PbUALxum;G)3}3%{_@Rxp`fhINJ%>GcJ z?$^$UA%fL5@HEi|G^!U=Uh48yr~_wakSwRPVMHr6)zD0F0Z~chBj8M#plnS^)5Nb|r<6c8Gb}!5=C|L& z<`6iX4PYjjP`QSAv}y6pil?0tXA&<66X0sP{$Y#1|2wDzavkJihb+)~z~7&Fi|#J? zQCro_;6r5YBjS!7d+cG9a-r9p!a4rMIsRdaNFFd z0c8#xfxF1i!D2AgUT`OwMiSJZWXnuSBFH<~8~~Vwrrze(pwX!|F@Ua^m7J0c8Gsm8 ztJTBf^TBzZHQ_+n(WjJ!IzdaZ08GUMu|sEy*+iU=4!^v+|8h1l|E0a|0equ#LXb_v)oT0?_2Xsw}oR?h#F@!j+|M~4N z+fVFRDVpT$TZzgnXjW_1P25xs*uaSiLRlk0>w^RMu>EEFvMOo-8f{pO4L6}@)KxHw ziza{3)}d4d;z~BL(x4iGvaF(&8^s4*mQU0Xiiz%GH<}f>BO$Au@dDFBh@H=4AO+&6 zA;$)XA;N_WT!8<=8X0R9>tBRwB8;2y-}abtPh?1(ghp_go9Jrbw#BY#eW@w2pmu{a zH+ho;DqR%B>+%?M6hMxdLk!iKkS6h6f{0?R5e#MXD|VlG1PxK?Srn9r3*co_GeHhn zUcW4j$pqV*bbg+5W@1?vlNqkA;pR?~QnlVCHP2kuxfQlxWXVaF!!pYn-8AQ$AMehN zXZWle6SZtrds&l1#@C`2Tttkkd|1N&t>tUhbtNwYwqdyD7NYM#wj7U#h`_)+K_Vnjk<)PNxF`X53vprmH)gR=u3?DPC$qG6PGx z28%ZZa@iCWAoJ?{jIZyXa04{n^>!iiOqFO+K2&xA@#n%2XV~3betx{z9Uu@jmHUAd z+e>A_Nc=Ungn#1j>0Xovy}UNY?_23a&^|%jExYg|JO0j6hq;z!8Sl)LGi2h~r=za% zZx6rRea;$)Dg4qkJ#+&%n8ZLBs1vSYf|RIp&XkH5BvHzo@-$7WciUeNo>ppna95r0 zk!!u`T_-EXUJ!7a)eVieH`)(|oT+$Na)-#JyH_lVOS5nMfEH%zYaWd>tDI`$cLmN? zPc?5LBG&b9&v$bD$?c9pb@I&Lt z@&mOwbj!}#bks(u^;GKa$HL=95gBhkI_#qM(>p?1f6)*!2;~8*Tg+L$q8V$fzD`%& zY_p=Eu2hlAS=Nh4j75*VwGcrKzers!?}EKa9J|iangFTsmfBf|Oig(~Eee3L8;82D zF<`@2<4(L2N^G?ofY1bc6cCU<_>(eo&U|;jySdJDf+8-MITPI6!s$6`!fdVG6j~E< zl9UbxnT1fSv`BTV3RwJu15Qf z3aQ6q>xFL7W4BcZF;meBWeH3@tcWthYV&;eHlJLe@_{ssBCb7OmCC^9ie{qBkf|JZ z2RI!(KFnv=DYdSCcR4-RO}9(37+L&JQ4^iIFBY z*4%odsR2BUf<5UolOT>!!!Y{qKnVK>h1v|5Y9usQ9B-5Oz_#v=G!Rpcse{c=Z-0B8 zh%>m|QGNY2XkMGF#5O>*=uBPGSSXLnQG!I7vK*G1Ib|R?d2{#6HO-V|d)BJ1lp`G> zK;=WDlz=^M!7+f@4Z4kpRO?ofg6nd#CIied@2rZ-y&VVoOj4NqnzssDs~MdzuMe^Q z#kPyCHorhJ>Nvkv6#7t0lp!HE34!y*kV=Ape9Js5n0m0bl(xa`fhuKpJ4Z8 zIV)+2?)Sg_)1O4_$q0Z@8uugRzN`Jfx z8;#qWDWh+L+I9u%C!Kuo2H%np?ukZ-MHv)#!e7coTb&XM$c8QcGD zP}h9o?!8&yWNAP+_{1(>zyqUW%?1c}BiDfKf%L*^q(pomXXlR?!S_kqH$0ghM?9Pq+*5&;|rOsNh7wQd|)-+YxHu6A=(u^@wpL+eoO+Jn* z-c(chjorQ?wwkm5rg2;K_q;rJ;S%XaCMXAniO2NrHl3YOO66I}6XC~KaC#yVRj>?DV*f-`qA)oV5p2$nwy%%j(?0+wT{*SHELu6X{)YeRH5mDk*nRQE4&4jy z2TwW@WN}t?byT`of^DcF7C3(KQ*NKP^t`+vs;RPliiKyyX^|mIAO>;*%D{6<$LG6; z4}5UsfW|SKs%H>DQ$PqP6Q>f0VVd)Fc!Y1>J+DtBUsWoLO3PPhi);$`jG%E!&H%E1 znj8)D_0`?4?{A(DfT7zzt%BXP0mIgVP})!3U4hoLjT*H57L+{uLF`M8ej*H_MOX{5 z!=rv&62WwL_QbogO=?=dz5V@Ndgf_SO2Hvg^Lb7&>|EOLk&F)<39e5KzdmnCo`S_O2=qruMqSk3t)S z%{R%c`5dBDYY4!XVfPI62|Fp#pttFlJ{N;*3C_j+LV6Q#Wc-H-%(UPRY3gy67e$4v zaT!;V?QLUtY7Vmzid*yID=nR8b3iaKBFF|=KK?+aFVPvJww%|Xsmxxf1i~sT$*=Gd zx1^q+>#_6GX=tX@r8^pdu;~2B`VdkwF$Smejypd?AdqUeUw-yxYkR>qJZh zM<@L1E!1p&Q-X)J~`-__RT${uBz?|!`5%zr@L9ms}#C?uuo<(Q4141BZ9 z3tuDHZYh!H#@()oA2I0rLRW7SHwtdX=?M8Gj*VXFF_Ya@9hs4R2^phqvcE~r< zv3Ai0(vO(iNvP^MKN4<0cvt{LxP>|+JdIM}Sgo%at?-Dc>@B+=8qH>rGCDxac3x$1 zgb?wZH;=cU-miD~Nf$lEI6Z(LZ*1GG>bW`wgdzadoly))CMY5-C!(@PV#=IovpHP< zboZa@uMNKXgiRBze#mt1uPV$(vZY2MSWOVePS#TJwqke%P2s3#5$ZCWDn<0ehFuxr zLpRV26_eZm0HQ$avx1N*gpgX8-ECc39A8=A!&ior4w>~D`$9PWhYndwm9faLK;+AX zg9Jf4dab@U-fnoOWke2N)sGu^&4^>!>dzPpwUW-EUViM+fIzOB=xPYv0IkNOhTMGx zBIYG|>^0^6g+gqaa#sSTQ!`!vaCd%Au>0aZGJNbqV&9=ZQ`ldNtzcvc2*X`gbs)!Ci+s~Ya$6~H|1>gP zp0|1f0c=L#-f;NmzjQ@u*1l4mIBvmoD%%I14o58DcLb5OQEGw^GwimH-UMj@thKlw zlBgl>J4(O_I1v!9Zg11g!*eu27O#FL%K(}PQqq_>%Y1r1JN^B~S0A?rR05A}E@hffd8>H1pt;!1ut5^ZVvLY@Kr@B$;=Hcek zKOKEqeXbb8p5p|z5d!Odz>=t9Nks!-B8|n&nP;Lo<&+`uYPDX!zy8m|uPmRSO>SEK z5rw>0mR<-1MbPriFqGC8GvtK=Jn)O!t5B)wpI(MKb0Ihw`jU>d8QcUzIeT3HLWe4x z-j3{{awP*VEs=U_h483lj{kL+WP7S5F%afUopHs=rXa0J(N%~gUsr+gv5ERMdo0D~ z3zbncU<>gPs0D5nL}GM|H0(#4JPhHdK5In2OJQl1Q>=!fTph?7U8Z1DQwB;zuV2m6 z#IkuA0RtSJKshqzg$jZccP{_{AOJ~3K~!I45R^cS?2#zpn9P*<@cj7Z!zFzDPfNFT zw)Wndx&Hn0S1*Xa)tnZ#<;KmpgrW_Dx`G%#U4o3qa1|@KvuC_ST&yzwTI}>tq+t8D z>%Gp##x?0+RWAs!5CA7l3L$v9dpB?IOMWkF?L$dg3_xbx<-MG;n?Ry4IWxn-+c&$5 zn>l~Oppp5E34n4#MR!TeNHb@F2zWQo7w5mfzy0dsMc8-WLHiOSUF2Tt@d$E7`yN5< z0kB(y0a+};ALRE!U$7390H*EfB|M)pr3@)U%InMXFFzlD!jI@o57ZWWy!Fb-KldW8 z!ivD^g=HejM2Tq5IT0sLbKX2&{&A7j1d&SPSOi>QXr%$B$ErcmLtPtENycs2g=>%S z7^+|lpR@sVKTia=9<&o+V>OP0CiV!&@lzaD-BvZYzMY-=5{%jylbjI)>XK?_kX2*X zpLOb``+_+0)EW3nS`x&W0Jug_s#g=_Cqn0X27`)$Yz0oO8p}P4HR96Vocf9#g6IK4 zZDNQwg|^95Es7f@I>5@!8WgI{v8q6!r(zw*Z`9eTZ2w5WDf8Xke0iBulH+uNIVFB~ z51Wm)&(4j9)&zr!kg@?Tlm`tyHc?O!w6b{`PK4AWF~oBK5K zRLdQ{PG8{?ow7<6v`Ak~;IH2+`rFUl;1)gNEG)lL)RaUdds_w-K4lX&jZN#@9LTy+ z=Nvfh`(A9ySPty15*yT3ElDG=joqo;K)Q!|Nkk=LS|7|0Z}Q0nmN=)Px=>f3hJr~J zUSkGXD67e>kO?=3tB3n9n^R7t>m9J^XHd-zjtcea##TUjgbfkn^!(=jxc~IUOK|tGtNw+N+JwxqV%nKm%WuYXze(-I52ZZ1Ht-JM`mfvB6aAn!K?1qy6ME zOOoBmAZN%__T+#>l=5_Vxclqnr}d`^R#2ih==b#k=eqa2R#k?RtSrElR5iA=cxhjj z{3W+RS<0O9$@S&e`}GWxk?M)wX`=AcQ0jpZF{%Q|xpJjSij_O%jtybBarB+#W?0-0 zqdnUztW8g93OmTWzzI(GSo4y6?b4 zG3|#!|LYzDXo83~=li1sS_@lmJeVSRe6_MrtnrPji_cXrir;mxV_PqdJ!B4sC=`N& zkv$Y~=zMKHiJ-?eH$PcYL(0x8vQtQz?=ep+e*fJp6IPN12gj$dy@qd*i!;0c0CX!7 z2HT^oWTd8)Pj61o&lz@KIBXEYqoEERa{22Gef|G*_3~HN@^KxwWt_@FyDsR^jWGtLab#F~3iNz4D)?eP< z{{C>5pgIE`7aM9?z*Uo(>tZnajf{%VJNMh(&%I;D6DPM-h>k!dO+!l~Hx^qPz0iC! zQUAI@YB52G6XlergG2b&SAU#-F@43g@7Oo6B+WvPT-raYJEc-x&bb_!JLj@H$l>{E zet+==XRw%iL--3E?M7r+9(nY(=}X^JBOV+#jjlsuoHP}3BpcI7ZXH((7)N+qoi)Gf zTble&h@Xxio43{6bmS4PeW%$q0P(_4{i?S^3vrH#pf{;h1s5seX8_hLIs;SC>U<}l zPcW9R>O)Rp)I8PF1S6uDDog+wa0R+yqMIA{N>vvpgX^h%R{B%zM4bw_3|Qxkkt8fD z%m8ResCdw7VKPHSleo$}fo1#Y;`QL0n{;uJce|oBm@*Ud_wQl7k>hhM$9sxWmFs+l zb!Jk$AVpO`7PUc$)BQg^te^f}h@efRz(_bKrs$yF>_VWlw0<>H^7Th%yR>s&&1dNndD+Lt>riKt}L@h{c70f0)P!q5% zDilLA5C@EFQ!3(vIyHi|?O_xn@y3#_1S{B!MUkDI! z;`PM^-QDlLkn?>oLq)%ZDn#T5l`iYVBoLEY!=VTZjTUaSK#rz z8>vaJRcaZiKMhoSYaQX(R-HEYcBCPU0gYnIwBZf z*xj;=jP#`n(R6~B8_CxNhBRh~u28wr^H+TRa(;zZB^*9;6Js-|*{x-1l#q;wk(K@D zH6F9?QI)@q+$whrz@o&E>aOjanV2{;pPtd>IpwmEJ25ce1ow|nydcY$;;05oBr%nA zPxzE2#B+Rox_vmnkH44?WK=OO+?PgPLL=Y2zDbz1+z`(0d))sTz;6TSUvqE)xVv8A zGXQBa#sU^%!+k9Z7&4McCRLgIKwP@lFqif`**NjSBG9Na-3WM0A{S4 z`>J-~#GGMsf0ynacX?HSv6Vd-D-^J}-pIddf=JE^QQ7?+5A(~YdpSO-wx@s^cQ`31V7MX)=6)PAQ2>{Oq?>! z%!zo;2X7xfeup#2+GbZ_MdlDbozZwu0kjtR4v|@x3qY|`DQBWYdCqyxWsS_~-SyY| zP1dkl-(06byi5**?$mb6I7V>|Q7cV~lJvS?Nrk>huI=0p!jO@Ri7?=s@ZT61zzT zcQ80~H_wgL0?##{_foXUB3t6A;q{_(WO|BTwob~BOe||&aBu6O1{+k(&GbPmD``<% zWSGi3-N?3f9HW7vRhZt0_7wwJMpcywy7Ja@83!n152_^e-J+&Y{p*sCqHTn}`m$KR z0?ocI0?Qne6V&AdJLEa>tB15+TVx!F;rIm3FGkVM#u7BEos}+&36hyIq@sQp2w?l& zcJ=8W;=^b+Yj5~Dj)|6zANA_%W!h8*W{E0WNX+9>MM%(gj>ZS}nl|JWwtp)J1egM? znTZ_W#M%%_P|yI>PrdZh;$cn;?S0qR9`F{UIC>}SBq=j;Os=F>NSXy?-d){2KfcG+ z+Hh4KL$`6M42IDF-e}@ z-2e9Oa$cF3b>kdSn@}Q1v_KPk%glo)5fE|C2e&sL|GN2tUqG5@yzGIHqGGFf?=6*(Q|6OXy1z}C zAW?b7Df7c4Op`X}^^>O;Rv1vMo1!zQIXE}v^H-N=X9S;j7M)rm)`byvF%g+Xd+KnA zZfotp4L8G|;A-=qAON!tupOaXJJL_vnoc&A)j_UJ#$MH5fs_kLpr0%DUD4v)zF6pY zj6(+N#q1&TC-`q=hdKaB@Py)(Pef&zYi4Ggw|DdPBT{a%`MJs;t&!E?PYmpLd8d*T z0x+##y?Q#j$h(A7O{)S>bBOiUW71YVu|{DuF{&)vVIo?szI=E0>E?(j74g7;pt&YJ z4xMa(AOvdv{78WBDn=Z0EFV8d4ZkteL2bFGsk77(qb+PgwP!uA5?qB9a8_YdvKVwh z3Lr2LK+d{5hz3DYTAiJJ`T6)${{81zG#z2evO^A=wiU8un-UeagQ6`50a1h$5@?d9VUac^5|l`g1POq^ z5?BBWU>6Hu_MX|9o$H<7_jPwwrhn9xRo&m4S+M8Ld*9bxot2f9m6?^5m8C$1fRK!i zDC_r?3Npq?e2l;d<0R=(Yx26RB;-!3p`z^bnWdX>sBC_@I4q=I0HGHm#|u>Ru5Skq z2!+C;06-VO7C(h(@Sy%<+)NmFa#u?jli&{#;D|;-PYc%P9G46CVOcmbj*uFWKE7~Z zzxY>r~|G8D}*$Y-J?sadgbQb z>#E*|I0Z=+*-=*_v{`8SZ*+Y|@?iFp)!Sjv$S^|rfa6;!j8=&_W+8`#neuEQ?SBUj zn{CSFLkN#}mSQEaL-E*6`|~&1v!iu+F@e!Qnxij-pkCW*){X-Jdyi7fZ{#{O{sbO1 zHZLmK1R+?Iy;CQf(J~RXHd|(RqZnmgko(w@m?y`0?N#;;&K}!e8<34P@Gykn>Q?-r zQts%FDBO?WR-WCB5UWUdAbWk*BO&)7U7PMGdjt+3Xle(0K**l$=ljS|W7CuwBt`eE z><`CwUvB8CS@`GUqw7k@h@#nS_vR2AyEWHPW0=S^y0^7-us|_TxvP<#4d=W_@G5av zf&9)9-2@Tw$iTBWBpbK>Hwvx;=`#@a4X3Xs?Uy=*lMscB)w_ej+RD5|!-PuW^&`0K zwgmbs@Pz~pY1i3)O9T%y2>V@xPv`Gq*SkIzwH;!@zRx(dOvOYtDsc;zMYpjZxZVcw zP7G(bI6I%c4I9FA9H!EO#gt*Z5_fkHY@~m}Kw{gA3xp1jMU0a>4}rl)f5#b=3uR#d z7m4Z|Aw`Y-n+ry@mSgqVK!9hP%Ix|71*3H>ZF>AnI!vkPQ0FnLiRz@ZF+JKfK2 z$Ab_E0xqx@46)Imi5h!S1A*betM9n7y2}(93B3f9yBB4>LO3LW_P*_Y*J2VP>+Du0 zGRD}+kEyLaWagKbrd$2SomLY(#we(Yo+e3m1f*JMWFkuvGYEkQ4H8cSiVi~2(tJ`0 z$%+^V+&EDnPFeD_S!AmUD< z_t?drp% z)j0)Z$u4~z+dB)RPL}B2BZK1e(N{J$y08lCG96oHIy=n290m+i4!%?H$Dl3Fp@I;J z?nAKa5Kz)S?AqW+)|fLsL88sDqSc~7?9ppq$!nR`VTrnIN;F*@aoDFtAmpOtjWw+` zyTDWcRIs@TL(Jb#E8{;w2;neA;oU~p@HodX0p+RR!2C=sCALJ01|@!ckch zgQ||7(MxOj{4HP-x{(0@(a&jP-VW>J*UW~Bxsf_^x>CdLaNF6JV^s#QYoFv}v$YEf zsn=F^?%bFTlZ*_>x@-$z_fSsIY9p8EfFl5QR^cVP1l`Sxsfx-FiwY=LQ(c!e8)NMp zCh!3Tm!QlZ7DH}9q$xL6_D`#drjYE$&pDPIh+ItvZI=_lzYsdd1`N<^4 zW`i4T!V(W2R1BFRofo7rytrsaBl3P#AcEnD7nhOQFYvTF(2i(J5jQFE;eN)h^pHP~ zSDV4|+~SJDdK`Bs=VLM-qOIB_zlI4lI%UiLC(^x(vu0}M8KbHDCnZAqA@US@PZhVS zwnNQMtFR6B7Pd&He%RR}9m1W1vdDy6Bw8%tZ*!bzVMai)p*W}j_Rcih>0vTz-65!| z<7a7p1pwSWpwNJhZgva=ZpR9_6eHT&3Z!~{*g84ZrH|8!R)Pc8vee?J_m+*{hVHYt z5|g27eR=21a;?Y$VNapkvv34`(wU-HKQnESLMjQK~DEjr?i{sujES_fT4WT-zlDSp2h&;i>a`O5A zoMlNqez~y;%7_h{M)y}24py=igM@ym+bpqrGN~;BQNvhEdX^mxV@;xb@RqqDC)=3p zaP$MOi~Nb^_87C@pXDA%!unCIQgD&|GE&>8QbuROS&${L5VN0uiK=63WdBC>6q^H* z=I9YZ}6U)unqt`bOJV_KFxqlH*tw!<_ix-9U)sQDB@9@hd<wOSh(U$O;t$8#Haz3k0a60nUP$nzZ zCEj28B}I?@%gKfV48K|!VbcE{b_r(RvwCMWAc~C6*B}U`meV`|?1X;H5Mlu5TJQ@o zb{UQsRCVkO%`Mu%q98b<$O(0XkY*o|N-h@FZHgg7#oQd8I#p4rL`YCOJ|ifMIJfrd z)1P7!^2gflv1t6Z6eev{*;fyr+8G_hl9&Ji0J)*VgM{FwOYxU1CnO>JxsN*p%OwaQ zZFxrbheLB}z6Jw`8F8|vrFSw8?O6EE$b#KBa)OJBGM$|O&-ygm7wPYJ3z0SqZr$zd zVgar*yt=bwR=8tdSZ3IPFhs&dQA36DM_}r%SG-52yH9d-WwjX4+Smp!G8c zVlu=_i)MAjXlCuri2jgQ*O7zy(LMY;?%p%Q;38ea9$hQ&PZ3V{H$_M0Mx-)s;OWliG^tad4VumRZnA zjfj=CY#2B$t}zoCe`FnLO@y8+J=i%!(xotJC-Lp8B0*fmBfIg5c*LJ2`anQ0ERHxbwwyz zuc4Y`?`{kim7A>N3vy2s+a2DX0xDn}@bMfOL(GI0^ezf7Mtn|GCbw|`2>9G-t&~e_ zs+o!TWrOcWf?eq;wH9T713g&4!E zshFGNV_Q=#3=i)P@ywH;7iNy`v(JkfHu^f(J;TB2&ArVb0Y#$*T_W4`hmYv6SatF_ ziI5F_k4YhAapH@q@;^I(jLP>o1!oU5D-8KBPtov94Qk75`}0TnYGAP1CG&&lF|X8E))dqk`Y{sr`-GlvU*BN9kkFn^xhucQ z!rne&VJLC-O6Mg4L>#bAt_pPqGI?&74j37V7sWGxoHxZ!sbco5n7zah22vX=23sTxM};V8C>WjI1;R|sSX7%QX*lP1cqg!vK^R7f=gVLy z80S=HwY0!nCu=G~>O7zDDzTe_+7L3`4O|zv;CB21*aHiS;^6G@gS7$6vk5%N87w1V z=h2iix$G!7QW)j{+CtJ7k`f2K`iTk*Td*+yCcE3kvfL*Awi>$tOLj+$Au`qr!emT2 zny>F#m=+bb#zISz1MAnI!R{`C3sMLoK`wZ z8gvg=X+U%i?9SkZHXX9X=-ashwz9jsmbs6XrS5iGCY8>u*QJVKADqYHX&YLn=Ivx} z%Ev^Xia`GrrCmsBM6le|0w~3TOalVekx?nY!g5r@ML-Wl{-SE9bg8-#^)#t z+*oX{9QL(O)f!E%E}FO{ySCWrqN>!kNprHO7!StcAoLUd9TH-8<(>oc4l5OPr zON(tn&*m)MDI%rYTL}6iI6sG!As`w%vsmhS$+ALrRQ-y5A)NjkalbW}L_f<3t|$8< zvv?dXYQgs!IXdF(hm^RP(vrDiV()uH#7km_fcwW{2Z1xd{rCk>)(AHCa^iIf2-!m6 zHUf)ms)^y5v^5Hf;Q0uthPp$<@0(@W3G@@6+Cr#Pn9epL(06ji;IkMI1jlvg^<<1hLD^zb zVW(wxyRIY5qa(&Sw5rbJnB095!o=EQ6kU8!BHOLP@Y{@HD--^bi*7#BlZ*k2cN zQ61Z+(VVZ@1zI@xT_y-Kgj0)H+hn`$6y{=Kf!2>#jo=(_)(EtuX#|l0EM#)#5gBqZ zvqY@a!P(96yv5Hp9NE3sHao;XO+WbGM|W97GSd0Bd=E)0TZNM?onb{IgCM;3(GQwp zl?c5KAVF>*MJqmSrJ2#cwN}_66{8-@YXnMSw4m8DU?l+AdA9}M2qK~zoOvx0la`dpT@HDrD70YY zxi)TbxioSu%L1Vaj5xLSinqp0BDSJShXDYMJKY8BB0e)~;>CHrFz@!o*pug$mU(W3 zzBL){xfvmo7Lw1DO2+0Zqv6tM*pxiXXB zM<9#wZ&EN?w7x(mgrhZ74rB%rM*=|rx0So2un=lNoCT|zf!%f()?hTScH3VGRCR3I z%q`osX~DQr{W<0jtZyfw)&-(tSP2_0mzMbWiHcOV5YyE>Y;h)fGg0VW>11UV$09CEPc-N2ZPIEr(o&g6BOHq)TjqmYC1$ zpWQ<_E}hyvtu2h|GzD!ABw zQuYY4$n~C`$G9VN*=}OeR1`gZ*V4E*1yF=?mYkq=J2VlMc2+W5iEd~=^1T4cFc?+ zW&VsxW(uDfda<*xHI4%)i-V;0jP`ZdYVPXDohtEd|Fla=>@$Yo)^8NsA-(OHL~rl;&&hDFXBi=p=o}=Jf9P6)5PODQMjwv6&&eS0g#kEj zu1+fQECqhxNvd*K%D18(m<>~}Pn&DnZI}Tt1{N1!WyNJGOYMfRJuGe+bB=uudo_uO zTto=NU~#mxQozA(m;HeNDEg+us1j_$$)8AcCzliTlrbDaT2bef)!rU*Gl#(uFvAoq z4)2*Vt?R&$c+HTO5!LoMi-jo=g)RTL3=oF^<~-A-@tD!46k{U~p#`irw$1#i4aJbF zCYVA9`poW#5wRdlE~<#sa6lW!r$(jy82c%F;5ZZ=nVD?FtP6Z1;u z190kWZfW9(bzrQ(Y-wRR74BAeVTVX+A0Q-&&f=rMHmQ2xPHvd3FWaU-yxWrgnel<_ z4#KhvuwGFSGc(xJDYY>+5R9RJ|Mt$}A+r}{ZV|-F4cU&=O-&TE_uNTCqq~rL&0MVfGuQ%RS{KHCQHZ@KiDF6br?Mgk~m@_ z!`yPW*y|hFBh!}d?JH|r*Ej)h8FYxs&aYkKG9@e_ zuWPN%n@Q}_Fu3gqD<_wW>5g9>?gH3xFVntxky+Zf3pjRsp7}nu9^{xrk@AgP*zp;= z9?rP?3Tw*A*48v=$9a?(X}j8!NA`P62*SDv`Asp^+6le5isX-}3w3cSuAKC;N(9`d zESnwG?y?~+7Up4lyCQ{Q1FP_2XT6f_q~xfg*`+2UA3@1_esuHv)_A1QtHI7lOi22; z%V10Hqr8=ti6c83=0Qnx#h^%FkhZS_&-98$Oe$nD%O-s6h8+}tUXkrM@*XCesofo4 z$L03=wc}G`?ABc5oTXK(GM0d4QAkHfn=BlN|87hjBw-=^LA2EEgerEs>bHZ7I zT@3z6OfTIfhWSXx^cAW2X9*q8Em?d_mkdeyQ=*4y;aP@=tTd%b_>2&DX=dZEQw8Ty zj_n!)S{5d!4+E+!*rBsu{z^M_@u>dJam`+AmFaM}bwWsEDDK_@mFZQO1dA|B1b z>e}psV^ZR-#<0G-bR8%B#EvCLt-}Y?9;J0SQMR_I?2Zj+aQMGYWFRufD*lg00 zdSMhf`-6eO9ds8=5JPG-an!=6JG)(PTOlszDZ^!#x5-1?-?z#%|3 zLhfXR%yf{FQOHNgE%F?Ogw!GK+m+4&dpib%co#wFF!s`^ZPU*{KHF1pFc9N@ zoweCBU8FqG`du469s@HX@~vDeEqRr56S}b-2_fkjdKBef2{j0lge~lyBSv3_NivL6 z%rPzC%3!>i4KW1hVvQVu&M^^c>@?3Jl94P?mb%yDx}Yx~#}0$FU_*K;@{4)kRyT;W zH6W0g>$RMT19?A0I{_#@LvRJ6L~tN z!N4wsYg{TKGK1mnxs7RG3_D+e6cn9&AQS+!!py_aj6H?1r=?_=dA03Sj-YaO@^pw@ z%(CMI0+{u;SQY^R1if$*tw`mKjA(N{PbOk8hK#Z1BN|Y5ZS0T6VF@H;iRSL+IFD8L zn6VH%wLR$(!jVjtd6?N-LdIr}CmJp<92`>(HOle~1`;K$4(d?F&+gDJ_IY8mp&nEK zh(}VD2x8ldJm1DgK|rNFg(+WQ97E!57TLqai*cA)RoE680l$nfq}Y;bQ5KV36LN?J zZub>Q#4ySm000F*UHMDU^JEl~veMQlOXQcl{z^M_JFiZ$I-?{)Y;$*VcW%)UQl9X| zB1RbRBrjo79zXRd|_BDSL;8Cq$hSbPX0U)->Y#Lr`mJ#h?) znb%jfl`TXJ%tZ++E3+IS5;aD*UmwAxPqquRF)nqqGQYezgz13|=4lVsjv8)#bslai z^r;vaU9Y1bvn~2@s}Ga6jz;%(+t7*pk?QYg$hWLl?g8w2L1@d!LrEboGoAMv?7k=O z?gA#N7gw8=&0vCL!M4Fz@L-)A1YBy=kR6rSa53nslP7EJcO`#n$2o=HF>MVq5V_r( zJ{*yO+7Rtb z1R1u$3I>hEWTYxYrI9r)>$U`J8cHHH9&n6}jiN;23$M0 zUQBL)NJ*Kr17jCdVNEC)}9mk;1z;Fw#+9TNk_0BF-JtyY`c2!K8>JH{~4KwV6$1$JJ2 zjtSZgsD2N(x2M!kahlyMNf65`{yf!~_l(HQ4R_A1PkRO#v+?Rj^eeu&)i=V(PVy{C z^fBr0a5HOB1fISd{>EMs1_ifKYD*lCYND09%z;E@v#%0;_>PT8C2hCq(qMV<;GW)? z_t4EtnUd&A%o>!U%0i-MiVXl#Noeo8$rOM~5JIF044Ycd9a}kEN=`6fNA|Wz?63*a zs?fX1JIb>|t=*xVw>IYr0Ke4I?wuK|n4p%qb6RRBhY2}jASS3`t6s}vEpaT66pX|( zFn5ojc0LQ69F+~h;=Gw3k_!@HHUt|RpuCe0A+Sx9PAtb11Av>9Sf{#6R7NmZo?BQ_ zFgXB>LMU)v-ZyfHfyj#lv&tpUtO)ke^|P-8hDRz#;OLjbyGIvD%C)4MEY9s)x2pP; znjq+zNucf7XXX}W$K~u6-pFyFwLfe`2oUM{rE2Rex^t9rWTJ?&-xvT~IFd{aV!vWh zsI9FjrzS{#Vg8$e{h=myAMPk0#vFJ<<8Jt0SEldnLV<0Fj*& zWVhVq*rj8RLQLH0+(Vl{i#7P|Rn9kJ)15uk_ClyR?$_X zwZ9zEl~lQIfiM_n=;s`9&C-KlueGHNWdS?elA6q8q(RCajak|OJz(f?d}h3EIgBl? z;fy&#clhBO(5c5eQ+R1}xj*y8a~qztbB)h61rqfE((c#loFecS|rYz>!(P zE684xbBibeKbbYEB|_VG*zeF{01-2aDO&QiWVo^a=a$?2IdGbZ0E{t%`Fd%QZ|uw( zRG}F%gd?8dOzgK;Fk(?`ZC3kJ;;H1_b|a;32!EKtp5Pi>Aa*ml84dQ1kE(-fu+M&E zCb}VoF1cJ3I5M26jU;+duHlhA0fc~Rg97O2dl9n{N}>;Vh@3lX03`tj9HmW!7PEOt zlo5bMiU|g=#s{-8tPN?yjUhu+HNCCXz3QdzjMjh|c;V#io0N2fG3Dw@@@73~dad zcG%JO1Q*|5dDR$i1nJzND%(ONltl0C=#(QY2-S(9)Np}+IEN6}FTt%nwB;y)upl6` z>e1INtdLt?w`q=aGLC48q*u`Su}CP1NoUAP;}i1hAr?Z5?GhO%%>_YR4r0ejBW8xg z4+g+-D?0%cDY>KUKwt(Ho+j8JFf($9jPaE^wqXEdXGZ}Hy3Ht7qcH=6%kE%veiH)$0``s{tHurRj>iMD z9t>-9#GVBJ(YuZ95+JY-eX<*g`@Q|mVRd)|592usLJ1|?)jTtkHv~Z;A}X|$cSEa# z@R74Q1T}j8^oKs#uqaf@Rf>tal9WdYH}(PBJ@km6P$?A>sMydfXmfjj#(voNHafOK z01Q_^NvaEuwu|FSyWnaJH`-{TMpI*oqNhj0{g)3FDzF1ENFl_9Zti zOY6&7p6@Ep*e)G_-4vr44EGmDhZ{vhjq;{Y*D#T$P_7+XSFYFDJO8EH5*k!$;qWO7 zJI!lLH6VM-qeD-t^lQuF$uN%+C8)DjGuwUAp=miKg#T>$rQQ5kvdx*nWJ$l~ILijw zE;~B@wA%{78J}AfBsWuZBVO3LpMeTxZI@GGf(6q)uR7>$2_XRPdc`Y+BtXP=GiS<1 z_PvyS!SY}iYvUvW0jQQ-ayQXNTC;o0t6pavIKIs&E$*;0RmdNF%0LWch)x{W!#-8D zJG-vmhs{kO@&Y4Zhp{TxP_G9Z{FoJr3T}@^RA zZMV_}5#9NEb}CNP7?+m>0hPj1sj^U|Qi@a}(V{UKs$(KQ1K)-7vI+{{}FS|l8qvNE&<_u!Mcka*(YN)fT zg-0}05qEm#ERkaZF>z${xVV-|`@(-k$tEo`BDiPMq!6)hX2*7z1$nA9?15DIk7_FX|hrLT#EMN!b*%wjR5IuimZ>lu{ zvWq3)+L%h~X=56#Yi$}L1<)^xURe%$<*+OUWl^9zaKtmQ?kQWwVBlQxUO$b%bjYdSpmSX zXx4|5r2!24gZX}MU=r zWxpuO!cC_+t{QoF1pot+VQoy^=&EX}s&4A0YP8W*E-e&|QTqq|Ua#Np_sU+OR8UJ8 zR3WoArfTYHGOg=MlW`A-5m2G(^#}dlps#ueiiiEf6RXocptFoJX%M_1K3|&FO;cCX z>2y5NTHCTkQ4EH|;b_>iSQQE|&J=`@_ALY^W3<+FRp~}+t+j4Q8&s;_?-ga)E6e_1 zP?jYZg+l9`gy6Up_J87chX;n?MHgyBWV4+m6KkAjke!ti6JIe;qy&l%?y>ku>lQE{&&9thf)pR_b z9FAdOczEz)bD+y!IT#HGqd{-bFMFjb6r%Ga9^BaL4+l%fRxHD(V<0MHLDb|=6wBT$ zcFtEDlxp{QYdu(5oGvRL8#`m&E3Z1aI)`ee7a}Uc)JS1TgTQ{r(97)dLjjzaLbV`lB zBN(FN-8Sj7Zp>b9KW!lr)I;|c7+X>p-BHp7C^MR(fGI?kFv|XR9+7kexj1bfpW?eM zvvkr;HNFAP?6F>EV$g04f|+cUVq|K7e4W)b5*^%I6vx@c728-^1ew{5n|LFU5thZmJ-439Ud~Ho$HY%t{OA0 z_4VDIx)^NU|L}=(cMlhrOzIf${FWkKL((2OE!mu|i%bs`9gh^t+hnO2fhqXSO zPF^~|Ph5H6D|_b-&Aeenh6X*e*}wL>wWnUY@lrE4Tp095y)z*AAG)w~&;HzM4{2+1<)OW&&K_PJF0RZE`omtYR}|L2@4f!cx&o(AO;tDh zb7!MIq~TnzKOAo@PX~+?b8T_L!NQAYOjB3YwA#6OvtYjK?AbHh z+jGNF-PD(_UVZAqh08lTtE;P{xsf#>!kWI^W@0t9A!@2>I+;{ey>tEA#pj;CdG%Ud zP0O;kyuNz!^y$s5t$tk(N29@DP?n_>S+WlOM#Ir)FdRZrM1(L93D__jt?Q-V^tn>(BS6O?BzU z<)>b{uyX@{%3!h}hXzk@D<2 z#g9K?0>CT#2N!n_6}k;L6Ri)c`s%^t3s?7^xH;a}1OQf15p${F}o+=PSKRIKInYE$A zy4e|5U%0yPhc7*FwOUo65qLB#SC)sDE+0Tq0`dLJ&wuBsubp1TrJ?ipU=Xv+0AL6j zO_RFWo75L8^(SlJ^yud6$F(kZFZL#TrW`cOC)DElJ(CyTas5+g`_CPU+CeK?+6+1>xr)f-RmA5Mru%r-HXs7|abKe)ZUy|%tEKR@gbdR9;SxMo9U zGM&Cq&j01B-e!9JBwB|7fQNfK4?g;b8`RL*1U?nvF&}kF4G?jPM$q;{-IZIZXKIjSa6021~@_XxSlk|Oed3_!^xF} zm6z{$Xga@IObwc1uz#?2@yTP;ODhY*(cE0m0`Y`OE+S)0UDxA-1Gs+e;jcdR`imFW ztEzCj-x!E*4hCP?+WOSJ_nFPjg@uK|a99=vC>7AK{7KrFx|vQU2fO>E&8uGh+Sk7B z^{cC^VXnf=2a|)(U3mP_r$1MfdTw#PKO7Xj0u>?v89I6X>}Y-j(WjUx?`SDPcu1-i5Yb1gPo3t@g ztewP6zlJ7ot3~*Z!TTV+{;JWb@(TJ&b|gpoCIz~cTLLYtS_KoV+fmo5G}gn(cMjH> zz$hYO^?oac$h)BsqdA9ZtCC9N(u^!Z!JH8bci|nc&mdaZ)?jf#d(2@i#zuw!0meT$ zz^$(sW60ju1RKjR7@$AwB^?4@(8z{SaE&F)RFa{z}>Q-IUeObY+$;Jwz zA+EJKnAXqj?0@vdo7XDM0KFot{-T{>U7YCaFW$UaHE-BjMFfPNT_dp03LA8&i5uec z-}5*B-Q`D~eC#GOD22Tedu0)5$;{VpPCkBp{P^PNyI=b^=*53%43P>?!N#Z<;zsML zu4{ru*V-6zD%=iGtEX527KJK`-k?zZQuWJzStu2aNwAAVl{R~msv0gl@)TH~^vL7?-*4=G`Ll=sJt&JpxkwI&y(XSEW^Yn|^3uvjF5aVA zDZVi`H<(PD@tCJmg~$bg8Jn+E%a;%D_>sH5cHagd;-FU)001sCB@<{vlUnbOtFO?~ zhwpjc)xG_tkAHCU>eq{AVtI>-UbB4i(!Fo};C(;&9hd*;TgT5J;II!xp%f^$;19$M z#!yu?hvUgJ*KdCErE9y5MpYEVO{2?R*)+OWmZ~UT+S}imTzKf@k$S_`Oy!SGFwJaX6Bv%mi*fAYeWE6d9`08mB23XvQrW+p>*T}{U0OV2&` z_@j^BynX`#`u%=};ET^bckRl{4?g_xJrCY*Zx%&iZ5qEsAVQ>EiS6{>m55?(cCAb-&ci zw7QOayGUk%&0DU&c>Z(O|KQ$Ny>#v#+h$c1%Da%5fr+%%^>n(wyFVI^-u|xdJaJ+h z0JJehSsJE7DMO}L_P^=A*Wa;q?jw)=;g#JRi->>&RVbySk)TPR9 zSry0vX_UK#g^3GP7S_|?R@NB+tcM#l(ZN_3gP~z``)ERB3KWTvLEChC&!1xoI0P7l>!n^`FSVLLVK0hzAD;P1CF_Ej{vsKlvAXyN4Gq6v|HWRS42C4BF7R zZoX>fK6>>e@znAK8N;kc!``@>;>0vdz52bIev3@t$%CdncsR% zwWkU-K(s2_>JnqPsrBJ>`qJ*+CoW&xH>OZ(GOe~xZoTE3zv=5wKmGbg9{JeEKk=2P zzBU{VD`Woh`R9lI-aRL_%c8^*3wx%b&uF6>Ubu-NFGb2w*v#Mg^3Idxjs3DL?Zzpk zie7&(94!xqqp~cOvy736jnUO~S^)gb_r7;yea-D05!{aopg^u^bA9b6e&G8*@S$JZ zKRi@L(L)j4fQ=-#Dwm1q?RTF2o{eL_@}*0U?&v-%nBplMf5)ln_;BvecF?*xZDb7i`6AiL z5R=w=T2*_yyFdQ*$4;0r%_&rfM7*%n|D|6w|KxvwCmsi-7V%DVVW;&S`Me*Jrc;DjUq9HRH&0V149L zwDzOl_Cp{1=!Xsu#|uS)SlS(a>?cNnAf3uqP|QV8INRS!3U)hUND~o(W@aci7k0`@ zg3BOtfaS$(8Y7vkJ-1WocVg(3V${vIQhi?9<;|Cffk?m52`!jPGQ(REo7_p#wwh0G z=KkugVzI7JYL-nPw{Cc`8ma2-BnMx%sB6nid`VC&zg~ear2Y16eRsQtNV~9PHL>qZ z=#Z8{C(+BazJFvxe=RBVZVlVMQ?tW`p81NrDTAy6%06sdR2{;Mokt`XK%(<0zNCC|nSC$N-OT=aOmsXl;tv~nj?v<&|!e(t>CNxC+*yX)r^P_WR zSt`|23KfEwSFzDAKKc01eE;h|_Lumjr>pC`x^74tWUy_AK@aCg#r9_T$i1q%^jSSU z#Kn1Eof}`wV2nA`@bNo-{O;#IeCd(DO{!N{^|Y!d(|R(krd3_n^|Y#|lg5yF`}9A& zpw4Y-bH+ScmPO%~b_f^@bFIxmRX^~(KYHqchk)o~AN$ycKJ=kq_=R6MbNaOHxcT|{ z4}9PQ2L}g#_wW8)EQ(jX=Z8M|{(n4ZOo4Wt0U3~)3~^;>GOhpk{6hy{tO}(SLs6>n zWQvH@wBo)Rf6w;e51hL9G*%R|E+gC_nW<5S)#&1fzza5 z3|EbwOzX$5?H(9VSj^AQ{q#@%*bo1}_q}-W(!cn%U;p;Ey!n0K``(ZK>7V^?ANUo^ z@}GP0;>!Gduh&z`EfiVBN(8Fnl|3BvRa*cuFsQp|@rQ|S+VvV_L`Il46aB0zD&>|U ztWBe}*3U49TeQ@WR3L(scQem13?aRPo*Kc*lo-@AsOfR;nlg z*$+P^(oH>`j34{NClB}bi?-iv&R3hTQi5z1i zFO6ZM)2qw>;F}lz{OPOz{)wxn2M3RA;;=V37>|uMs1%pvHu8JvVgC_P)9CSd{C!V9 zdKwR#Ii;9+b%U4IaPNBW*a=#mqkHd$roxwBM1WPU|N4tx`0(O#zbp%-ps=1>X5%7c zr<3U$-t^6L^Ye`{`@1{;;)B2X$DjVnxVMd?HT>$0fAdElc;x)nkNxd6F_9oJ9I&*V9(AS^qTb^aijdSG%PD( z1Q?_R$jKoDs*7S-yd<_tcItcfrh^shVWNZ`PovQzb&xK$pO$SZAHfb5_mptQ8o zmCG0q9gqnv4YS;o2neZX#oHFPA(*yN(uOm%Ij3jbC)HNvC~kPom?__Q9pwu-!a$RS zJD;K`Fsrb{UKZxG4HkP5*m8t}E~zCjM2r8r4G{svEzNMkk$%1t*eg1~WV<5T7Fag< zXCI7~#p<-_W7V&9D!7d>E&(?mTQvww1O&j$n;TG;Xv}Q7Bo~4|5Km^H0)&k_H;U#) zx+za$*KxUAT>x^;IJ`te+R)8O_0;Yp`j-%!rYXyW_pF7a04n0I?i_9{js|5}DzGUf zSQIQbI;GC2tf9I&(4Rz zH5Ff9eKSle=Emrzt{Tw##G<;%{L(>lv)3P-Id|uK-t(TxWI{xUc>J#OTd#f7&SM`R_7?pH zZ)Y5m*3U05e({ZW4?pr{*s00zpg&;HSW|U+e*ZszVEU?+Emi*WxrZLXWm9WFwf&km zUi;E#4RNVl!-&A{i+QGh{PFEKpZtS=)Hf3VMg^pLz^3UhUA*sm_g2qM&fI%&{h2fW z{vWM9^YLfTzx6Xq54@wkpvzuSptZw^*l5#eePcYiG_8w55%G`y&<}psyWa6n|Jkqp z#iu{ByTA9vFF$$z`Fl6k*M8=we*E8lo;C_`ssz&zQ!0*Du$NYkZKW{@4F2e*N=Q^d26~i<^SUE{Fn0!^C#9$Y%OkHsje5jLY02Wur=%J z7B*rF3WGCd*{=Q?w>5?hF#%~a+FsimQ1k^S5Zfv~t0yZNC9|BYw*{HhYgtOP3^=yF zW{N2o4FQNyUNOkHr2?Y8<<*(o8^N(Ev92Kj2n`qviyUo^uw=>;zprR;Q6*^c1z^5`o2>M7`3=WOJ#sPxu z0Q4zSsAUud%Mp`T9U@)0iLFX3`#K`;K}j@XhlL!&91C%PjSL|qoSiXb15}xjeLg1` z_IYE~xWEnuRl>#w7z2pidFm2pwGDe^FyvOR$)@fgp5ItlTq(Gk`uNLRuvBVyBczox zAR`h0Gktw`yw{L*dl1p9U;XNz{n?+LOeO(02N01F6yOVo)wD6jC9_wokQFj204P+^ z?A_4yw5saKcn|f}rT(=OOIJ^?yu3O0(tw^j+_`Z1(z7pLd3idmu{tbN38<{2iIoeu zW&6XV4{zM_)W1C3**(}lIM_QFa`j6;ao4~3x!3%^|K00;_)W)EU6-tTtlw7u$$j)S zn>&R87(>E3WPpZf?XL5~`2}l8ZJ*fMK7IDL{@Fjg`jNkN{Hy5p8u)tkEl>E%o`a0bAswErp3@+I_GsAQ`J%7g?>nke&N&2pGP+a@W z&5NJB(p%~+eaq7I&)?JsjY918dgt%BqiGsDBoG+9@2JuG%Egz8QWb@2iiKwn)}B9H zec^C*d39xBd3AAlb#Y~NVR>a?Wo3SO*{1q<;hAUZx?zstUtW{2F-GgAs_Lq4AZT#J zvWOyu8JfD8POGMAY`z%f)Vh1S^nHFmD^{{Z~s%AQ-Fvgq<{6_ z!=Tsy+y4_U^k4*P4j&%BKy}S7#>oef5ls#bPoF(EH@~2Y;;AQ}{KVJy%ZJ{x@tWhy z_paY{_v+dmtDE<2oPX!v_{wiH64;vsWJUB-ESRv^^g(K^{=uhNQP_Dw@NGuu_pW6tBcZEtt zkAze#;9V3}WTWqQxnVot6CVi`8h%GL!LhKsA4{^Jh7%OPkWMy(7DhLnP9UUh49^0p z5vBG!sXFb1n-Mlr%ojtBl$oKQzJcge$pYMUGrQW&JHpK56lO5ZLO^G>MAELV%W{l1 zW*|*cgNK&A=*?sYQUD2FERvDNSvO0^oxnV@ms@)AOEbYn@XI_L{`;wf4XdQ%>$>bw zRk>yc5{qBb%wOtrfcJ;S5K|r{xt?dP~7$U44V^!*(7^}{i$S) zF;^xv_+}}kKL7d8zw2G^diT5E{n3wpRHT;hI3pZ3=AhB5M8vGno-c%e1PF+#-rF@z zqk6rvR79mQWVAMhv|#}3l_mFiIyKA$)dZDt4l!auVyA2OYxUU^KT;h|6igJ;&;QhG zdZ_>8GcUaM-p&8?yYKq)S1*70=^KFf>Hb?QwfGu-(FMEs`H69-qw~`7lQx#JDAX6f z{N!hU=YRZ}Z+&LtP9Vhy^tQdrAN|Dp|LET}@A{q}A!24)-#*=&UofUNr43L(wx%}I z;jj-3`#*4wR{DdFUq<5Uk@drOpDkXP;%5K+^4xd!H*Pjn;ia>|f>GJSe{9Q)VPm+~ zbaj4f;qsHELN3c|cf9%L*|!|7-nmzpbfd#Y>|0*8qZ(}hnAj*#;EvlRqs^I< zCsm;gxnyg0N7BoW-Mn^T2aS69Gdo+~y1w$z@?d>{N+H0;+8P2FLq$PE3KdwjsOx5O za8MK_DpeG!Cba8&3&ZGvw!vGCDR-2DqL>~WPA8N3`FX>nK)Jz1Y>aN|W;z*9#^VFs zyKvo{tIhnNv?jl08)mw39S?VhTwd3v8I9(Lg8`I2&5F&8Oa^s*OdXmzg=FCToBC(& zo&Mkdi@NkhSla?%7^s5x_3yoZ@KZmJ-}0UK=|F?{1AAJ#h;*6w}n;=^y77EEUzdHl)Gyz{%tx|y!duWFm( z-5&1aBy>FK-b=G|w#M;41_4IF5dzK;Vi*DXr&ewh6_Q;@W)QM8f#>$vhm=m)Q)zr8 z%3kDONFr}C7V~eS_#9dX5T(7XBUx)=w+q3=FJg{E;_UWBb54?=-8`xwH)#vna^yh= zGs<`tK$1@$f@r7Qdm*413poP{48cLI(Wk#6qEn|%RaN!)-C6NL% z9ajgtqt#7jvc$W14WGMG08j5e!M(yxl^K|!8ly`tS_ttN>U*`fp+VCOc#S|qkljkq|E-2?BD$BCa<)AqPfN?P-u9$$poo+~m z8^cq>N-0Ej=N)HXzIv^$H6xxle(dM}-hX2Zz5j#%YBZYr=%0Q3@|CNqP^4YrHLxs7 zROw3B*!rTa4JTd@7F(@uQdgJCZy9ZBK#Q+x04Anqw zKDc2cb`fwe=$B<_H<`uQR3^J9Qxpo78ur!F5W}u2@f#6QYbXkZg<@u1Ro*0Z14|oS zPpiqn-d+v+3-{NH_x$#k)RUK<`Rfm_zv|8vB2yH6<3{tu7t1Tpt@b8wCwO)|dD5)y z04@)3P-2O}H_xQl40;Xp5Lm(8uVP)()1N993Z}j4&wm5qe5jH?>g>)Ja9=UjjTX*EuskkyE zj$pMTZW3^jFe)>+aBz%e;yROHUn{HI)R#Qu7Wtxn0cS!cV*~v|Zw_@XYx+T(8zLFs z%baEq>`H4_*f1~W%4B9Bq(P6D7DyZG&R~VGyo7FFX^Mlx-)ndFy4Qvv7(!-us)*6F zvOeF_W4jqGm zmE;CB10X6e&GhE=(fTnU0O04Z;;;X4vA#%`U*5g2ReskShYltgtS5y+L>0Qraf=JF z!D&So25;cWM3I@?C>R*)>fVjs&-~!St1Bb3|Npo5r9pBe*Lm+{W>sI)-E(6A3^2F` zSnR=FV7a>_m%F?rk|sq`GHHiJla?Hm#PC1Sp$ID!;k6xM`JX}x%Qoc@ebJUh1}Tyu zlA^d=?xnr&0}Cv$SX=`P26Io(baz$ed;XD?RawA$=$0sNzA+xhqh+t#Pr`8n#r4&j@DJ2L|39wqi0D%|-0h(AK zXhMms8KMZK5MX1cE19Sf3$K}sHtqJ-oNjif-v>CXIx!kNbylBx?efQttv9pY80qtfZ1cI+ekQh(c0XvOp$41qckG;VKBw@UuUHph6YF zB?4rS1Qh^@M1qA#wnOYvr1c#GdjyPx5Me1alG+^&alopyIR7S>8yjmNQG)^%NFimc zwIP#Scw?bjq8(GO##H0wY%nB2jv!M!oW^Em7oi!5K}^)zBF0{onRQgERh*gyfMiaH z?on2>bMftK?9#XZ`C>f6{Ks@Ah<$R*4v%1tnUr%*tKgND&0O-fKXuf|j_Rj*!L1%VEWQtug&^JNgB7WP0HU z^!!pt)0f%aObTGHH<`Dd<~B02cQdC^zm!6r;2}YWNmCrb1z^jb@NshcM0RS%am>l` zWVT(@cZVpqHRG=hI!^4C0|=ixNY*~RdA;5DhoPELisRU-XBet+sVvf^8fNxSD|*Fn zdSKFBk7hkWfPhh8bFzx@a$*%TAOgN@x%Mbj(EiB{x>WxlKq%!@t@P$*EQMX8bP^)4RZGwTwSVN zUDm6cA{2-KOoZKb;)96U*&}v}1DJzutFd)rwQ^esyw&P{;~Nis;+Nm`!S{VS2;>V- zpT6+?>0KDdF^K5RD3~Zqoi16VF0;ri5j!i30wn;gFE1S$>F{P}WfA}8*`eiDXJt*@ zdq_<;Iulh`J9{zKBvsH_Uev9%vXtHu5F-Ew^5(g#f4kc5N@39*IvvHEor9(75e{0N zHl!iFfH&qYaC=jrU;`$(1_h8Dy5>ay)}-SW(#ECe3mVAfKn+OZ8jEHH^NfsiKm|Zo!|V@?p?diUz&@w z{>K0OOQn=l3J^c>u@9d;e=#;15Gz4Y2}4NYml!)aw|5mW6A`@qwGbCG#$s|Hk!_z| zTVA%}h6tUtxZ94ZW95~l*2tlns>r?f>|jGeX2WfLb5k2C33L!7fxjvUt3yL;OUo!k zs9>T3Upfk>R``88#WPp=&@euBh2Ogqe|!#3c0fo$h~-M9T&Y@^Pe=&B#8DKDjf~!V z&#(RL<+b^%k&IEsAS0+U&YfR8Fjd<*F}t8PwmL>?lrai2l@T~}*3K-yp7eOj{bT-0aDDga9xw5GOH0$OTI!LqWOJZDP(m=F~~H6XB^FL_6(B)D5Hv zCdCAKO;!Brt26c@?qcsM2hVJos{bqb&gubQg4#HUoPf*ty1(*i=NhM%@N=M!5Uv_n-dD z|Ma7ue(S++|LOOC`1K!E*On(tYus#(3o*i`Oc4QR3sjuIEG5L+g*UCD3CoqWO@y{? zitetV_0^3|8C$z6ZS3f+O%BR6dn4MFS6_svBblMKCh5V`M}M zQ7)ICeesoROG{t-Q@TWn`$clk z+;s=}c9d+M*h(@ZVpuAjIe#IFVnhKTTJxP(zddhap18F!ysx_NgF6wEqtK~e_N6OV zL=t%&TqiOhsxTNHA7^GMWVIU3jH|gwiIRG?B`H+ryQ*1N7rJt|u7>JmB_#llP3?s z+uFxJ*Ex8Xu^uXR2g|`^L=~J@<3Yu6O~KMj-O~@N_x?K1-pN74qQ$CfCikd&zoHk< zz}zD+R8kc>BPK|d5dfSMsNHZ4Rd{V_G176ny>;umZ=YH@wb@?U8gA(N6z%(9+}um! zO$c@MwV&O7$L*b{V~FNgua?SHaDyd*+)fGj-g3UG$t(>gss`+mjCBXmiECT9qtOYH zNMM|~d=`v_uWGD-gMUgf)sx_4bT(Znn$K~m-FBJ=N{P@Epg{aAow*TCO8NJW;Pl|9E zAaSQ+aEp`~SADAPExPo%YsQTY26iklBxiIfQJ0kTB@Nfz`ZO~N7#~N=bmq63CL$$S*(J@Vp zbWdL%+U&}TLhg3a#3+SbP)T|)nO0lIAT)YC5<@Zy+U;Fq<>`sB%a6Uh^uSXUK@}y+ z%m#%nR~ASIDyoGMFfbFb%ywZBr4$<%&a7UU8{0E8J#*lJACKL6;94D8zyIO6$7d=t zObYT=mGY_bDY?>+5g){IAPl=zL|Y@F4&T6lKH@o;dmD%~ckHRlp?yOpI_y zmF~gHVtdP*dxGBF*nI7Uk~Q`w(fPm}5068+c6j5>royG8AK&%r4?@WZ28ANPy~{62 zrdRfSvfR2lbN2oc$D5;jX~*onFMVCA5D1dfB0{I@$C~QPmeSkpa1Nqj=k%qKm4OVec_c8N(BhKXQXMb%CTFCY;SBP zXPJD=e_gUY<>Z|+#}L4<6wX~+ym006{yozIaebl9C5p8^`hi{5Mu`lkw~1TC*zR^t zpT7_UAwwDfBau%j)s8)T-gxCzBD3GS_Sdh;>0dY0f)bE71+`=M2Hhk_C{mnoA?B_qT z@6aJ*%vQI3Wn;cvDuFyFM2opKS0=-x4HL7ba;+9kgoZo$O&3IW zwAJ_FV*uxj!j$Qy%;mzVaW@+($d9MX{12IYxy&IuV3GkWk!`!=77Qr23GZbQ@k>Zj+GV_dFfMg<~t{F+QObK zE4o9t9!za(`Y2($gf-})A__V5-l?~PLJCv>7XA9W&nrHZdrQ>fKA`JJH}Zc`Ui(m= z@_X@wUpizR@4d`k7xb@G$~=I#JD5HtV3{)D_F~*5i4Ae7!qsvz>mq_i11lA`2gBe* zBpFH$7bLda9?(snrH6<@^S&{37Yu9Nd?~(s0Z2<;AfheUoK0dTMztJTI z0MYM=gjIBgdA1%NXjY`Xcs3oOo|BkRGFn?oJ++e;E8lqp?!J**RG_;zm|yNR-*d;lkACX--a|W|`>ThQ?kYCIUNHl3 z@`2~Y=Asr*wu92LYHq{_cOj`?tP!_~8D>Zv4VeU;5*F_jiV%`-#~#A~agf zuQ$%id;igg?v1PCH=`a=ImaCWVDmNaRK7h4Av^5}x0G}JFuXWl{ zW)2X#o#>$-s@8^(5|T9nAYxM)GSwl;&=lsE&wTF(M?N#Oc5!6>We^epBmhXUcjILJ z+*(z)%AMtIP`!Hm3&$2;*kxKQt9B{Hiia$hsont1lF_lIBj z?BDz3$3FZIKKCn89KU(~!teddfBV$)F9l&p#52w2&gQTbGTBVDcsFq`h4ftQHnLQt zG^vH*Y1CRFPzLIW7hc-4b1G25-aAKU-a8hSmBrRVh!o%fKp3cppL}^~Z9Oc7*2O3{ z4G>tX*AL%z>+3JPaOKG#U3ub1{iHq7$wJ7P!-t2*#|5H;wT?UM=);VNL_9uPx#3{A zx*CCtzG71n!JZ?vj#N=cr%1>hjLU|Skk}2IKWHES`{U090sx4gxG%o^A-VS+nmQs( zH-7q0`0S4at#DZw<_9;Ac7lcXvSd{IlP>>9*tAXo2$N1MpTA>(L0}$;KprLdPf~>9SzLg;AHU5Zb+GUwd88G( zzWVF6fX+PmuXEv*f|V?sjqpnJZHhhWl422W5}c|wfD~$YwkFr49$v}L6?-_wXRH_< zq)_+XulZifnaWWy(UV6H3c2wkdmjBSCwtRfhu)GikD+a;?^D0MyaWgtMDQ_ye~cx2 z(a$zTnmz<#*iIv+0_;mhf(Lt3_6kiQBlhHs9m75BJn0T^o0!6V-l1z-V z5NJ#LXM2N}z-gV3%|;$@jhm-+cb-ADX^8S<`JT zo|>zi5+C@?Z+xxMsGol9=WqV}ht*Qa*Fg?eCtGl}sB`?%xo37CrVbl0hUizCjakCw z)}{ku5?X8O$p^yubAbqu!LBqA5e22VF=C}u2Ek433u{*%dE`A`h8MmwcK!*8z*5;B zoaoN8*6ZW5Z@mAj`?s#V|H2a(Rs=J%y*C787|_^gOeh3MsrFBdceH+GVNptTd4Azf z{_MY&%jIgN97XX~yREe;l|ne%lH4?hlD_8CJl&*akEWD3{tAcpL^la=Uxbc5QWHqZK@hkNGbOo zI;gwdbEjVK1>k9J#+b?7yY?TwLC7S+te?Kh_Kx|vx}7J zTabGDBt>F5kZ()FYSg}O(Hq0C!Mo)kNK+eO}Y-+lh~vAy-vk6u~5yxE)d zEvYYzDAcF$8GF)imsS4v{)ojJ7;l*;I&sN8_jB;dLdgH(3#hYnHbv&5na{-Mp~$@F z44OzJFt9yXkSK5>qL}EwbX+SN8*^Ps*f#^|vI0U@s{8AKA4q)1Y%mF9*k~K^Ozk*0 z9JH5``&asmpx$08RKczzX03$)jJVqFuC=>q8X<799MmPucgY}1ks}m>0ryvfk4)9; zrO+Ob$@aPYtwjb#Fj|k?cs!`qm^oBDF-+xvDk0X&08GXhgUVbu5pFCi=`K`Doc%ME zLjbR>*Y9q;da2dms2#7aY+ad$XbZb7(cK8z8@k(G)n-kznA+3`3^>||?Cl{Lc6IWt zq+GvrVP$b)_szH7`tJAYu{*!_YVH0D6Hjj*s~`KyZ+!KikB^R?dibX={>6U|$w(KO z9uoKgga8c0+yU|A=M>o5OP;*t{iVZcjs5uCk}_5bro$|gwh?FoV(>Sb9a6D=+cQ#zy94J zfx_wvV|NCG92@PDVgP%tRtTJ^)dGaYc83v#kWAd|Mn)S307PP#Y1Z%9v%69%NqhRq z5IDb7CXOp5oS8T@vu}GfT_n4%u&}&z>Dq#l$~QE&^@R{`T)ecfxOi}8Zz&9{n7f`q z3r!w+;>n*p`go~SvS+di>J^eub^w5l(Gel#>a}ZNSM0zo+$5)gVdu==8;&2VRIAe6 zg_}yIWwqVy64A~bJEW9Ew7k3=#jz0L+Vaxl&plhK)+WZr5HZ$zX=#ZKA>xHAm**B1 zq?G6!HB*oTfPusdo$;2z+0g|V04c!%qGDD63Pr%6;GxBX53d~$!g8`PYseS__G&1@ zI91=MMgjqaxV$>Q(c0M2oRmTkuvDs2tH~g+OEEo}}UA3LB1zG_f|InGFRy8?8FIlX&Q@zoMs;(@~Yvw0;8c6fEa* z0C3)pg-IzS=CIcc`?Eo30W$5Ks&w{$v`l&zex@r5KEs77SZ=dpl9*+lW572(Ub$Hs z??bLHJZ8|#7E^fCJ5f&~h;pW3> z*6c2XEQnN}MU`S8LJwlv4Hq!Pq}fEq7&Z}U7Uu3_Z6UPQWDM8qaPv*zkV9@M&t;Q9 zk;J)-SR2wYYfVvPj3%wQKGoQBs46!XA-VG7I@H^-8A`|!xY}M>Yn{5f>})M2TT5iF zb>h>lXud;R#F`ip$^wTK?ym(iwXm#Ia)6hMn22pjh{POg6YQE9zy03wj$IIxh?t0? zSVvJDwcFj*rS`d#c<$wrU>6F?p_&wrF=#T2T~(LyN~C}YfRR}+2w-GN=DCQBqFQD{ zLI_bWu|$!INWQh17`ky3j7;pj?XIaCZmEurVX1;zcQ@8n=gwVt=CQRmPL={Ch27Y( zEG7Ox$*h6sst6vbO|Gz@SPyNj?{BR%8Y6LI1cCsFp|d4c7HXSo^+46aQeb0g7$9Os zjGGfw8A2w=c8u8&8y(LF%~y9Eztr5fg^Em!LIpxhZqDCu^@Z8hvqA;}5YnLj2GnRX zt_(4OUD&b;$QUwY7F(N_*47rcI$dMzO{<}l%~Ckss87}Fp$ddZj+C)Uf@U&-E`{q; zH7)qI*&}1aBRw1LMPW;JsS&l-&z(H6y4g}nVXEr0^=M}1Znrz$tlxC#;Qs09M!gXz zX$-Ztw&v!qyn6cV+_h^#5FlDyk)UL+ptJ{p$QZ5HmX{YUU0PpWi8>u7LV-b8sx=#v zyLXT6*kLc#ORp*f&-gI2F(!_>J0~aay!F`O0|zc$ym)zj{_LfTa|;WG3?k0%-+$+A z$97HbIDO{K{KD0v1q0b_d^mv{Wtkx~|*SLvY~F`TbarREmu08WU-XG;1SOAdZe~gs}rN zwmaO~R$}2YZ6dO!&1rtjo~G|6e=(mX@15Ywn?G~n)JW$6fv=+3m({`nW6aWIIi@Bb zds4bI`Po~}RJo}rAbRY912H{b7rCZz(JNBMa-aR;(kAK+HBM zjGaEd4hpf~^1LB>ZJP4qx-Bnf%p%Fw1Gq&QO$9f}sxW@iM=t0oy8vazFlo{;Y0cEt zW@I?J{l-o=HpY-4*u4w(%_N)9m>awR88S%xI+=lpjAj#498(+_Z8+}4dyh|#*0vyO zXIs&=aLb&)q#MAT6NtaC|bE<6;Ha>ShF>j{h(wGb1ja4@Y;Go`a( zW-w$7Gpj(BtFlyPt>gA4#E}G64(fS1pw~Q!L$8hPl)BK8vylLRz{rRKg$-p+zy^qc z4eOzXX^c6{Y{e7OJPjE`)Irq}l}H4NP0h5+CQ<+r1rs1M83w~ltZEfKGO7*c>;wZ? zD9L1u>1u7mk0Xk5pvr+#LJ3SfaICj1ko8UlmZCM)XqS>(p%H+XaGM}ai3U%!AR;0G zNGY=zBi`TC-PN8umnh0%pp-O3-6+<^ST|31Sf(ht?hD(sEgRXEnN1wWQ51DL+Gr_c zST2WQC<7&&kOCBY(Fp(pu+|!gXQro>5a;LSVxy&$HsFdjMhS6f-@evH>+-@?Kuot| ztZbzU&!UQ6=O_-eDuOo{Sg z1_HZMf`AI7K*7M8H311BrIH{rh>XBwXlS&t_m)F|klfefwVUlQblb2108BtYhFBZZ zB@=1xYKo1C^w9M9#!r&nSyZu1rS?N1?kxl$mog2q;3J#D>lq5!K264) zr}K03Mk}6Ho%BE-KN%MGxf6Slp%5#2#cDdAQwv1M!woscwnHJVadJ;F=j@o4=vP0p z#@oT8bVi-ZDd!hdT=x}l58SAZ?Ue_iAN5Be0Pxs1PksMiJ#AvjrS6+_dnzD|G>1Os zrNCA`8TUK_ueSE91pymGY3+^0m3;V;Wa>|O-vArGtG~lYe-4tDjUi)Vqm3QQ zLJFyrNOp9GXD>DGQSh0{uhlLb?#+SqwykYBwh zLKeR%@&cIya4BL&*CsuuW*7l)Qpfhl1F#Kk8@23xUpz8>^Vqll#p73ATiGtnFGQ~9 zZ>`4rYKQ(<$sL+tLuMdNWBVrp zjDX(mRlM7gKQbX*S7n|VZD^*s)s5JYLrXT=J&R=L%FpEgh6gEylqCq#;yK5V*K5#U z5|ENUOcHD-6DS?9^Y?uuL0|*Jjjc$JKkzra_pY$4Ai$H`sL18yv?BOD}2#4MA zp{=S+@9{}U2p^Q>TQm3;{C=sV7QpZVPv=$f*{$ z#3gzLU3M)t69F=Z)zXfG(_yughFZT4rN{D^*=-b(Ju1wGOFJ9up$2y)4E7G3%o1n# zySE+K`(>LpOS3AxhkbjnkdpJ=nw}F*nl8UoQ;;akv&T7vk>d@nTWFd`!OZv8(Ph!Q z_>sNhX{oF@@Hp>VBiN>Pwu3mAZLaY-|4I`_Z&J54#b^)v8C@@S>fYPNzxLx#pZM9O zQxDBudUzKAIy1*|Pv35vzPBv!MBhE?jpyN4A?r)w zq*J6S(WLAzF0HPww!5)0-o8h#*0{cayd_h8 zU(d?hhMe9^D$q}#xt^l@SNC=ymG@I>KAnYriz@UqDSJP&J7vx3(Szi+5R95*6oi-{ zVJ_yCn({Q>YVs{vN=fV%F&S3l%}4|e%x}lAU#}F>Bo2vS?>chZiqUYjH5?LC(Ty&* zjaL*Y_bkUiIyMUF_T(Yc@};bq`iU=RKmvC@aXQzpd6AH$mBXE zDqYI8pw`|R1I9413@PF_7vh=kzWq~k0~*kP1~i}n4QN3B52-gq#DE4gpaBhNKm!`k{|_3VkO2*7 zKm!`kfClu=&;W%DXg~uR(0~Rspm&A_C}cnb8qk0SG@t>!Gc-UU0~*kP1~i}n4d|Vr z0SXz=fCe<60S#zC?+gu4$bbekpaBhNKm&Sb=>GtY6(&4q(wpW00000Nl9YTQn?LqeQ)Ny z^X~erR-ww5?x4Ll?>Fzy?3>wT#yjt^NPA0($0N9S#is>wp@2d{)X=w{DnLS_UMzs$ zkBVht4)CQCQ|%!|pjDL%C3fl~+zS--s<2XoE>kdgP=$Ml6!m5+hssq8Q$hEEdS%!| zypvud2TZxW;7>zkD4P5&&_2>*YSqKoOjaxT$p$;sC@w3AvL3RiCxS{IhC>yiqvVe% z#}i|MS3SkkNi}7q(0!-gPSSJIX3}GdKCoS(!Ib@d4)kPP zsQo_?9_DT2Z?nMmaZs|V}rs_WJSv*}>1bdCK&A2_F4 zw{!|HGm036QI5qT;<0_*oYkpU_x^SNGiS;tYk&3Po3SS^zQi`rC(2+!eV!7`qYuPz zY99+665{SV=J_hh7Whg<2;1huRS8#P?!p8j!F*^fYF)`IcZinJ~PY+(`nQNXk!_)llS6MzTA zogxsjD-94X9Qbn*uM$-bd_Lg!z~w9%05q`gwDUONx8cZXN`vRuQ@}11elc*H!sCjF zeT0W-LaieFdq4xCYDWJ*PVy_sPAkcOlJIfDaon)%gbVu<(2x^iu_8ji{OiW)RwoRj zdoXJBBvR32Vt*W1Y%;QDG-De5(L{=o?raXF62fTf*lfh&nRss^YsNDjo12p9RJumGYU44D67Eq_NPA*wk1oo<_cZReIGV7ixx^RgA*uk>E! z_nAiVopRvgG=9F2Qe=7NFKkjczGIYU#gAKX)mw#6Sa5#kv1QVN^V~vw%7U|R#NFaX zz>R<#0XG6}1l$O?5%{np@VCml{-qzj;?s|o{Q=gt`d3EHlKffy@Xvi?vMc$urvQF0 zf8Te2R4x}N58Tfr*DNHz`t7#ib9?mROZwqIPd?buK2mlBmQec0f=WpmPJ^ZV;tZ(# z{g^(|@J*=bBV|t@SwCei2G?7#4zB0s$19f~LdRo7K|Uen*LERUc~c*r)K9;&Nk2X1 z)jcok=Wd#dz`%WEz?UEIsay{IVtwrIp$2RgxleTJhZ{<;st>+ z#Ng-UvKz4L_Ur~-oBo@RKqDIJ1ij%$ujs?M@mC_(v71LDSM(G5$l_o4Av!-O4OG53 z>WN%u^c4qsefJoe3GZkhX~@EkApH5Z;q&3nw&82xj_~mHPJN_02JrUwl{auqCXAc; zyngzI*Id5(HHt_3@O$mU?=%npC7fUMC;jl4M_>QP+*>$a5A6=`3hxf@2^(WQJ;BQ5 zU&j8)@xhTqzjB-lBP*NTA2$MS1l$O?5pW~mM!=1L8v!>0ZUo#2xDoh2iGauUwNZ$+ zEiGF&SiTQER8zkjLm}~KSK=W!FMxn&srOU(jS#<=OuU=V4*;D4dIG3#GM~rqT33PM zce47c`TSX+&jPKYk1P0X6pLs7HsKizc$QX_`;I{y;>+NA7Hr{8T{M@=FE{r>bq!nt zfJ?w1Xz^ElrgHuxzC&Wuk`4DiaIgFfi2A$W+R1WI$AUIZxYk3T z;23cDlY#gKTwjEC`R%X8ANYDno4@L7-iTitDUJA7JYLr9uQ@VD_tzgTZ}o>#{`#=L zChT9)=+_$kRgL~Yqu&Q#@`QLDuCIa}{>BHaTigh^5pW~mM!=1L8v!>0ZUo#2xDjw8 z@S#V5&&Tn3INFXC&b(D{kK`sxz&USKCg@zecIVl3jhUwkBA!W~GAv3x8giRaHf9+zWqm;PdHLGhR6T z%;(STc&Rv0)J|Dp9@*s~_%wg)c)8$tX2*Sk$IFh-6(?yN?fAUHe6r&(JL$Qx;}t?H ziZ2i~MR9*2|H5vkQt)$V$H9nZMO57jCyV)fy|vW~C!Gh2%HLi%PivQ7RCu24IGk24 zGXK2d4#Cf#U4G_yY;5-yIY+HoQQ|Yl{VlS?|1Yro4Oy8v z4+GF2wC_Cszf9sY=g%)?|7Sj5wSeQf{c*>+`bNMt?u3ONm-x(ixCiiJ=kU{j7t2%F z2Y9hOh$l&2ge*>>dJ1sO4oU6>z>DQ0i~?RPAK^Ekg?R_gJcy@AK1B0;75O>~c(FW% z*Gb-)r*IK)jdZQ#eZb`(Sgjz|yEA6i%)yDHZZVy5V3_?zHzplqF|ipW(?(x36@!Ec zqxlP4!kgQg>|!$e0w74+F(Nvd)0?*e1nCxRxV3$2W4PVe+S0N;(qVLj8`~r3PUdgi zVz!1O2P71-rdHfaGKVFPLnW8Yn#^I(OR@Jr1hYf^X0!{anNhTlYl##jr3{E*Ds9Gt zy{TMqAd?=5XUriB)Rjv>>Qy2}5R6~78SNEPyf2#V6T#R}3S1}(X)Lm3Up$jdq*FG= zfVNCL8ASyVlnE=rfut$$C)k^YiWwh-Uzs@*%%o*DOfcR@)2lBA`phYPHP4g=*THzS zKhX`{!DN~stDv|pkmeEN$WAD_(vN@J#p6MxvKChdZvfOO?&pGr%q`>qU$ACHQz2MO2bre(HC$oR& z{QV*6bNq!yl0@H&vXhJt@@6`%9jiPJdeOPhd6LbH@aI0bL)G;y6!(>vQ|uc`BGQ`0ovo_*)|==tt? zw@2-gra>-IOfXaxQcERD2_K47B+4IvREgp!H07V5Mu;|03Z`j=i;~ny2{Mr6cyH#t z^X~dAC`Cw!9c%B+`_229eKWhB-JSPvq^rHm=M!A~;u8Y7P*5QuYRGJ+3XqU!5=-Fs zgJP9f0DQT`RC`DfXjSD*nUhu$?gxr`HCQP@S1A}gsKPx&ihA=EW1(tcD(E~=uL7Hh zchk${fGM{Z{b{HSMU%fpI!JmmiGJLRa!I9I6nVAb(6b zo){B6nkb%bswpeQ?z{DRNzYB&NRKJ{z_R;IEB5dB+rfI8G$Wc^^fmR(KvHf?$&pq_>^3R{WW9OB{Z>;^{JKg?RKifc`D1!y{c}g&kK2QeF z|M1RlR%r1@Y7tumM>QNRkzbwr%%awppF8{5{?qYa3{`D;eDU}0I6Lv1Q)i#r(D&;3 zGxztdy6@p9_b*xY`coiYvS7Tm5-lqLyS@aT1WYS|KQj;B3wThxUj#!=C6jRB!k?6Q zji_=q_d8$&X!hlgT6uEq)tlBSf9YZGWo0O_^XQIXK%mx z6$zNWW#R>D=ldhymo$po4Ba;wpQLfA3@Js%nLl&8!tq*R--t}waMfESH)X^5+QpV> z8_shE@fjP=z7h9|7XdEnnB?9kM-}pCU^jxKJq~h1G)-}E`VU-nL zGDd$^c|x8-Vbf87FBR5)3rO{9f%3rpL~?CH@(t%Z$4=j4jJ!gG#>{`h2>dL`SYX3c=OkwVvJWjhGg@MwH#b;!#cQLRG6$@eGna=APVvcDZi-? z$+~OC*tBu{!tKWK8NcB>X`H@hEdv8<$v|aca-e!O^o#YezXzMKS>!+3V~jSJVbvIW z)2cF#G%o;VYF(jFn2N#A$%?D+)a}~~x(@xf9)LzP)B}2B51li{@{=z{u3$HhM9vvc z7~{)d2tagxR35B;e!>^I!sv@G^vd27XeNAT*LZUdo)E&H>KuDH+|xOBIour{yV7Hf z*Tn$d-L>v2j>(jHtxzzIU-et78(yV&bd6o=8oSUo_Q!Bx+3$_f6Fy_}YxzIncapAv9f#WoAzS6#G`$QJ+NN@0pCjh$MKsXerK6_ zyHLmgodNm;(8}pT0l)WM1o|w{ri+EbOF)kSt)Y)H_-z!6@4;QdHyre>tXf$4D6}EI z3XWr73!l_Q+d}!pXAM+0!jS=70)b$Apyrd+iyx>wC~jY|<>p(~+=Sw&e>WVxEQcTz zv}wVy8Tur@(M1BmLuIW?790S_fWs>T@l`nPg?9NZussm`N?B*1=F9#_KpQWQ1Zuxj z(H5vbw7>{7jV|m6gi?W~aG*XMsBH;oErFVrK(HlHiC-GUZ{au$c8cHpfcJ_Q0WShx z1iT1%5%415MZk-I7XdE-8JgDfnOT z=Z9HUQ{u$^@Xmqvr`yf=VfQodKX>BgVt+|H6~%evlwTlt{y6c4g6EkNuM|99PJEHz zadzU@73Y%^huKNjjT5gDT1k9~s4t1n?mu?gsTO=4I&mq!w%=+ zlJYkQzOJ3}%Zk^t6Njs>#QgJ%_Z6={r~KUg+1Tzcv9DU;e7Bjkg4bEOxLBA)R1NQ2 zWw@W)6;IfKA@QeO_=gDR`=GKS#H~<)SzFxa&DV9i#OKCgi0trvmFSh8rxm?+R~?n2~L5CS*-GZDWc=ESEM1qp29CU9^3ATX<_{ zt5ZzoZ~z2JJ!Zrpb4J@PfFNmu4R>^HZwYsq+uPfBN4m}Ka7$MN-N`JFcbD_wN*oD= z>zHaTdAI(Z(Eb-#Q*;0MIfCg9(x>HjaUIWQqfo(T z2-fFyBGZEyTqxK_tn&Hu^FabIJZ0AB^(0e%P5}{F$Q-lceyHIy1MBm;lc`3M+<%s1 zdH~w-8H9OWpE6~AcmK((7>5eRl=TmjBc>B1$o}2u|2VYcIdMDub5VsTKMxWreQ_P> z*Ws}1Yoy1N&9M&iOpm(sdHu|k<>u3W#-$%31*YF|4Vc^B4_x}ZZeq&M%k1Ahe}7E+ z9DkvaBvHJ+?8WW>r_hL9WPM)WGri5O40X5vQ!f2sO(`&)R&4Q?$De^$pn_{qejMZH z1KzW?4ltyNEbF<#|?0BfB61~?@PGv4t<)qYh1?JFUu~SM?co2B&u8r HE>`>l-=Kal literal 0 HcmV?d00001 diff --git a/build/CMakeFiles/3.16.3/CMakeSystem.cmake b/build/CMakeFiles/3.16.3/CMakeSystem.cmake new file mode 100644 index 0000000..b33d2e7 --- /dev/null +++ b/build/CMakeFiles/3.16.3/CMakeSystem.cmake @@ -0,0 +1,15 @@ +set(CMAKE_HOST_SYSTEM "Linux-5.4.0-58-generic") +set(CMAKE_HOST_SYSTEM_NAME "Linux") +set(CMAKE_HOST_SYSTEM_VERSION "5.4.0-58-generic") +set(CMAKE_HOST_SYSTEM_PROCESSOR "x86_64") + + + +set(CMAKE_SYSTEM "Linux-5.4.0-58-generic") +set(CMAKE_SYSTEM_NAME "Linux") +set(CMAKE_SYSTEM_VERSION "5.4.0-58-generic") +set(CMAKE_SYSTEM_PROCESSOR "x86_64") + +set(CMAKE_CROSSCOMPILING "FALSE") + +set(CMAKE_SYSTEM_LOADED 1) diff --git a/build/CMakeFiles/3.16.3/CompilerIdC/CMakeCCompilerId.c b/build/CMakeFiles/3.16.3/CompilerIdC/CMakeCCompilerId.c new file mode 100644 index 0000000..d884b50 --- /dev/null +++ b/build/CMakeFiles/3.16.3/CompilerIdC/CMakeCCompilerId.c @@ -0,0 +1,671 @@ +#ifdef __cplusplus +# error "A C++ compiler has been selected for C." +#endif + +#if defined(__18CXX) +# define ID_VOID_MAIN +#endif +#if defined(__CLASSIC_C__) +/* cv-qualifiers did not exist in K&R C */ +# define const +# define volatile +#endif + + +/* Version number components: V=Version, R=Revision, P=Patch + Version date components: YYYY=Year, MM=Month, DD=Day */ + +#if defined(__INTEL_COMPILER) || defined(__ICC) +# define COMPILER_ID "Intel" +# if defined(_MSC_VER) +# define SIMULATE_ID "MSVC" +# endif +# if defined(__GNUC__) +# define SIMULATE_ID "GNU" +# endif + /* __INTEL_COMPILER = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER/100) +# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER/10 % 10) +# if defined(__INTEL_COMPILER_UPDATE) +# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER_UPDATE) +# else +# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER % 10) +# endif +# if defined(__INTEL_COMPILER_BUILD_DATE) + /* __INTEL_COMPILER_BUILD_DATE = YYYYMMDD */ +# define COMPILER_VERSION_TWEAK DEC(__INTEL_COMPILER_BUILD_DATE) +# endif +# if defined(_MSC_VER) + /* _MSC_VER = VVRR */ +# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100) +# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100) +# endif +# if defined(__GNUC__) +# define SIMULATE_VERSION_MAJOR DEC(__GNUC__) +# elif defined(__GNUG__) +# define SIMULATE_VERSION_MAJOR DEC(__GNUG__) +# endif +# if defined(__GNUC_MINOR__) +# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__) +# endif +# if defined(__GNUC_PATCHLEVEL__) +# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__) +# endif + +#elif defined(__PATHCC__) +# define COMPILER_ID "PathScale" +# define COMPILER_VERSION_MAJOR DEC(__PATHCC__) +# define COMPILER_VERSION_MINOR DEC(__PATHCC_MINOR__) +# if defined(__PATHCC_PATCHLEVEL__) +# define COMPILER_VERSION_PATCH DEC(__PATHCC_PATCHLEVEL__) +# endif + +#elif defined(__BORLANDC__) && defined(__CODEGEARC_VERSION__) +# define COMPILER_ID "Embarcadero" +# define COMPILER_VERSION_MAJOR HEX(__CODEGEARC_VERSION__>>24 & 0x00FF) +# define COMPILER_VERSION_MINOR HEX(__CODEGEARC_VERSION__>>16 & 0x00FF) +# define COMPILER_VERSION_PATCH DEC(__CODEGEARC_VERSION__ & 0xFFFF) + +#elif defined(__BORLANDC__) +# define COMPILER_ID "Borland" + /* __BORLANDC__ = 0xVRR */ +# define COMPILER_VERSION_MAJOR HEX(__BORLANDC__>>8) +# define COMPILER_VERSION_MINOR HEX(__BORLANDC__ & 0xFF) + +#elif defined(__WATCOMC__) && __WATCOMC__ < 1200 +# define COMPILER_ID "Watcom" + /* __WATCOMC__ = VVRR */ +# define COMPILER_VERSION_MAJOR DEC(__WATCOMC__ / 100) +# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10) +# if (__WATCOMC__ % 10) > 0 +# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10) +# endif + +#elif defined(__WATCOMC__) +# define COMPILER_ID "OpenWatcom" + /* __WATCOMC__ = VVRP + 1100 */ +# define COMPILER_VERSION_MAJOR DEC((__WATCOMC__ - 1100) / 100) +# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10) +# if (__WATCOMC__ % 10) > 0 +# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10) +# endif + +#elif defined(__SUNPRO_C) +# define COMPILER_ID "SunPro" +# if __SUNPRO_C >= 0x5100 + /* __SUNPRO_C = 0xVRRP */ +# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>12) +# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xFF) +# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF) +# else + /* __SUNPRO_CC = 0xVRP */ +# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>8) +# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xF) +# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF) +# endif + +#elif defined(__HP_cc) +# define COMPILER_ID "HP" + /* __HP_cc = VVRRPP */ +# define COMPILER_VERSION_MAJOR DEC(__HP_cc/10000) +# define COMPILER_VERSION_MINOR DEC(__HP_cc/100 % 100) +# define COMPILER_VERSION_PATCH DEC(__HP_cc % 100) + +#elif defined(__DECC) +# define COMPILER_ID "Compaq" + /* __DECC_VER = VVRRTPPPP */ +# define COMPILER_VERSION_MAJOR DEC(__DECC_VER/10000000) +# define COMPILER_VERSION_MINOR DEC(__DECC_VER/100000 % 100) +# define COMPILER_VERSION_PATCH DEC(__DECC_VER % 10000) + +#elif defined(__IBMC__) && defined(__COMPILER_VER__) +# define COMPILER_ID "zOS" + /* __IBMC__ = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100) +# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10) +# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10) + +#elif defined(__ibmxl__) && defined(__clang__) +# define COMPILER_ID "XLClang" +# define COMPILER_VERSION_MAJOR DEC(__ibmxl_version__) +# define COMPILER_VERSION_MINOR DEC(__ibmxl_release__) +# define COMPILER_VERSION_PATCH DEC(__ibmxl_modification__) +# define COMPILER_VERSION_TWEAK DEC(__ibmxl_ptf_fix_level__) + + +#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ >= 800 +# define COMPILER_ID "XL" + /* __IBMC__ = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100) +# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10) +# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10) + +#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ < 800 +# define COMPILER_ID "VisualAge" + /* __IBMC__ = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100) +# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10) +# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10) + +#elif defined(__PGI) +# define COMPILER_ID "PGI" +# define COMPILER_VERSION_MAJOR DEC(__PGIC__) +# define COMPILER_VERSION_MINOR DEC(__PGIC_MINOR__) +# if defined(__PGIC_PATCHLEVEL__) +# define COMPILER_VERSION_PATCH DEC(__PGIC_PATCHLEVEL__) +# endif + +#elif defined(_CRAYC) +# define COMPILER_ID "Cray" +# define COMPILER_VERSION_MAJOR DEC(_RELEASE_MAJOR) +# define COMPILER_VERSION_MINOR DEC(_RELEASE_MINOR) + +#elif defined(__TI_COMPILER_VERSION__) +# define COMPILER_ID "TI" + /* __TI_COMPILER_VERSION__ = VVVRRRPPP */ +# define COMPILER_VERSION_MAJOR DEC(__TI_COMPILER_VERSION__/1000000) +# define COMPILER_VERSION_MINOR DEC(__TI_COMPILER_VERSION__/1000 % 1000) +# define COMPILER_VERSION_PATCH DEC(__TI_COMPILER_VERSION__ % 1000) + +#elif defined(__FUJITSU) || defined(__FCC_VERSION) || defined(__fcc_version) +# define COMPILER_ID "Fujitsu" + +#elif defined(__ghs__) +# define COMPILER_ID "GHS" +/* __GHS_VERSION_NUMBER = VVVVRP */ +# ifdef __GHS_VERSION_NUMBER +# define COMPILER_VERSION_MAJOR DEC(__GHS_VERSION_NUMBER / 100) +# define COMPILER_VERSION_MINOR DEC(__GHS_VERSION_NUMBER / 10 % 10) +# define COMPILER_VERSION_PATCH DEC(__GHS_VERSION_NUMBER % 10) +# endif + +#elif defined(__TINYC__) +# define COMPILER_ID "TinyCC" + +#elif defined(__BCC__) +# define COMPILER_ID "Bruce" + +#elif defined(__SCO_VERSION__) +# define COMPILER_ID "SCO" + +#elif defined(__ARMCC_VERSION) && !defined(__clang__) +# define COMPILER_ID "ARMCC" +#if __ARMCC_VERSION >= 1000000 + /* __ARMCC_VERSION = VRRPPPP */ + # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/1000000) + # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 100) + # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000) +#else + /* __ARMCC_VERSION = VRPPPP */ + # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/100000) + # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 10) + # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000) +#endif + + +#elif defined(__clang__) && defined(__apple_build_version__) +# define COMPILER_ID "AppleClang" +# if defined(_MSC_VER) +# define SIMULATE_ID "MSVC" +# endif +# define COMPILER_VERSION_MAJOR DEC(__clang_major__) +# define COMPILER_VERSION_MINOR DEC(__clang_minor__) +# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__) +# if defined(_MSC_VER) + /* _MSC_VER = VVRR */ +# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100) +# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100) +# endif +# define COMPILER_VERSION_TWEAK DEC(__apple_build_version__) + +#elif defined(__clang__) && defined(__ARMCOMPILER_VERSION) +# define COMPILER_ID "ARMClang" + # define COMPILER_VERSION_MAJOR DEC(__ARMCOMPILER_VERSION/1000000) + # define COMPILER_VERSION_MINOR DEC(__ARMCOMPILER_VERSION/10000 % 100) + # define COMPILER_VERSION_PATCH DEC(__ARMCOMPILER_VERSION % 10000) +# define COMPILER_VERSION_INTERNAL DEC(__ARMCOMPILER_VERSION) + +#elif defined(__clang__) +# define COMPILER_ID "Clang" +# if defined(_MSC_VER) +# define SIMULATE_ID "MSVC" +# endif +# define COMPILER_VERSION_MAJOR DEC(__clang_major__) +# define COMPILER_VERSION_MINOR DEC(__clang_minor__) +# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__) +# if defined(_MSC_VER) + /* _MSC_VER = VVRR */ +# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100) +# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100) +# endif + +#elif defined(__GNUC__) +# define COMPILER_ID "GNU" +# define COMPILER_VERSION_MAJOR DEC(__GNUC__) +# if defined(__GNUC_MINOR__) +# define COMPILER_VERSION_MINOR DEC(__GNUC_MINOR__) +# endif +# if defined(__GNUC_PATCHLEVEL__) +# define COMPILER_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__) +# endif + +#elif defined(_MSC_VER) +# define COMPILER_ID "MSVC" + /* _MSC_VER = VVRR */ +# define COMPILER_VERSION_MAJOR DEC(_MSC_VER / 100) +# define COMPILER_VERSION_MINOR DEC(_MSC_VER % 100) +# if defined(_MSC_FULL_VER) +# if _MSC_VER >= 1400 + /* _MSC_FULL_VER = VVRRPPPPP */ +# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 100000) +# else + /* _MSC_FULL_VER = VVRRPPPP */ +# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 10000) +# endif +# endif +# if defined(_MSC_BUILD) +# define COMPILER_VERSION_TWEAK DEC(_MSC_BUILD) +# endif + +#elif defined(__VISUALDSPVERSION__) || defined(__ADSPBLACKFIN__) || defined(__ADSPTS__) || defined(__ADSP21000__) +# define COMPILER_ID "ADSP" +#if defined(__VISUALDSPVERSION__) + /* __VISUALDSPVERSION__ = 0xVVRRPP00 */ +# define COMPILER_VERSION_MAJOR HEX(__VISUALDSPVERSION__>>24) +# define COMPILER_VERSION_MINOR HEX(__VISUALDSPVERSION__>>16 & 0xFF) +# define COMPILER_VERSION_PATCH HEX(__VISUALDSPVERSION__>>8 & 0xFF) +#endif + +#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC) +# define COMPILER_ID "IAR" +# if defined(__VER__) && defined(__ICCARM__) +# define COMPILER_VERSION_MAJOR DEC((__VER__) / 1000000) +# define COMPILER_VERSION_MINOR DEC(((__VER__) / 1000) % 1000) +# define COMPILER_VERSION_PATCH DEC((__VER__) % 1000) +# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__) +# elif defined(__VER__) && (defined(__ICCAVR__) || defined(__ICCRX__) || defined(__ICCRH850__) || defined(__ICCRL78__) || defined(__ICC430__) || defined(__ICCRISCV__) || defined(__ICCV850__) || defined(__ICC8051__)) +# define COMPILER_VERSION_MAJOR DEC((__VER__) / 100) +# define COMPILER_VERSION_MINOR DEC((__VER__) - (((__VER__) / 100)*100)) +# define COMPILER_VERSION_PATCH DEC(__SUBVERSION__) +# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__) +# endif + +#elif defined(__SDCC_VERSION_MAJOR) || defined(SDCC) +# define COMPILER_ID "SDCC" +# if defined(__SDCC_VERSION_MAJOR) +# define COMPILER_VERSION_MAJOR DEC(__SDCC_VERSION_MAJOR) +# define COMPILER_VERSION_MINOR DEC(__SDCC_VERSION_MINOR) +# define COMPILER_VERSION_PATCH DEC(__SDCC_VERSION_PATCH) +# else + /* SDCC = VRP */ +# define COMPILER_VERSION_MAJOR DEC(SDCC/100) +# define COMPILER_VERSION_MINOR DEC(SDCC/10 % 10) +# define COMPILER_VERSION_PATCH DEC(SDCC % 10) +# endif + + +/* These compilers are either not known or too old to define an + identification macro. Try to identify the platform and guess that + it is the native compiler. */ +#elif defined(__hpux) || defined(__hpua) +# define COMPILER_ID "HP" + +#else /* unknown compiler */ +# define COMPILER_ID "" +#endif + +/* Construct the string literal in pieces to prevent the source from + getting matched. Store it in a pointer rather than an array + because some compilers will just produce instructions to fill the + array rather than assigning a pointer to a static array. */ +char const* info_compiler = "INFO" ":" "compiler[" COMPILER_ID "]"; +#ifdef SIMULATE_ID +char const* info_simulate = "INFO" ":" "simulate[" SIMULATE_ID "]"; +#endif + +#ifdef __QNXNTO__ +char const* qnxnto = "INFO" ":" "qnxnto[]"; +#endif + +#if defined(__CRAYXE) || defined(__CRAYXC) +char const *info_cray = "INFO" ":" "compiler_wrapper[CrayPrgEnv]"; +#endif + +#define STRINGIFY_HELPER(X) #X +#define STRINGIFY(X) STRINGIFY_HELPER(X) + +/* Identify known platforms by name. */ +#if defined(__linux) || defined(__linux__) || defined(linux) +# define PLATFORM_ID "Linux" + +#elif defined(__CYGWIN__) +# define PLATFORM_ID "Cygwin" + +#elif defined(__MINGW32__) +# define PLATFORM_ID "MinGW" + +#elif defined(__APPLE__) +# define PLATFORM_ID "Darwin" + +#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32) +# define PLATFORM_ID "Windows" + +#elif defined(__FreeBSD__) || defined(__FreeBSD) +# define PLATFORM_ID "FreeBSD" + +#elif defined(__NetBSD__) || defined(__NetBSD) +# define PLATFORM_ID "NetBSD" + +#elif defined(__OpenBSD__) || defined(__OPENBSD) +# define PLATFORM_ID "OpenBSD" + +#elif defined(__sun) || defined(sun) +# define PLATFORM_ID "SunOS" + +#elif defined(_AIX) || defined(__AIX) || defined(__AIX__) || defined(__aix) || defined(__aix__) +# define PLATFORM_ID "AIX" + +#elif defined(__hpux) || defined(__hpux__) +# define PLATFORM_ID "HP-UX" + +#elif defined(__HAIKU__) +# define PLATFORM_ID "Haiku" + +#elif defined(__BeOS) || defined(__BEOS__) || defined(_BEOS) +# define PLATFORM_ID "BeOS" + +#elif defined(__QNX__) || defined(__QNXNTO__) +# define PLATFORM_ID "QNX" + +#elif defined(__tru64) || defined(_tru64) || defined(__TRU64__) +# define PLATFORM_ID "Tru64" + +#elif defined(__riscos) || defined(__riscos__) +# define PLATFORM_ID "RISCos" + +#elif defined(__sinix) || defined(__sinix__) || defined(__SINIX__) +# define PLATFORM_ID "SINIX" + +#elif defined(__UNIX_SV__) +# define PLATFORM_ID "UNIX_SV" + +#elif defined(__bsdos__) +# define PLATFORM_ID "BSDOS" + +#elif defined(_MPRAS) || defined(MPRAS) +# define PLATFORM_ID "MP-RAS" + +#elif defined(__osf) || defined(__osf__) +# define PLATFORM_ID "OSF1" + +#elif defined(_SCO_SV) || defined(SCO_SV) || defined(sco_sv) +# define PLATFORM_ID "SCO_SV" + +#elif defined(__ultrix) || defined(__ultrix__) || defined(_ULTRIX) +# define PLATFORM_ID "ULTRIX" + +#elif defined(__XENIX__) || defined(_XENIX) || defined(XENIX) +# define PLATFORM_ID "Xenix" + +#elif defined(__WATCOMC__) +# if defined(__LINUX__) +# define PLATFORM_ID "Linux" + +# elif defined(__DOS__) +# define PLATFORM_ID "DOS" + +# elif defined(__OS2__) +# define PLATFORM_ID "OS2" + +# elif defined(__WINDOWS__) +# define PLATFORM_ID "Windows3x" + +# else /* unknown platform */ +# define PLATFORM_ID +# endif + +#elif defined(__INTEGRITY) +# if defined(INT_178B) +# define PLATFORM_ID "Integrity178" + +# else /* regular Integrity */ +# define PLATFORM_ID "Integrity" +# endif + +#else /* unknown platform */ +# define PLATFORM_ID + +#endif + +/* For windows compilers MSVC and Intel we can determine + the architecture of the compiler being used. This is because + the compilers do not have flags that can change the architecture, + but rather depend on which compiler is being used +*/ +#if defined(_WIN32) && defined(_MSC_VER) +# if defined(_M_IA64) +# define ARCHITECTURE_ID "IA64" + +# elif defined(_M_X64) || defined(_M_AMD64) +# define ARCHITECTURE_ID "x64" + +# elif defined(_M_IX86) +# define ARCHITECTURE_ID "X86" + +# elif defined(_M_ARM64) +# define ARCHITECTURE_ID "ARM64" + +# elif defined(_M_ARM) +# if _M_ARM == 4 +# define ARCHITECTURE_ID "ARMV4I" +# elif _M_ARM == 5 +# define ARCHITECTURE_ID "ARMV5I" +# else +# define ARCHITECTURE_ID "ARMV" STRINGIFY(_M_ARM) +# endif + +# elif defined(_M_MIPS) +# define ARCHITECTURE_ID "MIPS" + +# elif defined(_M_SH) +# define ARCHITECTURE_ID "SHx" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif + +#elif defined(__WATCOMC__) +# if defined(_M_I86) +# define ARCHITECTURE_ID "I86" + +# elif defined(_M_IX86) +# define ARCHITECTURE_ID "X86" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif + +#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC) +# if defined(__ICCARM__) +# define ARCHITECTURE_ID "ARM" + +# elif defined(__ICCRX__) +# define ARCHITECTURE_ID "RX" + +# elif defined(__ICCRH850__) +# define ARCHITECTURE_ID "RH850" + +# elif defined(__ICCRL78__) +# define ARCHITECTURE_ID "RL78" + +# elif defined(__ICCRISCV__) +# define ARCHITECTURE_ID "RISCV" + +# elif defined(__ICCAVR__) +# define ARCHITECTURE_ID "AVR" + +# elif defined(__ICC430__) +# define ARCHITECTURE_ID "MSP430" + +# elif defined(__ICCV850__) +# define ARCHITECTURE_ID "V850" + +# elif defined(__ICC8051__) +# define ARCHITECTURE_ID "8051" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif + +#elif defined(__ghs__) +# if defined(__PPC64__) +# define ARCHITECTURE_ID "PPC64" + +# elif defined(__ppc__) +# define ARCHITECTURE_ID "PPC" + +# elif defined(__ARM__) +# define ARCHITECTURE_ID "ARM" + +# elif defined(__x86_64__) +# define ARCHITECTURE_ID "x64" + +# elif defined(__i386__) +# define ARCHITECTURE_ID "X86" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif +#else +# define ARCHITECTURE_ID +#endif + +/* Convert integer to decimal digit literals. */ +#define DEC(n) \ + ('0' + (((n) / 10000000)%10)), \ + ('0' + (((n) / 1000000)%10)), \ + ('0' + (((n) / 100000)%10)), \ + ('0' + (((n) / 10000)%10)), \ + ('0' + (((n) / 1000)%10)), \ + ('0' + (((n) / 100)%10)), \ + ('0' + (((n) / 10)%10)), \ + ('0' + ((n) % 10)) + +/* Convert integer to hex digit literals. */ +#define HEX(n) \ + ('0' + ((n)>>28 & 0xF)), \ + ('0' + ((n)>>24 & 0xF)), \ + ('0' + ((n)>>20 & 0xF)), \ + ('0' + ((n)>>16 & 0xF)), \ + ('0' + ((n)>>12 & 0xF)), \ + ('0' + ((n)>>8 & 0xF)), \ + ('0' + ((n)>>4 & 0xF)), \ + ('0' + ((n) & 0xF)) + +/* Construct a string literal encoding the version number components. */ +#ifdef COMPILER_VERSION_MAJOR +char const info_version[] = { + 'I', 'N', 'F', 'O', ':', + 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','[', + COMPILER_VERSION_MAJOR, +# ifdef COMPILER_VERSION_MINOR + '.', COMPILER_VERSION_MINOR, +# ifdef COMPILER_VERSION_PATCH + '.', COMPILER_VERSION_PATCH, +# ifdef COMPILER_VERSION_TWEAK + '.', COMPILER_VERSION_TWEAK, +# endif +# endif +# endif + ']','\0'}; +#endif + +/* Construct a string literal encoding the internal version number. */ +#ifdef COMPILER_VERSION_INTERNAL +char const info_version_internal[] = { + 'I', 'N', 'F', 'O', ':', + 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','_', + 'i','n','t','e','r','n','a','l','[', + COMPILER_VERSION_INTERNAL,']','\0'}; +#endif + +/* Construct a string literal encoding the version number components. */ +#ifdef SIMULATE_VERSION_MAJOR +char const info_simulate_version[] = { + 'I', 'N', 'F', 'O', ':', + 's','i','m','u','l','a','t','e','_','v','e','r','s','i','o','n','[', + SIMULATE_VERSION_MAJOR, +# ifdef SIMULATE_VERSION_MINOR + '.', SIMULATE_VERSION_MINOR, +# ifdef SIMULATE_VERSION_PATCH + '.', SIMULATE_VERSION_PATCH, +# ifdef SIMULATE_VERSION_TWEAK + '.', SIMULATE_VERSION_TWEAK, +# endif +# endif +# endif + ']','\0'}; +#endif + +/* Construct the string literal in pieces to prevent the source from + getting matched. Store it in a pointer rather than an array + because some compilers will just produce instructions to fill the + array rather than assigning a pointer to a static array. */ +char const* info_platform = "INFO" ":" "platform[" PLATFORM_ID "]"; +char const* info_arch = "INFO" ":" "arch[" ARCHITECTURE_ID "]"; + + + + +#if !defined(__STDC__) +# if (defined(_MSC_VER) && !defined(__clang__)) \ + || (defined(__ibmxl__) || defined(__IBMC__)) +# define C_DIALECT "90" +# else +# define C_DIALECT +# endif +#elif __STDC_VERSION__ >= 201000L +# define C_DIALECT "11" +#elif __STDC_VERSION__ >= 199901L +# define C_DIALECT "99" +#else +# define C_DIALECT "90" +#endif +const char* info_language_dialect_default = + "INFO" ":" "dialect_default[" C_DIALECT "]"; + +/*--------------------------------------------------------------------------*/ + +#ifdef ID_VOID_MAIN +void main() {} +#else +# if defined(__CLASSIC_C__) +int main(argc, argv) int argc; char *argv[]; +# else +int main(int argc, char* argv[]) +# endif +{ + int require = 0; + require += info_compiler[argc]; + require += info_platform[argc]; + require += info_arch[argc]; +#ifdef COMPILER_VERSION_MAJOR + require += info_version[argc]; +#endif +#ifdef COMPILER_VERSION_INTERNAL + require += info_version_internal[argc]; +#endif +#ifdef SIMULATE_ID + require += info_simulate[argc]; +#endif +#ifdef SIMULATE_VERSION_MAJOR + require += info_simulate_version[argc]; +#endif +#if defined(__CRAYXE) || defined(__CRAYXC) + require += info_cray[argc]; +#endif + require += info_language_dialect_default[argc]; + (void)argv; + return require; +} +#endif diff --git a/build/CMakeFiles/3.16.3/CompilerIdC/a.out b/build/CMakeFiles/3.16.3/CompilerIdC/a.out new file mode 100755 index 0000000000000000000000000000000000000000..46f1233d9a6b2e660d5d0c5fc3dbde0dfb7e863d GIT binary patch literal 16712 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 Ri&oaZ+NLB{yA)ha@h^*jkRt#9 literal 0 HcmV?d00001 diff --git a/build/CMakeFiles/3.16.3/CompilerIdCXX/CMakeCXXCompilerId.cpp b/build/CMakeFiles/3.16.3/CompilerIdCXX/CMakeCXXCompilerId.cpp new file mode 100644 index 0000000..69cfdba --- /dev/null +++ b/build/CMakeFiles/3.16.3/CompilerIdCXX/CMakeCXXCompilerId.cpp @@ -0,0 +1,660 @@ +/* This source file must have a .cpp extension so that all C++ compilers + recognize the extension without flags. Borland does not know .cxx for + example. */ +#ifndef __cplusplus +# error "A C compiler has been selected for C++." +#endif + + +/* Version number components: V=Version, R=Revision, P=Patch + Version date components: YYYY=Year, MM=Month, DD=Day */ + +#if defined(__COMO__) +# define COMPILER_ID "Comeau" + /* __COMO_VERSION__ = VRR */ +# define COMPILER_VERSION_MAJOR DEC(__COMO_VERSION__ / 100) +# define COMPILER_VERSION_MINOR DEC(__COMO_VERSION__ % 100) + +#elif defined(__INTEL_COMPILER) || defined(__ICC) +# define COMPILER_ID "Intel" +# if defined(_MSC_VER) +# define SIMULATE_ID "MSVC" +# endif +# if defined(__GNUC__) +# define SIMULATE_ID "GNU" +# endif + /* __INTEL_COMPILER = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER/100) +# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER/10 % 10) +# if defined(__INTEL_COMPILER_UPDATE) +# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER_UPDATE) +# else +# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER % 10) +# endif +# if defined(__INTEL_COMPILER_BUILD_DATE) + /* __INTEL_COMPILER_BUILD_DATE = YYYYMMDD */ +# define COMPILER_VERSION_TWEAK DEC(__INTEL_COMPILER_BUILD_DATE) +# endif +# if defined(_MSC_VER) + /* _MSC_VER = VVRR */ +# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100) +# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100) +# endif +# if defined(__GNUC__) +# define SIMULATE_VERSION_MAJOR DEC(__GNUC__) +# elif defined(__GNUG__) +# define SIMULATE_VERSION_MAJOR DEC(__GNUG__) +# endif +# if defined(__GNUC_MINOR__) +# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__) +# endif +# if defined(__GNUC_PATCHLEVEL__) +# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__) +# endif + +#elif defined(__PATHCC__) +# define COMPILER_ID "PathScale" +# define COMPILER_VERSION_MAJOR DEC(__PATHCC__) +# define COMPILER_VERSION_MINOR DEC(__PATHCC_MINOR__) +# if defined(__PATHCC_PATCHLEVEL__) +# define COMPILER_VERSION_PATCH DEC(__PATHCC_PATCHLEVEL__) +# endif + +#elif defined(__BORLANDC__) && defined(__CODEGEARC_VERSION__) +# define COMPILER_ID "Embarcadero" +# define COMPILER_VERSION_MAJOR HEX(__CODEGEARC_VERSION__>>24 & 0x00FF) +# define COMPILER_VERSION_MINOR HEX(__CODEGEARC_VERSION__>>16 & 0x00FF) +# define COMPILER_VERSION_PATCH DEC(__CODEGEARC_VERSION__ & 0xFFFF) + +#elif defined(__BORLANDC__) +# define COMPILER_ID "Borland" + /* __BORLANDC__ = 0xVRR */ +# define COMPILER_VERSION_MAJOR HEX(__BORLANDC__>>8) +# define COMPILER_VERSION_MINOR HEX(__BORLANDC__ & 0xFF) + +#elif defined(__WATCOMC__) && __WATCOMC__ < 1200 +# define COMPILER_ID "Watcom" + /* __WATCOMC__ = VVRR */ +# define COMPILER_VERSION_MAJOR DEC(__WATCOMC__ / 100) +# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10) +# if (__WATCOMC__ % 10) > 0 +# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10) +# endif + +#elif defined(__WATCOMC__) +# define COMPILER_ID "OpenWatcom" + /* __WATCOMC__ = VVRP + 1100 */ +# define COMPILER_VERSION_MAJOR DEC((__WATCOMC__ - 1100) / 100) +# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10) +# if (__WATCOMC__ % 10) > 0 +# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10) +# endif + +#elif defined(__SUNPRO_CC) +# define COMPILER_ID "SunPro" +# if __SUNPRO_CC >= 0x5100 + /* __SUNPRO_CC = 0xVRRP */ +# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_CC>>12) +# define COMPILER_VERSION_MINOR HEX(__SUNPRO_CC>>4 & 0xFF) +# define COMPILER_VERSION_PATCH HEX(__SUNPRO_CC & 0xF) +# else + /* __SUNPRO_CC = 0xVRP */ +# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_CC>>8) +# define COMPILER_VERSION_MINOR HEX(__SUNPRO_CC>>4 & 0xF) +# define COMPILER_VERSION_PATCH HEX(__SUNPRO_CC & 0xF) +# endif + +#elif defined(__HP_aCC) +# define COMPILER_ID "HP" + /* __HP_aCC = VVRRPP */ +# define COMPILER_VERSION_MAJOR DEC(__HP_aCC/10000) +# define COMPILER_VERSION_MINOR DEC(__HP_aCC/100 % 100) +# define COMPILER_VERSION_PATCH DEC(__HP_aCC % 100) + +#elif defined(__DECCXX) +# define COMPILER_ID "Compaq" + /* __DECCXX_VER = VVRRTPPPP */ +# define COMPILER_VERSION_MAJOR DEC(__DECCXX_VER/10000000) +# define COMPILER_VERSION_MINOR DEC(__DECCXX_VER/100000 % 100) +# define COMPILER_VERSION_PATCH DEC(__DECCXX_VER % 10000) + +#elif defined(__IBMCPP__) && defined(__COMPILER_VER__) +# define COMPILER_ID "zOS" + /* __IBMCPP__ = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100) +# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10) +# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10) + +#elif defined(__ibmxl__) && defined(__clang__) +# define COMPILER_ID "XLClang" +# define COMPILER_VERSION_MAJOR DEC(__ibmxl_version__) +# define COMPILER_VERSION_MINOR DEC(__ibmxl_release__) +# define COMPILER_VERSION_PATCH DEC(__ibmxl_modification__) +# define COMPILER_VERSION_TWEAK DEC(__ibmxl_ptf_fix_level__) + + +#elif defined(__IBMCPP__) && !defined(__COMPILER_VER__) && __IBMCPP__ >= 800 +# define COMPILER_ID "XL" + /* __IBMCPP__ = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100) +# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10) +# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10) + +#elif defined(__IBMCPP__) && !defined(__COMPILER_VER__) && __IBMCPP__ < 800 +# define COMPILER_ID "VisualAge" + /* __IBMCPP__ = VRP */ +# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100) +# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10) +# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10) + +#elif defined(__PGI) +# define COMPILER_ID "PGI" +# define COMPILER_VERSION_MAJOR DEC(__PGIC__) +# define COMPILER_VERSION_MINOR DEC(__PGIC_MINOR__) +# if defined(__PGIC_PATCHLEVEL__) +# define COMPILER_VERSION_PATCH DEC(__PGIC_PATCHLEVEL__) +# endif + +#elif defined(_CRAYC) +# define COMPILER_ID "Cray" +# define COMPILER_VERSION_MAJOR DEC(_RELEASE_MAJOR) +# define COMPILER_VERSION_MINOR DEC(_RELEASE_MINOR) + +#elif defined(__TI_COMPILER_VERSION__) +# define COMPILER_ID "TI" + /* __TI_COMPILER_VERSION__ = VVVRRRPPP */ +# define COMPILER_VERSION_MAJOR DEC(__TI_COMPILER_VERSION__/1000000) +# define COMPILER_VERSION_MINOR DEC(__TI_COMPILER_VERSION__/1000 % 1000) +# define COMPILER_VERSION_PATCH DEC(__TI_COMPILER_VERSION__ % 1000) + +#elif defined(__FUJITSU) || defined(__FCC_VERSION) || defined(__fcc_version) +# define COMPILER_ID "Fujitsu" + +#elif defined(__ghs__) +# define COMPILER_ID "GHS" +/* __GHS_VERSION_NUMBER = VVVVRP */ +# ifdef __GHS_VERSION_NUMBER +# define COMPILER_VERSION_MAJOR DEC(__GHS_VERSION_NUMBER / 100) +# define COMPILER_VERSION_MINOR DEC(__GHS_VERSION_NUMBER / 10 % 10) +# define COMPILER_VERSION_PATCH DEC(__GHS_VERSION_NUMBER % 10) +# endif + +#elif defined(__SCO_VERSION__) +# define COMPILER_ID "SCO" + +#elif defined(__ARMCC_VERSION) && !defined(__clang__) +# define COMPILER_ID "ARMCC" +#if __ARMCC_VERSION >= 1000000 + /* __ARMCC_VERSION = VRRPPPP */ + # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/1000000) + # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 100) + # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000) +#else + /* __ARMCC_VERSION = VRPPPP */ + # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/100000) + # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 10) + # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000) +#endif + + +#elif defined(__clang__) && defined(__apple_build_version__) +# define COMPILER_ID "AppleClang" +# if defined(_MSC_VER) +# define SIMULATE_ID "MSVC" +# endif +# define COMPILER_VERSION_MAJOR DEC(__clang_major__) +# define COMPILER_VERSION_MINOR DEC(__clang_minor__) +# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__) +# if defined(_MSC_VER) + /* _MSC_VER = VVRR */ +# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100) +# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100) +# endif +# define COMPILER_VERSION_TWEAK DEC(__apple_build_version__) + +#elif defined(__clang__) && defined(__ARMCOMPILER_VERSION) +# define COMPILER_ID "ARMClang" + # define COMPILER_VERSION_MAJOR DEC(__ARMCOMPILER_VERSION/1000000) + # define COMPILER_VERSION_MINOR DEC(__ARMCOMPILER_VERSION/10000 % 100) + # define COMPILER_VERSION_PATCH DEC(__ARMCOMPILER_VERSION % 10000) +# define COMPILER_VERSION_INTERNAL DEC(__ARMCOMPILER_VERSION) + +#elif defined(__clang__) +# define COMPILER_ID "Clang" +# if defined(_MSC_VER) +# define SIMULATE_ID "MSVC" +# endif +# define COMPILER_VERSION_MAJOR DEC(__clang_major__) +# define COMPILER_VERSION_MINOR DEC(__clang_minor__) +# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__) +# if defined(_MSC_VER) + /* _MSC_VER = VVRR */ +# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100) +# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100) +# endif + +#elif defined(__GNUC__) || defined(__GNUG__) +# define COMPILER_ID "GNU" +# if defined(__GNUC__) +# define COMPILER_VERSION_MAJOR DEC(__GNUC__) +# else +# define COMPILER_VERSION_MAJOR DEC(__GNUG__) +# endif +# if defined(__GNUC_MINOR__) +# define COMPILER_VERSION_MINOR DEC(__GNUC_MINOR__) +# endif +# if defined(__GNUC_PATCHLEVEL__) +# define COMPILER_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__) +# endif + +#elif defined(_MSC_VER) +# define COMPILER_ID "MSVC" + /* _MSC_VER = VVRR */ +# define COMPILER_VERSION_MAJOR DEC(_MSC_VER / 100) +# define COMPILER_VERSION_MINOR DEC(_MSC_VER % 100) +# if defined(_MSC_FULL_VER) +# if _MSC_VER >= 1400 + /* _MSC_FULL_VER = VVRRPPPPP */ +# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 100000) +# else + /* _MSC_FULL_VER = VVRRPPPP */ +# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 10000) +# endif +# endif +# if defined(_MSC_BUILD) +# define COMPILER_VERSION_TWEAK DEC(_MSC_BUILD) +# endif + +#elif defined(__VISUALDSPVERSION__) || defined(__ADSPBLACKFIN__) || defined(__ADSPTS__) || defined(__ADSP21000__) +# define COMPILER_ID "ADSP" +#if defined(__VISUALDSPVERSION__) + /* __VISUALDSPVERSION__ = 0xVVRRPP00 */ +# define COMPILER_VERSION_MAJOR HEX(__VISUALDSPVERSION__>>24) +# define COMPILER_VERSION_MINOR HEX(__VISUALDSPVERSION__>>16 & 0xFF) +# define COMPILER_VERSION_PATCH HEX(__VISUALDSPVERSION__>>8 & 0xFF) +#endif + +#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC) +# define COMPILER_ID "IAR" +# if defined(__VER__) && defined(__ICCARM__) +# define COMPILER_VERSION_MAJOR DEC((__VER__) / 1000000) +# define COMPILER_VERSION_MINOR DEC(((__VER__) / 1000) % 1000) +# define COMPILER_VERSION_PATCH DEC((__VER__) % 1000) +# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__) +# elif defined(__VER__) && (defined(__ICCAVR__) || defined(__ICCRX__) || defined(__ICCRH850__) || defined(__ICCRL78__) || defined(__ICC430__) || defined(__ICCRISCV__) || defined(__ICCV850__) || defined(__ICC8051__)) +# define COMPILER_VERSION_MAJOR DEC((__VER__) / 100) +# define COMPILER_VERSION_MINOR DEC((__VER__) - (((__VER__) / 100)*100)) +# define COMPILER_VERSION_PATCH DEC(__SUBVERSION__) +# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__) +# endif + + +/* These compilers are either not known or too old to define an + identification macro. Try to identify the platform and guess that + it is the native compiler. */ +#elif defined(__hpux) || defined(__hpua) +# define COMPILER_ID "HP" + +#else /* unknown compiler */ +# define COMPILER_ID "" +#endif + +/* Construct the string literal in pieces to prevent the source from + getting matched. Store it in a pointer rather than an array + because some compilers will just produce instructions to fill the + array rather than assigning a pointer to a static array. */ +char const* info_compiler = "INFO" ":" "compiler[" COMPILER_ID "]"; +#ifdef SIMULATE_ID +char const* info_simulate = "INFO" ":" "simulate[" SIMULATE_ID "]"; +#endif + +#ifdef __QNXNTO__ +char const* qnxnto = "INFO" ":" "qnxnto[]"; +#endif + +#if defined(__CRAYXE) || defined(__CRAYXC) +char const *info_cray = "INFO" ":" "compiler_wrapper[CrayPrgEnv]"; +#endif + +#define STRINGIFY_HELPER(X) #X +#define STRINGIFY(X) STRINGIFY_HELPER(X) + +/* Identify known platforms by name. */ +#if defined(__linux) || defined(__linux__) || defined(linux) +# define PLATFORM_ID "Linux" + +#elif defined(__CYGWIN__) +# define PLATFORM_ID "Cygwin" + +#elif defined(__MINGW32__) +# define PLATFORM_ID "MinGW" + +#elif defined(__APPLE__) +# define PLATFORM_ID "Darwin" + +#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32) +# define PLATFORM_ID "Windows" + +#elif defined(__FreeBSD__) || defined(__FreeBSD) +# define PLATFORM_ID "FreeBSD" + +#elif defined(__NetBSD__) || defined(__NetBSD) +# define PLATFORM_ID "NetBSD" + +#elif defined(__OpenBSD__) || defined(__OPENBSD) +# define PLATFORM_ID "OpenBSD" + +#elif defined(__sun) || defined(sun) +# define PLATFORM_ID "SunOS" + +#elif defined(_AIX) || defined(__AIX) || defined(__AIX__) || defined(__aix) || defined(__aix__) +# define PLATFORM_ID "AIX" + +#elif defined(__hpux) || defined(__hpux__) +# define PLATFORM_ID "HP-UX" + +#elif defined(__HAIKU__) +# define PLATFORM_ID "Haiku" + +#elif defined(__BeOS) || defined(__BEOS__) || defined(_BEOS) +# define PLATFORM_ID "BeOS" + +#elif defined(__QNX__) || defined(__QNXNTO__) +# define PLATFORM_ID "QNX" + +#elif defined(__tru64) || defined(_tru64) || defined(__TRU64__) +# define PLATFORM_ID "Tru64" + +#elif defined(__riscos) || defined(__riscos__) +# define PLATFORM_ID "RISCos" + +#elif defined(__sinix) || defined(__sinix__) || defined(__SINIX__) +# define PLATFORM_ID "SINIX" + +#elif defined(__UNIX_SV__) +# define PLATFORM_ID "UNIX_SV" + +#elif defined(__bsdos__) +# define PLATFORM_ID "BSDOS" + +#elif defined(_MPRAS) || defined(MPRAS) +# define PLATFORM_ID "MP-RAS" + +#elif defined(__osf) || defined(__osf__) +# define PLATFORM_ID "OSF1" + +#elif defined(_SCO_SV) || defined(SCO_SV) || defined(sco_sv) +# define PLATFORM_ID "SCO_SV" + +#elif defined(__ultrix) || defined(__ultrix__) || defined(_ULTRIX) +# define PLATFORM_ID "ULTRIX" + +#elif defined(__XENIX__) || defined(_XENIX) || defined(XENIX) +# define PLATFORM_ID "Xenix" + +#elif defined(__WATCOMC__) +# if defined(__LINUX__) +# define PLATFORM_ID "Linux" + +# elif defined(__DOS__) +# define PLATFORM_ID "DOS" + +# elif defined(__OS2__) +# define PLATFORM_ID "OS2" + +# elif defined(__WINDOWS__) +# define PLATFORM_ID "Windows3x" + +# else /* unknown platform */ +# define PLATFORM_ID +# endif + +#elif defined(__INTEGRITY) +# if defined(INT_178B) +# define PLATFORM_ID "Integrity178" + +# else /* regular Integrity */ +# define PLATFORM_ID "Integrity" +# endif + +#else /* unknown platform */ +# define PLATFORM_ID + +#endif + +/* For windows compilers MSVC and Intel we can determine + the architecture of the compiler being used. This is because + the compilers do not have flags that can change the architecture, + but rather depend on which compiler is being used +*/ +#if defined(_WIN32) && defined(_MSC_VER) +# if defined(_M_IA64) +# define ARCHITECTURE_ID "IA64" + +# elif defined(_M_X64) || defined(_M_AMD64) +# define ARCHITECTURE_ID "x64" + +# elif defined(_M_IX86) +# define ARCHITECTURE_ID "X86" + +# elif defined(_M_ARM64) +# define ARCHITECTURE_ID "ARM64" + +# elif defined(_M_ARM) +# if _M_ARM == 4 +# define ARCHITECTURE_ID "ARMV4I" +# elif _M_ARM == 5 +# define ARCHITECTURE_ID "ARMV5I" +# else +# define ARCHITECTURE_ID "ARMV" STRINGIFY(_M_ARM) +# endif + +# elif defined(_M_MIPS) +# define ARCHITECTURE_ID "MIPS" + +# elif defined(_M_SH) +# define ARCHITECTURE_ID "SHx" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif + +#elif defined(__WATCOMC__) +# if defined(_M_I86) +# define ARCHITECTURE_ID "I86" + +# elif defined(_M_IX86) +# define ARCHITECTURE_ID "X86" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif + +#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC) +# if defined(__ICCARM__) +# define ARCHITECTURE_ID "ARM" + +# elif defined(__ICCRX__) +# define ARCHITECTURE_ID "RX" + +# elif defined(__ICCRH850__) +# define ARCHITECTURE_ID "RH850" + +# elif defined(__ICCRL78__) +# define ARCHITECTURE_ID "RL78" + +# elif defined(__ICCRISCV__) +# define ARCHITECTURE_ID "RISCV" + +# elif defined(__ICCAVR__) +# define ARCHITECTURE_ID "AVR" + +# elif defined(__ICC430__) +# define ARCHITECTURE_ID "MSP430" + +# elif defined(__ICCV850__) +# define ARCHITECTURE_ID "V850" + +# elif defined(__ICC8051__) +# define ARCHITECTURE_ID "8051" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif + +#elif defined(__ghs__) +# if defined(__PPC64__) +# define ARCHITECTURE_ID "PPC64" + +# elif defined(__ppc__) +# define ARCHITECTURE_ID "PPC" + +# elif defined(__ARM__) +# define ARCHITECTURE_ID "ARM" + +# elif defined(__x86_64__) +# define ARCHITECTURE_ID "x64" + +# elif defined(__i386__) +# define ARCHITECTURE_ID "X86" + +# else /* unknown architecture */ +# define ARCHITECTURE_ID "" +# endif +#else +# define ARCHITECTURE_ID +#endif + +/* Convert integer to decimal digit literals. */ +#define DEC(n) \ + ('0' + (((n) / 10000000)%10)), \ + ('0' + (((n) / 1000000)%10)), \ + ('0' + (((n) / 100000)%10)), \ + ('0' + (((n) / 10000)%10)), \ + ('0' + (((n) / 1000)%10)), \ + ('0' + (((n) / 100)%10)), \ + ('0' + (((n) / 10)%10)), \ + ('0' + ((n) % 10)) + +/* Convert integer to hex digit literals. */ +#define HEX(n) \ + ('0' + ((n)>>28 & 0xF)), \ + ('0' + ((n)>>24 & 0xF)), \ + ('0' + ((n)>>20 & 0xF)), \ + ('0' + ((n)>>16 & 0xF)), \ + ('0' + ((n)>>12 & 0xF)), \ + ('0' + ((n)>>8 & 0xF)), \ + ('0' + ((n)>>4 & 0xF)), \ + ('0' + ((n) & 0xF)) + +/* Construct a string literal encoding the version number components. */ +#ifdef COMPILER_VERSION_MAJOR +char const info_version[] = { + 'I', 'N', 'F', 'O', ':', + 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','[', + COMPILER_VERSION_MAJOR, +# ifdef COMPILER_VERSION_MINOR + '.', COMPILER_VERSION_MINOR, +# ifdef COMPILER_VERSION_PATCH + '.', COMPILER_VERSION_PATCH, +# ifdef COMPILER_VERSION_TWEAK + '.', COMPILER_VERSION_TWEAK, +# endif +# endif +# endif + ']','\0'}; +#endif + +/* Construct a string literal encoding the internal version number. */ +#ifdef COMPILER_VERSION_INTERNAL +char const info_version_internal[] = { + 'I', 'N', 'F', 'O', ':', + 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','_', + 'i','n','t','e','r','n','a','l','[', + COMPILER_VERSION_INTERNAL,']','\0'}; +#endif + +/* Construct a string literal encoding the version number components. */ +#ifdef SIMULATE_VERSION_MAJOR +char const info_simulate_version[] = { + 'I', 'N', 'F', 'O', ':', + 's','i','m','u','l','a','t','e','_','v','e','r','s','i','o','n','[', + SIMULATE_VERSION_MAJOR, +# ifdef SIMULATE_VERSION_MINOR + '.', SIMULATE_VERSION_MINOR, +# ifdef SIMULATE_VERSION_PATCH + '.', SIMULATE_VERSION_PATCH, +# ifdef SIMULATE_VERSION_TWEAK + '.', SIMULATE_VERSION_TWEAK, +# endif +# endif +# endif + ']','\0'}; +#endif + +/* Construct the string literal in pieces to prevent the source from + getting matched. Store it in a pointer rather than an array + because some compilers will just produce instructions to fill the + array rather than assigning a pointer to a static array. */ +char const* info_platform = "INFO" ":" "platform[" PLATFORM_ID "]"; +char const* info_arch = "INFO" ":" "arch[" ARCHITECTURE_ID "]"; + + + + +#if defined(__INTEL_COMPILER) && defined(_MSVC_LANG) && _MSVC_LANG < 201403L +# if defined(__INTEL_CXX11_MODE__) +# if defined(__cpp_aggregate_nsdmi) +# define CXX_STD 201402L +# else +# define CXX_STD 201103L +# endif +# else +# define CXX_STD 199711L +# endif +#elif defined(_MSC_VER) && defined(_MSVC_LANG) +# define CXX_STD _MSVC_LANG +#else +# define CXX_STD __cplusplus +#endif + +const char* info_language_dialect_default = "INFO" ":" "dialect_default[" +#if CXX_STD > 201703L + "20" +#elif CXX_STD >= 201703L + "17" +#elif CXX_STD >= 201402L + "14" +#elif CXX_STD >= 201103L + "11" +#else + "98" +#endif +"]"; + +/*--------------------------------------------------------------------------*/ + +int main(int argc, char* argv[]) +{ + int require = 0; + require += info_compiler[argc]; + require += info_platform[argc]; +#ifdef COMPILER_VERSION_MAJOR + require += info_version[argc]; +#endif +#ifdef COMPILER_VERSION_INTERNAL + require += info_version_internal[argc]; +#endif +#ifdef SIMULATE_ID + require += info_simulate[argc]; +#endif +#ifdef SIMULATE_VERSION_MAJOR + require += info_simulate_version[argc]; +#endif +#if defined(__CRAYXE) || defined(__CRAYXC) + require += info_cray[argc]; +#endif + require += info_language_dialect_default[argc]; + (void)argv; + return require; +} diff --git a/build/CMakeFiles/3.16.3/CompilerIdCXX/a.out b/build/CMakeFiles/3.16.3/CompilerIdCXX/a.out new file mode 100755 index 0000000000000000000000000000000000000000..c8684265455284359fc556a1ef0b98aa7a612508 GIT binary patch literal 16720 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 literal 0 HcmV?d00001 diff --git a/build/CMakeFiles/CMakeDirectoryInformation.cmake b/build/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/CMakeFiles/CMakeOutput.log b/build/CMakeFiles/CMakeOutput.log new file mode 100644 index 0000000..f57593e --- /dev/null +++ b/build/CMakeFiles/CMakeOutput.log @@ -0,0 +1,478 @@ +The system is: Linux - 5.4.0-58-generic - x86_64 +Compiling the C compiler identification source file "CMakeCCompilerId.c" succeeded. +Compiler: /bin/x86_64-linux-gnu-gcc-9 +Build flags: +Id flags: + +The output was: +0 + + +Compilation of the C compiler identification source "CMakeCCompilerId.c" produced "a.out" + +The C compiler identification is GNU, found in "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/3.16.3/CompilerIdC/a.out" + +Compiling the CXX compiler identification source file "CMakeCXXCompilerId.cpp" succeeded. +Compiler: /bin/x86_64-linux-gnu-g++-9 +Build flags: +Id flags: + +The output was: +0 + + +Compilation of the CXX compiler identification source "CMakeCXXCompilerId.cpp" produced "a.out" + +The CXX compiler identification is GNU, found in "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/3.16.3/CompilerIdCXX/a.out" + +Determining if the C compiler works passed with the following output: +Change Dir: /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp + +Run Build Command(s):/usr/bin/make cmTC_c874e/fast && /usr/bin/make -f CMakeFiles/cmTC_c874e.dir/build.make CMakeFiles/cmTC_c874e.dir/build +make[1]: Entering directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' +Building C object CMakeFiles/cmTC_c874e.dir/testCCompiler.c.o +/bin/x86_64-linux-gnu-gcc-9 -o CMakeFiles/cmTC_c874e.dir/testCCompiler.c.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp/testCCompiler.c +Linking C executable cmTC_c874e +/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_c874e.dir/link.txt --verbose=1 +/bin/x86_64-linux-gnu-gcc-9 -rdynamic CMakeFiles/cmTC_c874e.dir/testCCompiler.c.o -o cmTC_c874e +make[1]: Leaving directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' + + + +Detecting C compiler ABI info compiled with the following output: +Change Dir: /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp + +Run Build Command(s):/usr/bin/make cmTC_4214e/fast && /usr/bin/make -f CMakeFiles/cmTC_4214e.dir/build.make CMakeFiles/cmTC_4214e.dir/build +make[1]: Entering directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' +Building C object CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o +/bin/x86_64-linux-gnu-gcc-9 -v -o CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -c /usr/share/cmake-3.16/Modules/CMakeCCompilerABI.c +Using built-in specs. +COLLECT_GCC=/bin/x86_64-linux-gnu-gcc-9 +OFFLOAD_TARGET_NAMES=nvptx-none:hsa +OFFLOAD_TARGET_DEFAULT=1 +Target: x86_64-linux-gnu +Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr,hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu +Thread model: posix +gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) +COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64' + /usr/lib/gcc/x86_64-linux-gnu/9/cc1 -quiet -v -imultiarch x86_64-linux-gnu /usr/share/cmake-3.16/Modules/CMakeCCompilerABI.c -quiet -dumpbase CMakeCCompilerABI.c -mtune=generic -march=x86-64 -auxbase-strip CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -version -fasynchronous-unwind-tables -fstack-protector-strong -Wformat -Wformat-security -fstack-clash-protection -fcf-protection -o /tmp/ccQOOU9q.s +GNU C17 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu) + compiled by GNU C version 9.3.0, GMP version 6.2.0, MPFR version 4.0.2, MPC version 1.1.0, isl version isl-0.22.1-GMP + +GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072 +ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu" +ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/include-fixed" +ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/../../../../x86_64-linux-gnu/include" +#include "..." search starts here: +#include <...> search starts here: + /usr/lib/gcc/x86_64-linux-gnu/9/include + /usr/local/include + /usr/include/x86_64-linux-gnu + /usr/include +End of search list. +GNU C17 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu) + compiled by GNU C version 9.3.0, GMP version 6.2.0, MPFR version 4.0.2, MPC version 1.1.0, isl version isl-0.22.1-GMP + +GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072 +Compiler executable checksum: bbf13931d8de1abe14040c9909cb6969 +COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64' + as -v --64 -o CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o /tmp/ccQOOU9q.s +GNU assembler version 2.34 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.34 +COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/ +LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/ +COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64' +Linking C executable cmTC_4214e +/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_4214e.dir/link.txt --verbose=1 +/bin/x86_64-linux-gnu-gcc-9 -v -rdynamic CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -o cmTC_4214e +Using built-in specs. +COLLECT_GCC=/bin/x86_64-linux-gnu-gcc-9 +COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper +OFFLOAD_TARGET_NAMES=nvptx-none:hsa +OFFLOAD_TARGET_DEFAULT=1 +Target: x86_64-linux-gnu +Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr,hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu +Thread model: posix +gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) +COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/ +LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/ +COLLECT_GCC_OPTIONS='-v' '-rdynamic' '-o' 'cmTC_4214e' '-mtune=generic' '-march=x86-64' + /usr/lib/gcc/x86_64-linux-gnu/9/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/9/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper -plugin-opt=-fresolution=/tmp/cccCf2KW.res -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -export-dynamic -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro -o cmTC_4214e /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/9/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/9 -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/9/../../.. CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -lgcc --push-state --as-needed -lgcc_s --pop-state -lc -lgcc --push-state --as-needed -lgcc_s --pop-state /usr/lib/gcc/x86_64-linux-gnu/9/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crtn.o +COLLECT_GCC_OPTIONS='-v' '-rdynamic' '-o' 'cmTC_4214e' '-mtune=generic' '-march=x86-64' +make[1]: Leaving directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' + + + +Parsed C implicit include dir info from above output: rv=done + found start of include info + found start of implicit include info + add: [/usr/lib/gcc/x86_64-linux-gnu/9/include] + add: [/usr/local/include] + add: [/usr/include/x86_64-linux-gnu] + add: [/usr/include] + end of search list found + collapse include dir [/usr/lib/gcc/x86_64-linux-gnu/9/include] ==> [/usr/lib/gcc/x86_64-linux-gnu/9/include] + collapse include dir [/usr/local/include] ==> [/usr/local/include] + collapse include dir [/usr/include/x86_64-linux-gnu] ==> [/usr/include/x86_64-linux-gnu] + collapse include dir [/usr/include] ==> [/usr/include] + implicit include dirs: [/usr/lib/gcc/x86_64-linux-gnu/9/include;/usr/local/include;/usr/include/x86_64-linux-gnu;/usr/include] + + +Parsed C implicit link information from above output: + link line regex: [^( *|.*[/\])(ld|CMAKE_LINK_STARTFILE-NOTFOUND|([^/\]+-)?ld|collect2)[^/\]*( |$)] + ignore line: [Change Dir: /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp] + ignore line: [] + ignore line: [Run Build Command(s):/usr/bin/make cmTC_4214e/fast && /usr/bin/make -f CMakeFiles/cmTC_4214e.dir/build.make CMakeFiles/cmTC_4214e.dir/build] + ignore line: [make[1]: Entering directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp'] + ignore line: [Building C object CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o] + ignore line: [/bin/x86_64-linux-gnu-gcc-9 -v -o CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -c /usr/share/cmake-3.16/Modules/CMakeCCompilerABI.c] + ignore line: [Using built-in specs.] + ignore line: [COLLECT_GCC=/bin/x86_64-linux-gnu-gcc-9] + ignore line: [OFFLOAD_TARGET_NAMES=nvptx-none:hsa] + ignore line: [OFFLOAD_TARGET_DEFAULT=1] + ignore line: [Target: x86_64-linux-gnu] + ignore line: [Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c ada c++ go brig d fortran objc obj-c++ gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32 m64 mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu] + ignore line: [Thread model: posix] + ignore line: [gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) ] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64'] + ignore line: [ /usr/lib/gcc/x86_64-linux-gnu/9/cc1 -quiet -v -imultiarch x86_64-linux-gnu /usr/share/cmake-3.16/Modules/CMakeCCompilerABI.c -quiet -dumpbase CMakeCCompilerABI.c -mtune=generic -march=x86-64 -auxbase-strip CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -version -fasynchronous-unwind-tables -fstack-protector-strong -Wformat -Wformat-security -fstack-clash-protection -fcf-protection -o /tmp/ccQOOU9q.s] + ignore line: [GNU C17 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu)] + ignore line: [ compiled by GNU C version 9.3.0 GMP version 6.2.0 MPFR version 4.0.2 MPC version 1.1.0 isl version isl-0.22.1-GMP] + ignore line: [] + ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072] + ignore line: [ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"] + ignore line: [ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/include-fixed"] + ignore line: [ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/../../../../x86_64-linux-gnu/include"] + ignore line: [#include "..." search starts here:] + ignore line: [#include <...> search starts here:] + ignore line: [ /usr/lib/gcc/x86_64-linux-gnu/9/include] + ignore line: [ /usr/local/include] + ignore line: [ /usr/include/x86_64-linux-gnu] + ignore line: [ /usr/include] + ignore line: [End of search list.] + ignore line: [GNU C17 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu)] + ignore line: [ compiled by GNU C version 9.3.0 GMP version 6.2.0 MPFR version 4.0.2 MPC version 1.1.0 isl version isl-0.22.1-GMP] + ignore line: [] + ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072] + ignore line: [Compiler executable checksum: bbf13931d8de1abe14040c9909cb6969] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64'] + ignore line: [ as -v --64 -o CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o /tmp/ccQOOU9q.s] + ignore line: [GNU assembler version 2.34 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.34] + ignore line: [COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/] + ignore line: [LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64'] + ignore line: [Linking C executable cmTC_4214e] + ignore line: [/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_4214e.dir/link.txt --verbose=1] + ignore line: [/bin/x86_64-linux-gnu-gcc-9 -v -rdynamic CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -o cmTC_4214e ] + ignore line: [Using built-in specs.] + ignore line: [COLLECT_GCC=/bin/x86_64-linux-gnu-gcc-9] + ignore line: [COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper] + ignore line: [OFFLOAD_TARGET_NAMES=nvptx-none:hsa] + ignore line: [OFFLOAD_TARGET_DEFAULT=1] + ignore line: [Target: x86_64-linux-gnu] + ignore line: [Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c ada c++ go brig d fortran objc obj-c++ gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32 m64 mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu] + ignore line: [Thread model: posix] + ignore line: [gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) ] + ignore line: [COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/] + ignore line: [LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-rdynamic' '-o' 'cmTC_4214e' '-mtune=generic' '-march=x86-64'] + link line: [ /usr/lib/gcc/x86_64-linux-gnu/9/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/9/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper -plugin-opt=-fresolution=/tmp/cccCf2KW.res -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -export-dynamic -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro -o cmTC_4214e /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/9/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/9 -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/9/../../.. CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o -lgcc --push-state --as-needed -lgcc_s --pop-state -lc -lgcc --push-state --as-needed -lgcc_s --pop-state /usr/lib/gcc/x86_64-linux-gnu/9/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crtn.o] + arg [/usr/lib/gcc/x86_64-linux-gnu/9/collect2] ==> ignore + arg [-plugin] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/liblto_plugin.so] ==> ignore + arg [-plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper] ==> ignore + arg [-plugin-opt=-fresolution=/tmp/cccCf2KW.res] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc_s] ==> ignore + arg [-plugin-opt=-pass-through=-lc] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc_s] ==> ignore + arg [--build-id] ==> ignore + arg [--eh-frame-hdr] ==> ignore + arg [-m] ==> ignore + arg [elf_x86_64] ==> ignore + arg [--hash-style=gnu] ==> ignore + arg [--as-needed] ==> ignore + arg [-export-dynamic] ==> ignore + arg [-dynamic-linker] ==> ignore + arg [/lib64/ld-linux-x86-64.so.2] ==> ignore + arg [-pie] ==> ignore + arg [-znow] ==> ignore + arg [-zrelro] ==> ignore + arg [-o] ==> ignore + arg [cmTC_4214e] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/Scrt1.o] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crti.o] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/crtbeginS.o] ==> ignore + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9] + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu] + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib] + arg [-L/lib/x86_64-linux-gnu] ==> dir [/lib/x86_64-linux-gnu] + arg [-L/lib/../lib] ==> dir [/lib/../lib] + arg [-L/usr/lib/x86_64-linux-gnu] ==> dir [/usr/lib/x86_64-linux-gnu] + arg [-L/usr/lib/../lib] ==> dir [/usr/lib/../lib] + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9/../../..] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../..] + arg [CMakeFiles/cmTC_4214e.dir/CMakeCCompilerABI.c.o] ==> ignore + arg [-lgcc] ==> lib [gcc] + arg [--push-state] ==> ignore + arg [--as-needed] ==> ignore + arg [-lgcc_s] ==> lib [gcc_s] + arg [--pop-state] ==> ignore + arg [-lc] ==> lib [c] + arg [-lgcc] ==> lib [gcc] + arg [--push-state] ==> ignore + arg [--as-needed] ==> ignore + arg [-lgcc_s] ==> lib [gcc_s] + arg [--pop-state] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/crtendS.o] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crtn.o] ==> ignore + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9] ==> [/usr/lib/gcc/x86_64-linux-gnu/9] + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu] ==> [/usr/lib/x86_64-linux-gnu] + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib] ==> [/usr/lib] + collapse library dir [/lib/x86_64-linux-gnu] ==> [/lib/x86_64-linux-gnu] + collapse library dir [/lib/../lib] ==> [/lib] + collapse library dir [/usr/lib/x86_64-linux-gnu] ==> [/usr/lib/x86_64-linux-gnu] + collapse library dir [/usr/lib/../lib] ==> [/usr/lib] + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../..] ==> [/usr/lib] + implicit libs: [gcc;gcc_s;c;gcc;gcc_s] + implicit dirs: [/usr/lib/gcc/x86_64-linux-gnu/9;/usr/lib/x86_64-linux-gnu;/usr/lib;/lib/x86_64-linux-gnu;/lib] + implicit fwks: [] + + +Determining if the CXX compiler works passed with the following output: +Change Dir: /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp + +Run Build Command(s):/usr/bin/make cmTC_2c9be/fast && /usr/bin/make -f CMakeFiles/cmTC_2c9be.dir/build.make CMakeFiles/cmTC_2c9be.dir/build +make[1]: Entering directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' +Building CXX object CMakeFiles/cmTC_2c9be.dir/testCXXCompiler.cxx.o +/bin/x86_64-linux-gnu-g++-9 -o CMakeFiles/cmTC_2c9be.dir/testCXXCompiler.cxx.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp/testCXXCompiler.cxx +Linking CXX executable cmTC_2c9be +/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_2c9be.dir/link.txt --verbose=1 +/bin/x86_64-linux-gnu-g++-9 -rdynamic CMakeFiles/cmTC_2c9be.dir/testCXXCompiler.cxx.o -o cmTC_2c9be +make[1]: Leaving directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' + + + +Detecting CXX compiler ABI info compiled with the following output: +Change Dir: /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp + +Run Build Command(s):/usr/bin/make cmTC_e9690/fast && /usr/bin/make -f CMakeFiles/cmTC_e9690.dir/build.make CMakeFiles/cmTC_e9690.dir/build +make[1]: Entering directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' +Building CXX object CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o +/bin/x86_64-linux-gnu-g++-9 -v -o CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -c /usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp +Using built-in specs. +COLLECT_GCC=/bin/x86_64-linux-gnu-g++-9 +OFFLOAD_TARGET_NAMES=nvptx-none:hsa +OFFLOAD_TARGET_DEFAULT=1 +Target: x86_64-linux-gnu +Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr,hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu +Thread model: posix +gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) +COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o' '-c' '-shared-libgcc' '-mtune=generic' '-march=x86-64' + /usr/lib/gcc/x86_64-linux-gnu/9/cc1plus -quiet -v -imultiarch x86_64-linux-gnu -D_GNU_SOURCE /usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp -quiet -dumpbase CMakeCXXCompilerABI.cpp -mtune=generic -march=x86-64 -auxbase-strip CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -version -fasynchronous-unwind-tables -fstack-protector-strong -Wformat -Wformat-security -fstack-clash-protection -fcf-protection -o /tmp/ccZrhU8r.s +GNU C++14 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu) + compiled by GNU C version 9.3.0, GMP version 6.2.0, MPFR version 4.0.2, MPC version 1.1.0, isl version isl-0.22.1-GMP + +GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072 +ignoring duplicate directory "/usr/include/x86_64-linux-gnu/c++/9" +ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu" +ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/include-fixed" +ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/../../../../x86_64-linux-gnu/include" +#include "..." search starts here: +#include <...> search starts here: + /usr/include/c++/9 + /usr/include/x86_64-linux-gnu/c++/9 + /usr/include/c++/9/backward + /usr/lib/gcc/x86_64-linux-gnu/9/include + /usr/local/include + /usr/include/x86_64-linux-gnu + /usr/include +End of search list. +GNU C++14 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu) + compiled by GNU C version 9.3.0, GMP version 6.2.0, MPFR version 4.0.2, MPC version 1.1.0, isl version isl-0.22.1-GMP + +GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072 +Compiler executable checksum: 466f818abe2f30ba03783f22bd12d815 +COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o' '-c' '-shared-libgcc' '-mtune=generic' '-march=x86-64' + as -v --64 -o CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o /tmp/ccZrhU8r.s +GNU assembler version 2.34 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.34 +COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/ +LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/ +COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o' '-c' '-shared-libgcc' '-mtune=generic' '-march=x86-64' +Linking CXX executable cmTC_e9690 +/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_e9690.dir/link.txt --verbose=1 +/bin/x86_64-linux-gnu-g++-9 -v -rdynamic CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -o cmTC_e9690 +Using built-in specs. +COLLECT_GCC=/bin/x86_64-linux-gnu-g++-9 +COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper +OFFLOAD_TARGET_NAMES=nvptx-none:hsa +OFFLOAD_TARGET_DEFAULT=1 +Target: x86_64-linux-gnu +Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr,hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu +Thread model: posix +gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) +COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/ +LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/ +COLLECT_GCC_OPTIONS='-v' '-rdynamic' '-o' 'cmTC_e9690' '-shared-libgcc' '-mtune=generic' '-march=x86-64' + /usr/lib/gcc/x86_64-linux-gnu/9/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/9/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper -plugin-opt=-fresolution=/tmp/ccnDWzmT.res -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -export-dynamic -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro -o cmTC_e9690 /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/9/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/9 -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/9/../../.. CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -lstdc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/gcc/x86_64-linux-gnu/9/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crtn.o +COLLECT_GCC_OPTIONS='-v' '-rdynamic' '-o' 'cmTC_e9690' '-shared-libgcc' '-mtune=generic' '-march=x86-64' +make[1]: Leaving directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' + + + +Parsed CXX implicit include dir info from above output: rv=done + found start of include info + found start of implicit include info + add: [/usr/include/c++/9] + add: [/usr/include/x86_64-linux-gnu/c++/9] + add: [/usr/include/c++/9/backward] + add: [/usr/lib/gcc/x86_64-linux-gnu/9/include] + add: [/usr/local/include] + add: [/usr/include/x86_64-linux-gnu] + add: [/usr/include] + end of search list found + collapse include dir [/usr/include/c++/9] ==> [/usr/include/c++/9] + collapse include dir [/usr/include/x86_64-linux-gnu/c++/9] ==> [/usr/include/x86_64-linux-gnu/c++/9] + collapse include dir [/usr/include/c++/9/backward] ==> [/usr/include/c++/9/backward] + collapse include dir [/usr/lib/gcc/x86_64-linux-gnu/9/include] ==> [/usr/lib/gcc/x86_64-linux-gnu/9/include] + collapse include dir [/usr/local/include] ==> [/usr/local/include] + collapse include dir [/usr/include/x86_64-linux-gnu] ==> [/usr/include/x86_64-linux-gnu] + collapse include dir [/usr/include] ==> [/usr/include] + implicit include dirs: [/usr/include/c++/9;/usr/include/x86_64-linux-gnu/c++/9;/usr/include/c++/9/backward;/usr/lib/gcc/x86_64-linux-gnu/9/include;/usr/local/include;/usr/include/x86_64-linux-gnu;/usr/include] + + +Parsed CXX implicit link information from above output: + link line regex: [^( *|.*[/\])(ld|CMAKE_LINK_STARTFILE-NOTFOUND|([^/\]+-)?ld|collect2)[^/\]*( |$)] + ignore line: [Change Dir: /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp] + ignore line: [] + ignore line: [Run Build Command(s):/usr/bin/make cmTC_e9690/fast && /usr/bin/make -f CMakeFiles/cmTC_e9690.dir/build.make CMakeFiles/cmTC_e9690.dir/build] + ignore line: [make[1]: Entering directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp'] + ignore line: [Building CXX object CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o] + ignore line: [/bin/x86_64-linux-gnu-g++-9 -v -o CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -c /usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp] + ignore line: [Using built-in specs.] + ignore line: [COLLECT_GCC=/bin/x86_64-linux-gnu-g++-9] + ignore line: [OFFLOAD_TARGET_NAMES=nvptx-none:hsa] + ignore line: [OFFLOAD_TARGET_DEFAULT=1] + ignore line: [Target: x86_64-linux-gnu] + ignore line: [Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c ada c++ go brig d fortran objc obj-c++ gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32 m64 mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu] + ignore line: [Thread model: posix] + ignore line: [gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) ] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o' '-c' '-shared-libgcc' '-mtune=generic' '-march=x86-64'] + ignore line: [ /usr/lib/gcc/x86_64-linux-gnu/9/cc1plus -quiet -v -imultiarch x86_64-linux-gnu -D_GNU_SOURCE /usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp -quiet -dumpbase CMakeCXXCompilerABI.cpp -mtune=generic -march=x86-64 -auxbase-strip CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -version -fasynchronous-unwind-tables -fstack-protector-strong -Wformat -Wformat-security -fstack-clash-protection -fcf-protection -o /tmp/ccZrhU8r.s] + ignore line: [GNU C++14 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu)] + ignore line: [ compiled by GNU C version 9.3.0 GMP version 6.2.0 MPFR version 4.0.2 MPC version 1.1.0 isl version isl-0.22.1-GMP] + ignore line: [] + ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072] + ignore line: [ignoring duplicate directory "/usr/include/x86_64-linux-gnu/c++/9"] + ignore line: [ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"] + ignore line: [ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/include-fixed"] + ignore line: [ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/9/../../../../x86_64-linux-gnu/include"] + ignore line: [#include "..." search starts here:] + ignore line: [#include <...> search starts here:] + ignore line: [ /usr/include/c++/9] + ignore line: [ /usr/include/x86_64-linux-gnu/c++/9] + ignore line: [ /usr/include/c++/9/backward] + ignore line: [ /usr/lib/gcc/x86_64-linux-gnu/9/include] + ignore line: [ /usr/local/include] + ignore line: [ /usr/include/x86_64-linux-gnu] + ignore line: [ /usr/include] + ignore line: [End of search list.] + ignore line: [GNU C++14 (Ubuntu 9.3.0-17ubuntu1~20.04) version 9.3.0 (x86_64-linux-gnu)] + ignore line: [ compiled by GNU C version 9.3.0 GMP version 6.2.0 MPFR version 4.0.2 MPC version 1.1.0 isl version isl-0.22.1-GMP] + ignore line: [] + ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072] + ignore line: [Compiler executable checksum: 466f818abe2f30ba03783f22bd12d815] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o' '-c' '-shared-libgcc' '-mtune=generic' '-march=x86-64'] + ignore line: [ as -v --64 -o CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o /tmp/ccZrhU8r.s] + ignore line: [GNU assembler version 2.34 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.34] + ignore line: [COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/] + ignore line: [LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o' '-c' '-shared-libgcc' '-mtune=generic' '-march=x86-64'] + ignore line: [Linking CXX executable cmTC_e9690] + ignore line: [/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_e9690.dir/link.txt --verbose=1] + ignore line: [/bin/x86_64-linux-gnu-g++-9 -v -rdynamic CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -o cmTC_e9690 ] + ignore line: [Using built-in specs.] + ignore line: [COLLECT_GCC=/bin/x86_64-linux-gnu-g++-9] + ignore line: [COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper] + ignore line: [OFFLOAD_TARGET_NAMES=nvptx-none:hsa] + ignore line: [OFFLOAD_TARGET_DEFAULT=1] + ignore line: [Target: x86_64-linux-gnu] + ignore line: [Configured with: ../src/configure -v --with-pkgversion='Ubuntu 9.3.0-17ubuntu1~20.04' --with-bugurl=file:///usr/share/doc/gcc-9/README.Bugs --enable-languages=c ada c++ go brig d fortran objc obj-c++ gm2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-9 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32 m64 mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-9-HskZEa/gcc-9-9.3.0/debian/tmp-nvptx/usr hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu] + ignore line: [Thread model: posix] + ignore line: [gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04) ] + ignore line: [COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/] + ignore line: [LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/9/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/9/../../../:/lib/:/usr/lib/] + ignore line: [COLLECT_GCC_OPTIONS='-v' '-rdynamic' '-o' 'cmTC_e9690' '-shared-libgcc' '-mtune=generic' '-march=x86-64'] + link line: [ /usr/lib/gcc/x86_64-linux-gnu/9/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/9/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper -plugin-opt=-fresolution=/tmp/ccnDWzmT.res -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -export-dynamic -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro -o cmTC_e9690 /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/9/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/9 -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/9/../../.. CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o -lstdc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/gcc/x86_64-linux-gnu/9/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crtn.o] + arg [/usr/lib/gcc/x86_64-linux-gnu/9/collect2] ==> ignore + arg [-plugin] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/liblto_plugin.so] ==> ignore + arg [-plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/9/lto-wrapper] ==> ignore + arg [-plugin-opt=-fresolution=/tmp/ccnDWzmT.res] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc_s] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc] ==> ignore + arg [-plugin-opt=-pass-through=-lc] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc_s] ==> ignore + arg [-plugin-opt=-pass-through=-lgcc] ==> ignore + arg [--build-id] ==> ignore + arg [--eh-frame-hdr] ==> ignore + arg [-m] ==> ignore + arg [elf_x86_64] ==> ignore + arg [--hash-style=gnu] ==> ignore + arg [--as-needed] ==> ignore + arg [-export-dynamic] ==> ignore + arg [-dynamic-linker] ==> ignore + arg [/lib64/ld-linux-x86-64.so.2] ==> ignore + arg [-pie] ==> ignore + arg [-znow] ==> ignore + arg [-zrelro] ==> ignore + arg [-o] ==> ignore + arg [cmTC_e9690] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/Scrt1.o] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crti.o] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/crtbeginS.o] ==> ignore + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9] + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu] + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib] + arg [-L/lib/x86_64-linux-gnu] ==> dir [/lib/x86_64-linux-gnu] + arg [-L/lib/../lib] ==> dir [/lib/../lib] + arg [-L/usr/lib/x86_64-linux-gnu] ==> dir [/usr/lib/x86_64-linux-gnu] + arg [-L/usr/lib/../lib] ==> dir [/usr/lib/../lib] + arg [-L/usr/lib/gcc/x86_64-linux-gnu/9/../../..] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../..] + arg [CMakeFiles/cmTC_e9690.dir/CMakeCXXCompilerABI.cpp.o] ==> ignore + arg [-lstdc++] ==> lib [stdc++] + arg [-lm] ==> lib [m] + arg [-lgcc_s] ==> lib [gcc_s] + arg [-lgcc] ==> lib [gcc] + arg [-lc] ==> lib [c] + arg [-lgcc_s] ==> lib [gcc_s] + arg [-lgcc] ==> lib [gcc] + arg [/usr/lib/gcc/x86_64-linux-gnu/9/crtendS.o] ==> ignore + arg [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu/crtn.o] ==> ignore + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9] ==> [/usr/lib/gcc/x86_64-linux-gnu/9] + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../x86_64-linux-gnu] ==> [/usr/lib/x86_64-linux-gnu] + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../../../lib] ==> [/usr/lib] + collapse library dir [/lib/x86_64-linux-gnu] ==> [/lib/x86_64-linux-gnu] + collapse library dir [/lib/../lib] ==> [/lib] + collapse library dir [/usr/lib/x86_64-linux-gnu] ==> [/usr/lib/x86_64-linux-gnu] + collapse library dir [/usr/lib/../lib] ==> [/usr/lib] + collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/9/../../..] ==> [/usr/lib] + implicit libs: [stdc++;m;gcc_s;gcc;c;gcc_s;gcc] + implicit dirs: [/usr/lib/gcc/x86_64-linux-gnu/9;/usr/lib/x86_64-linux-gnu;/usr/lib;/lib/x86_64-linux-gnu;/lib] + implicit fwks: [] + + +Performing C++ SOURCE FILE Test HAS_FLTO succeeded with the following output: +Change Dir: /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp + +Run Build Command(s):/usr/bin/make cmTC_0782e/fast && /usr/bin/make -f CMakeFiles/cmTC_0782e.dir/build.make CMakeFiles/cmTC_0782e.dir/build +make[1]: Entering directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' +Building CXX object CMakeFiles/cmTC_0782e.dir/src.cxx.o +/bin/x86_64-linux-gnu-g++-9 -Wall -Wextra -pedantic -DHAS_FLTO -flto -fno-fat-lto-objects -std=c++14 -o CMakeFiles/cmTC_0782e.dir/src.cxx.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp/src.cxx +Linking CXX executable cmTC_0782e +/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_0782e.dir/link.txt --verbose=1 +/bin/x86_64-linux-gnu-g++-9 -Wall -Wextra -pedantic -DHAS_FLTO CMakeFiles/cmTC_0782e.dir/src.cxx.o -o cmTC_0782e -flto +make[1]: Leaving directory '/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/CMakeTmp' + + +Source file was: +int main() { return 0; } diff --git a/build/CMakeFiles/CMakeRuleHashes.txt b/build/CMakeFiles/CMakeRuleHashes.txt new file mode 100644 index 0000000..f2a8670 --- /dev/null +++ b/build/CMakeFiles/CMakeRuleHashes.txt @@ -0,0 +1,34 @@ +# Hashes of file build rules. +74ed1c0ee6e6e1ebec79277f78c3965a CMakeFiles/albert-bin_autogen +26ef5a7e33ad8ad41b427f7356cc0634 CMakeFiles/albert-lib_autogen +c607f57dd0e79193626abed7435db8ed albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp +e9ff4fd033ae775231cd109000d3c512 lib/globalshortcut/CMakeFiles/globalshortcut_autogen +9d09bae668c2435225c3d1959c003414 lib/xdg/CMakeFiles/xdg_autogen +9d6e68c759432781bea9dca82fd1abd3 plugins/applications/CMakeFiles/applications_autogen +aa22231014a3a6943d4b5be34096779a plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp +37f3d51a498b28ce7808ba293f611646 plugins/calculator/CMakeFiles/calculator_autogen +e2f0284c7a73d099dd6b939ec0db1251 plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp +7e50caba996bf857ab0ddd866c8267a1 plugins/chromium/CMakeFiles/chromium_autogen +f8d5f98339df294f2a3b440c83096fe8 plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp +d52ffb1505bb0b4be783d57f9c70431a plugins/files/CMakeFiles/files_autogen +ef54ed2302502253d68461163f50425d plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp +afb5c60239a5f29e9a0fcf55e01b8359 plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen +9340a5c938b03861a1444844d06a5eb1 plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp +54417aefb5de019727d2a55f63f93ed2 plugins/hashgenerator/CMakeFiles/hashgenerator_autogen +ed448b4f1a8f01906ebbe70a851f7fec plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp +0beca63c4dee83f1b881f79ab0be6629 plugins/mpris/CMakeFiles/mpris_autogen +55baecf57e79613f03aed833df8b120f plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp +7511fe7c7f58a220af1be129c5181ee9 plugins/python/CMakeFiles/python_autogen +ba580e124339ee4b1a027a435d89f5c4 plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp +95d5969f7e044fa4cf2b2d68f3eb0eb0 plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen +5b7ddcbe73bb097c27b79e61f3b7d37c plugins/snippets/CMakeFiles/snippets_autogen +1a94390b664c92c00a6411c1c18d4885 plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp +502ec1c5e47d1bf5a2a540bad57dffa3 plugins/ssh/CMakeFiles/ssh_autogen +9ebed01652d3fc86ec7c1fb1e013f796 plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp +d5c7c90a4f5260f9e4972b53c86a7c1f plugins/system/CMakeFiles/system_autogen +36c2763a532d19f11afa87ac54a26bf1 plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp +4ab13024c364b0ddfa7c7227d48a8d7b plugins/terminal/CMakeFiles/terminal_autogen +5f400be5d253ff211ea4553e45b6491f plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp +15a7cd8f0ef3616cc42df5f5a49baaa7 plugins/websearch/CMakeFiles/websearch_autogen +ab5b73c9137af0384ba866093891e0e3 plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp +44fc3aa607eda9ba383e5cd7c5bf0798 plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen diff --git a/build/CMakeFiles/Makefile.cmake b/build/CMakeFiles/Makefile.cmake new file mode 100644 index 0000000..17780c5 --- /dev/null +++ b/build/CMakeFiles/Makefile.cmake @@ -0,0 +1,231 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# The generator used is: +set(CMAKE_DEPENDS_GENERATOR "Unix Makefiles") + +# The top level Makefile was generated from the following files: +set(CMAKE_MAKEFILE_DEPENDS + "CMakeCache.txt" + "../CMakeLists.txt" + "CMakeFiles/3.16.3/CMakeCCompiler.cmake" + "CMakeFiles/3.16.3/CMakeCXXCompiler.cmake" + "CMakeFiles/3.16.3/CMakeSystem.cmake" + "../lib/globalshortcut/CMakeLists.txt" + "../lib/xdg/CMakeLists.txt" + "../plugins/CMakeLists.txt" + "../plugins/applications/CMakeLists.txt" + "../plugins/applications/applications.qrc" + "../plugins/calculator/CMakeLists.txt" + "../plugins/calculator/calculator.qrc" + "../plugins/chromium/CMakeLists.txt" + "../plugins/chromium/chromium.qrc" + "../plugins/files/CMakeLists.txt" + "../plugins/files/files.qrc" + "../plugins/firefoxbookmarks/CMakeLists.txt" + "../plugins/firefoxbookmarks/firefoxbookmarks.qrc" + "../plugins/hashgenerator/CMakeLists.txt" + "../plugins/hashgenerator/hashgenerator.qrc" + "../plugins/mpris/CMakeLists.txt" + "../plugins/mpris/mpris.qrc" + "../plugins/python/CMakeLists.txt" + "../plugins/python/pybind11/CMakeLists.txt" + "../plugins/python/pybind11/tools/FindPythonLibsNew.cmake" + "../plugins/python/pybind11/tools/pybind11Common.cmake" + "../plugins/python/pybind11/tools/pybind11Tools.cmake" + "../plugins/python/python.qrc" + "../plugins/qmlboxmodel/CMakeLists.txt" + "../plugins/snippets/CMakeLists.txt" + "../plugins/snippets/snippets.qrc" + "../plugins/ssh/CMakeLists.txt" + "../plugins/ssh/ssh.qrc" + "../plugins/system/CMakeLists.txt" + "../plugins/system/system.qrc" + "../plugins/terminal/CMakeLists.txt" + "../plugins/terminal/terminal.qrc" + "../plugins/websearch/CMakeLists.txt" + "../plugins/websearch/websearch.qrc" + "../plugins/widgetboxmodel/CMakeLists.txt" + "../resources.qrc" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5/Qt5Config.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5/Qt5ConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5/Qt5ModuleLocation.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Charts/Qt5ChartsConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Charts/Qt5ChartsConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Concurrent/Qt5ConcurrentConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Concurrent/Qt5ConcurrentConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Core/Qt5CoreConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Core/Qt5CoreConfigExtras.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Core/Qt5CoreConfigExtrasMkspecDir.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Core/Qt5CoreConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Core/Qt5CoreMacros.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5DBus/Qt5DBusConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5DBus/Qt5DBusConfigExtras.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5DBus/Qt5DBusConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5DBus/Qt5DBusMacros.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5GuiConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5GuiConfigExtras.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5GuiConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QComposePlatformInputContextPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEglFSEmulatorIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEglFSIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEglFSKmsEglDeviceIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEglFSKmsGbmIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEglFSX11IntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEvdevKeyboardPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEvdevMousePlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEvdevTabletPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QEvdevTouchScreenPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QGifPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QICOPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QIbusPlatformInputContextPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QJpegPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QLibInputPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QLinuxFbIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QMinimalEglIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QMinimalIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QOffscreenIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QTuioTouchPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QVncIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QXcbEglIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QXcbGlxIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Gui/Qt5Gui_QXcbIntegrationPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Network/Qt5NetworkConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Network/Qt5NetworkConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Network/Qt5Network_QConnmanEnginePlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Network/Qt5Network_QGenericEnginePlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Network/Qt5Network_QNetworkManagerEnginePlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5QmlConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5QmlConfigExtras.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5QmlConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QDebugMessageServiceFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QLocalClientConnectionFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQmlDebugServerFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQmlDebuggerServiceFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQmlInspectorServiceFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQmlNativeDebugConnectorFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQmlNativeDebugServiceFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQmlPreviewServiceFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQmlProfilerServiceFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QQuickProfilerAdapterFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Qml/Qt5Qml_QTcpServerConnectionFactory.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Quick/Qt5QuickConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Quick/Qt5QuickConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Sql/Qt5SqlConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Sql/Qt5SqlConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Svg/Qt5SvgConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Svg/Qt5SvgConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Svg/Qt5Svg_QSvgIconPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Svg/Qt5Svg_QSvgPlugin.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Widgets/Qt5WidgetsConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Widgets/Qt5WidgetsConfigExtras.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Widgets/Qt5WidgetsConfigVersion.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5Widgets/Qt5WidgetsMacros.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5X11Extras/Qt5X11ExtrasConfig.cmake" + "/usr/lib/x86_64-linux-gnu/cmake/Qt5X11Extras/Qt5X11ExtrasConfigVersion.cmake" + "/usr/share/cmake-3.16/Modules/CMakeCInformation.cmake" + "/usr/share/cmake-3.16/Modules/CMakeCXXInformation.cmake" + "/usr/share/cmake-3.16/Modules/CMakeCheckCompilerFlagCommonPatterns.cmake" + "/usr/share/cmake-3.16/Modules/CMakeCommonLanguageInclude.cmake" + "/usr/share/cmake-3.16/Modules/CMakeDependentOption.cmake" + "/usr/share/cmake-3.16/Modules/CMakeGenericSystem.cmake" + "/usr/share/cmake-3.16/Modules/CMakeInitializeConfigs.cmake" + "/usr/share/cmake-3.16/Modules/CMakeLanguageInformation.cmake" + "/usr/share/cmake-3.16/Modules/CMakePackageConfigHelpers.cmake" + "/usr/share/cmake-3.16/Modules/CMakeParseArguments.cmake" + "/usr/share/cmake-3.16/Modules/CMakeSystemSpecificInformation.cmake" + "/usr/share/cmake-3.16/Modules/CMakeSystemSpecificInitialize.cmake" + "/usr/share/cmake-3.16/Modules/CheckCXXCompilerFlag.cmake" + "/usr/share/cmake-3.16/Modules/CheckCXXSourceCompiles.cmake" + "/usr/share/cmake-3.16/Modules/Compiler/CMakeCommonCompilerMacros.cmake" + "/usr/share/cmake-3.16/Modules/Compiler/GNU-C.cmake" + "/usr/share/cmake-3.16/Modules/Compiler/GNU-CXX.cmake" + "/usr/share/cmake-3.16/Modules/Compiler/GNU.cmake" + "/usr/share/cmake-3.16/Modules/FindPackageHandleStandardArgs.cmake" + "/usr/share/cmake-3.16/Modules/FindPackageMessage.cmake" + "/usr/share/cmake-3.16/Modules/FindPythonInterp.cmake" + "/usr/share/cmake-3.16/Modules/GNUInstallDirs.cmake" + "/usr/share/cmake-3.16/Modules/Internal/CMakeCheckCompilerFlag.cmake" + "/usr/share/cmake-3.16/Modules/MacroAddFileDependencies.cmake" + "/usr/share/cmake-3.16/Modules/Platform/Linux-GNU-C.cmake" + "/usr/share/cmake-3.16/Modules/Platform/Linux-GNU-CXX.cmake" + "/usr/share/cmake-3.16/Modules/Platform/Linux-GNU.cmake" + "/usr/share/cmake-3.16/Modules/Platform/Linux.cmake" + "/usr/share/cmake-3.16/Modules/Platform/UnixPaths.cmake" + "/usr/share/cmake-3.16/Modules/WriteBasicConfigVersionFile.cmake" + ) + +# The corresponding makefile is: +set(CMAKE_MAKEFILE_OUTPUTS + "Makefile" + "CMakeFiles/cmake.check_cache" + ) + +# Byproducts of CMake generate step: +set(CMAKE_MAKEFILE_PRODUCTS + "CMakeFiles/albert-bin_autogen.dir/AutogenInfo.json" + "CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Info.json" + "CMakeFiles/albert-lib_autogen.dir/AutogenInfo.json" + "CMakeFiles/CMakeDirectoryInformation.cmake" + "lib/globalshortcut/CMakeFiles/CMakeDirectoryInformation.cmake" + "lib/xdg/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/widgetboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/qmlboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/applications/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/calculator/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/chromium/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/files/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/firefoxbookmarks/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/hashgenerator/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/mpris/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/python/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/python/pybind11/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/snippets/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/ssh/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/system/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/terminal/CMakeFiles/CMakeDirectoryInformation.cmake" + "plugins/websearch/CMakeFiles/CMakeDirectoryInformation.cmake" + ) + +# Dependency information for all targets: +set(CMAKE_DEPEND_INFO_FILES + "CMakeFiles/albert-bin.dir/DependInfo.cmake" + "CMakeFiles/albert-lib.dir/DependInfo.cmake" + "CMakeFiles/albert-bin_autogen.dir/DependInfo.cmake" + "CMakeFiles/albert-lib_autogen.dir/DependInfo.cmake" + "lib/globalshortcut/CMakeFiles/globalshortcut.dir/DependInfo.cmake" + "lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/DependInfo.cmake" + "lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + "lib/xdg/CMakeFiles/xdg_autogen.dir/DependInfo.cmake" + "plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/DependInfo.cmake" + "plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/DependInfo.cmake" + "plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/DependInfo.cmake" + "plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/DependInfo.cmake" + "plugins/applications/CMakeFiles/applications.dir/DependInfo.cmake" + "plugins/applications/CMakeFiles/applications_autogen.dir/DependInfo.cmake" + "plugins/calculator/CMakeFiles/calculator.dir/DependInfo.cmake" + "plugins/calculator/CMakeFiles/calculator_autogen.dir/DependInfo.cmake" + "plugins/chromium/CMakeFiles/chromium.dir/DependInfo.cmake" + "plugins/chromium/CMakeFiles/chromium_autogen.dir/DependInfo.cmake" + "plugins/files/CMakeFiles/files.dir/DependInfo.cmake" + "plugins/files/CMakeFiles/files_autogen.dir/DependInfo.cmake" + "plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/DependInfo.cmake" + "plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/DependInfo.cmake" + "plugins/hashgenerator/CMakeFiles/hashgenerator.dir/DependInfo.cmake" + "plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/DependInfo.cmake" + "plugins/mpris/CMakeFiles/mpris.dir/DependInfo.cmake" + "plugins/mpris/CMakeFiles/mpris_autogen.dir/DependInfo.cmake" + "plugins/python/CMakeFiles/python.dir/DependInfo.cmake" + "plugins/python/CMakeFiles/python_autogen.dir/DependInfo.cmake" + "plugins/snippets/CMakeFiles/snippets.dir/DependInfo.cmake" + "plugins/snippets/CMakeFiles/snippets_autogen.dir/DependInfo.cmake" + "plugins/ssh/CMakeFiles/ssh.dir/DependInfo.cmake" + "plugins/ssh/CMakeFiles/ssh_autogen.dir/DependInfo.cmake" + "plugins/system/CMakeFiles/system.dir/DependInfo.cmake" + "plugins/system/CMakeFiles/system_autogen.dir/DependInfo.cmake" + "plugins/terminal/CMakeFiles/terminal.dir/DependInfo.cmake" + "plugins/terminal/CMakeFiles/terminal_autogen.dir/DependInfo.cmake" + "plugins/websearch/CMakeFiles/websearch.dir/DependInfo.cmake" + "plugins/websearch/CMakeFiles/websearch_autogen.dir/DependInfo.cmake" + ) diff --git a/build/CMakeFiles/Makefile2 b/build/CMakeFiles/Makefile2 new file mode 100644 index 0000000..c0b2ada --- /dev/null +++ b/build/CMakeFiles/Makefile2 @@ -0,0 +1,1562 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Directory level rules for the build root directory + +# The main recursive "all" target. +all: CMakeFiles/albert-bin.dir/all +all: CMakeFiles/albert-lib.dir/all +all: lib/globalshortcut/all +all: lib/xdg/all +all: plugins/all + +.PHONY : all + +# The main recursive "preinstall" target. +preinstall: lib/globalshortcut/preinstall +preinstall: lib/xdg/preinstall +preinstall: plugins/preinstall + +.PHONY : preinstall + +# The main recursive "clean" target. +clean: CMakeFiles/albert-bin.dir/clean +clean: CMakeFiles/albert-lib.dir/clean +clean: CMakeFiles/albert-bin_autogen.dir/clean +clean: CMakeFiles/albert-lib_autogen.dir/clean +clean: lib/globalshortcut/clean +clean: lib/xdg/clean +clean: plugins/clean + +.PHONY : clean + +#============================================================================= +# Directory level rules for directory lib/globalshortcut + +# Recursive "all" directory target. +lib/globalshortcut/all: lib/globalshortcut/CMakeFiles/globalshortcut.dir/all + +.PHONY : lib/globalshortcut/all + +# Recursive "preinstall" directory target. +lib/globalshortcut/preinstall: + +.PHONY : lib/globalshortcut/preinstall + +# Recursive "clean" directory target. +lib/globalshortcut/clean: lib/globalshortcut/CMakeFiles/globalshortcut.dir/clean +lib/globalshortcut/clean: lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/clean + +.PHONY : lib/globalshortcut/clean + +#============================================================================= +# Directory level rules for directory lib/xdg + +# Recursive "all" directory target. +lib/xdg/all: lib/xdg/CMakeFiles/xdg.dir/all + +.PHONY : lib/xdg/all + +# Recursive "preinstall" directory target. +lib/xdg/preinstall: + +.PHONY : lib/xdg/preinstall + +# Recursive "clean" directory target. +lib/xdg/clean: lib/xdg/CMakeFiles/xdg.dir/clean +lib/xdg/clean: lib/xdg/CMakeFiles/xdg_autogen.dir/clean + +.PHONY : lib/xdg/clean + +#============================================================================= +# Directory level rules for directory plugins + +# Recursive "all" directory target. +plugins/all: plugins/widgetboxmodel/all +plugins/all: plugins/qmlboxmodel/all +plugins/all: plugins/applications/all +plugins/all: plugins/calculator/all +plugins/all: plugins/chromium/all +plugins/all: plugins/files/all +plugins/all: plugins/firefoxbookmarks/all +plugins/all: plugins/hashgenerator/all +plugins/all: plugins/mpris/all +plugins/all: plugins/python/all +plugins/all: plugins/snippets/all +plugins/all: plugins/ssh/all +plugins/all: plugins/system/all +plugins/all: plugins/terminal/all +plugins/all: plugins/websearch/all + +.PHONY : plugins/all + +# Recursive "preinstall" directory target. +plugins/preinstall: plugins/widgetboxmodel/preinstall +plugins/preinstall: plugins/qmlboxmodel/preinstall +plugins/preinstall: plugins/applications/preinstall +plugins/preinstall: plugins/calculator/preinstall +plugins/preinstall: plugins/chromium/preinstall +plugins/preinstall: plugins/files/preinstall +plugins/preinstall: plugins/firefoxbookmarks/preinstall +plugins/preinstall: plugins/hashgenerator/preinstall +plugins/preinstall: plugins/mpris/preinstall +plugins/preinstall: plugins/python/preinstall +plugins/preinstall: plugins/snippets/preinstall +plugins/preinstall: plugins/ssh/preinstall +plugins/preinstall: plugins/system/preinstall +plugins/preinstall: plugins/terminal/preinstall +plugins/preinstall: plugins/websearch/preinstall + +.PHONY : plugins/preinstall + +# Recursive "clean" directory target. +plugins/clean: plugins/widgetboxmodel/clean +plugins/clean: plugins/qmlboxmodel/clean +plugins/clean: plugins/applications/clean +plugins/clean: plugins/calculator/clean +plugins/clean: plugins/chromium/clean +plugins/clean: plugins/files/clean +plugins/clean: plugins/firefoxbookmarks/clean +plugins/clean: plugins/hashgenerator/clean +plugins/clean: plugins/mpris/clean +plugins/clean: plugins/python/clean +plugins/clean: plugins/snippets/clean +plugins/clean: plugins/ssh/clean +plugins/clean: plugins/system/clean +plugins/clean: plugins/terminal/clean +plugins/clean: plugins/websearch/clean + +.PHONY : plugins/clean + +#============================================================================= +# Directory level rules for directory plugins/applications + +# Recursive "all" directory target. +plugins/applications/all: plugins/applications/CMakeFiles/applications.dir/all + +.PHONY : plugins/applications/all + +# Recursive "preinstall" directory target. +plugins/applications/preinstall: + +.PHONY : plugins/applications/preinstall + +# Recursive "clean" directory target. +plugins/applications/clean: plugins/applications/CMakeFiles/applications.dir/clean +plugins/applications/clean: plugins/applications/CMakeFiles/applications_autogen.dir/clean + +.PHONY : plugins/applications/clean + +#============================================================================= +# Directory level rules for directory plugins/calculator + +# Recursive "all" directory target. +plugins/calculator/all: plugins/calculator/CMakeFiles/calculator.dir/all + +.PHONY : plugins/calculator/all + +# Recursive "preinstall" directory target. +plugins/calculator/preinstall: + +.PHONY : plugins/calculator/preinstall + +# Recursive "clean" directory target. +plugins/calculator/clean: plugins/calculator/CMakeFiles/calculator.dir/clean +plugins/calculator/clean: plugins/calculator/CMakeFiles/calculator_autogen.dir/clean + +.PHONY : plugins/calculator/clean + +#============================================================================= +# Directory level rules for directory plugins/chromium + +# Recursive "all" directory target. +plugins/chromium/all: plugins/chromium/CMakeFiles/chromium.dir/all + +.PHONY : plugins/chromium/all + +# Recursive "preinstall" directory target. +plugins/chromium/preinstall: + +.PHONY : plugins/chromium/preinstall + +# Recursive "clean" directory target. +plugins/chromium/clean: plugins/chromium/CMakeFiles/chromium.dir/clean +plugins/chromium/clean: plugins/chromium/CMakeFiles/chromium_autogen.dir/clean + +.PHONY : plugins/chromium/clean + +#============================================================================= +# Directory level rules for directory plugins/files + +# Recursive "all" directory target. +plugins/files/all: plugins/files/CMakeFiles/files.dir/all + +.PHONY : plugins/files/all + +# Recursive "preinstall" directory target. +plugins/files/preinstall: + +.PHONY : plugins/files/preinstall + +# Recursive "clean" directory target. +plugins/files/clean: plugins/files/CMakeFiles/files.dir/clean +plugins/files/clean: plugins/files/CMakeFiles/files_autogen.dir/clean + +.PHONY : plugins/files/clean + +#============================================================================= +# Directory level rules for directory plugins/firefoxbookmarks + +# Recursive "all" directory target. +plugins/firefoxbookmarks/all: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/all + +.PHONY : plugins/firefoxbookmarks/all + +# Recursive "preinstall" directory target. +plugins/firefoxbookmarks/preinstall: + +.PHONY : plugins/firefoxbookmarks/preinstall + +# Recursive "clean" directory target. +plugins/firefoxbookmarks/clean: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/clean +plugins/firefoxbookmarks/clean: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/clean + +.PHONY : plugins/firefoxbookmarks/clean + +#============================================================================= +# Directory level rules for directory plugins/hashgenerator + +# Recursive "all" directory target. +plugins/hashgenerator/all: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/all + +.PHONY : plugins/hashgenerator/all + +# Recursive "preinstall" directory target. +plugins/hashgenerator/preinstall: + +.PHONY : plugins/hashgenerator/preinstall + +# Recursive "clean" directory target. +plugins/hashgenerator/clean: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/clean +plugins/hashgenerator/clean: plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/clean + +.PHONY : plugins/hashgenerator/clean + +#============================================================================= +# Directory level rules for directory plugins/mpris + +# Recursive "all" directory target. +plugins/mpris/all: plugins/mpris/CMakeFiles/mpris.dir/all + +.PHONY : plugins/mpris/all + +# Recursive "preinstall" directory target. +plugins/mpris/preinstall: + +.PHONY : plugins/mpris/preinstall + +# Recursive "clean" directory target. +plugins/mpris/clean: plugins/mpris/CMakeFiles/mpris.dir/clean +plugins/mpris/clean: plugins/mpris/CMakeFiles/mpris_autogen.dir/clean + +.PHONY : plugins/mpris/clean + +#============================================================================= +# Directory level rules for directory plugins/python + +# Recursive "all" directory target. +plugins/python/all: plugins/python/CMakeFiles/python.dir/all +plugins/python/all: plugins/python/pybind11/all + +.PHONY : plugins/python/all + +# Recursive "preinstall" directory target. +plugins/python/preinstall: plugins/python/pybind11/preinstall + +.PHONY : plugins/python/preinstall + +# Recursive "clean" directory target. +plugins/python/clean: plugins/python/CMakeFiles/python.dir/clean +plugins/python/clean: plugins/python/CMakeFiles/python_autogen.dir/clean +plugins/python/clean: plugins/python/pybind11/clean + +.PHONY : plugins/python/clean + +#============================================================================= +# Directory level rules for directory plugins/python/pybind11 + +# Recursive "all" directory target. +plugins/python/pybind11/all: + +.PHONY : plugins/python/pybind11/all + +# Recursive "preinstall" directory target. +plugins/python/pybind11/preinstall: + +.PHONY : plugins/python/pybind11/preinstall + +# Recursive "clean" directory target. +plugins/python/pybind11/clean: + +.PHONY : plugins/python/pybind11/clean + +#============================================================================= +# Directory level rules for directory plugins/qmlboxmodel + +# Recursive "all" directory target. +plugins/qmlboxmodel/all: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/all + +.PHONY : plugins/qmlboxmodel/all + +# Recursive "preinstall" directory target. +plugins/qmlboxmodel/preinstall: + +.PHONY : plugins/qmlboxmodel/preinstall + +# Recursive "clean" directory target. +plugins/qmlboxmodel/clean: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/clean +plugins/qmlboxmodel/clean: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/clean + +.PHONY : plugins/qmlboxmodel/clean + +#============================================================================= +# Directory level rules for directory plugins/snippets + +# Recursive "all" directory target. +plugins/snippets/all: plugins/snippets/CMakeFiles/snippets.dir/all + +.PHONY : plugins/snippets/all + +# Recursive "preinstall" directory target. +plugins/snippets/preinstall: + +.PHONY : plugins/snippets/preinstall + +# Recursive "clean" directory target. +plugins/snippets/clean: plugins/snippets/CMakeFiles/snippets.dir/clean +plugins/snippets/clean: plugins/snippets/CMakeFiles/snippets_autogen.dir/clean + +.PHONY : plugins/snippets/clean + +#============================================================================= +# Directory level rules for directory plugins/ssh + +# Recursive "all" directory target. +plugins/ssh/all: plugins/ssh/CMakeFiles/ssh.dir/all + +.PHONY : plugins/ssh/all + +# Recursive "preinstall" directory target. +plugins/ssh/preinstall: + +.PHONY : plugins/ssh/preinstall + +# Recursive "clean" directory target. +plugins/ssh/clean: plugins/ssh/CMakeFiles/ssh.dir/clean +plugins/ssh/clean: plugins/ssh/CMakeFiles/ssh_autogen.dir/clean + +.PHONY : plugins/ssh/clean + +#============================================================================= +# Directory level rules for directory plugins/system + +# Recursive "all" directory target. +plugins/system/all: plugins/system/CMakeFiles/system.dir/all + +.PHONY : plugins/system/all + +# Recursive "preinstall" directory target. +plugins/system/preinstall: + +.PHONY : plugins/system/preinstall + +# Recursive "clean" directory target. +plugins/system/clean: plugins/system/CMakeFiles/system.dir/clean +plugins/system/clean: plugins/system/CMakeFiles/system_autogen.dir/clean + +.PHONY : plugins/system/clean + +#============================================================================= +# Directory level rules for directory plugins/terminal + +# Recursive "all" directory target. +plugins/terminal/all: plugins/terminal/CMakeFiles/terminal.dir/all + +.PHONY : plugins/terminal/all + +# Recursive "preinstall" directory target. +plugins/terminal/preinstall: + +.PHONY : plugins/terminal/preinstall + +# Recursive "clean" directory target. +plugins/terminal/clean: plugins/terminal/CMakeFiles/terminal.dir/clean +plugins/terminal/clean: plugins/terminal/CMakeFiles/terminal_autogen.dir/clean + +.PHONY : plugins/terminal/clean + +#============================================================================= +# Directory level rules for directory plugins/websearch + +# Recursive "all" directory target. +plugins/websearch/all: plugins/websearch/CMakeFiles/websearch.dir/all + +.PHONY : plugins/websearch/all + +# Recursive "preinstall" directory target. +plugins/websearch/preinstall: + +.PHONY : plugins/websearch/preinstall + +# Recursive "clean" directory target. +plugins/websearch/clean: plugins/websearch/CMakeFiles/websearch.dir/clean +plugins/websearch/clean: plugins/websearch/CMakeFiles/websearch_autogen.dir/clean + +.PHONY : plugins/websearch/clean + +#============================================================================= +# Directory level rules for directory plugins/widgetboxmodel + +# Recursive "all" directory target. +plugins/widgetboxmodel/all: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/all + +.PHONY : plugins/widgetboxmodel/all + +# Recursive "preinstall" directory target. +plugins/widgetboxmodel/preinstall: + +.PHONY : plugins/widgetboxmodel/preinstall + +# Recursive "clean" directory target. +plugins/widgetboxmodel/clean: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/clean +plugins/widgetboxmodel/clean: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/clean + +.PHONY : plugins/widgetboxmodel/clean + +#============================================================================= +# Target rules for target CMakeFiles/albert-bin.dir + +# All Build rule for target. +CMakeFiles/albert-bin.dir/all: CMakeFiles/albert-lib.dir/all +CMakeFiles/albert-bin.dir/all: lib/globalshortcut/CMakeFiles/globalshortcut.dir/all +CMakeFiles/albert-bin.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +CMakeFiles/albert-bin.dir/all: CMakeFiles/albert-bin_autogen.dir/all + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/depend + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=1,2,3,4,5,6,7,8,9,10 "Built target albert-bin" +.PHONY : CMakeFiles/albert-bin.dir/all + +# Build rule for subdir invocation for target. +CMakeFiles/albert-bin.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 25 + $(MAKE) -f CMakeFiles/Makefile2 CMakeFiles/albert-bin.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : CMakeFiles/albert-bin.dir/rule + +# Convenience name for target. +albert-bin: CMakeFiles/albert-bin.dir/rule + +.PHONY : albert-bin + +# clean rule for target. +CMakeFiles/albert-bin.dir/clean: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/clean +.PHONY : CMakeFiles/albert-bin.dir/clean + +#============================================================================= +# Target rules for target CMakeFiles/albert-lib.dir + +# All Build rule for target. +CMakeFiles/albert-lib.dir/all: CMakeFiles/albert-lib_autogen.dir/all + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/depend + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=12,13,14,15,16,17,18 "Built target albert-lib" +.PHONY : CMakeFiles/albert-lib.dir/all + +# Build rule for subdir invocation for target. +CMakeFiles/albert-lib.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 7 + $(MAKE) -f CMakeFiles/Makefile2 CMakeFiles/albert-lib.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : CMakeFiles/albert-lib.dir/rule + +# Convenience name for target. +albert-lib: CMakeFiles/albert-lib.dir/rule + +.PHONY : albert-lib + +# clean rule for target. +CMakeFiles/albert-lib.dir/clean: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/clean +.PHONY : CMakeFiles/albert-lib.dir/clean + +#============================================================================= +# Target rules for target CMakeFiles/albert-bin_autogen.dir + +# All Build rule for target. +CMakeFiles/albert-bin_autogen.dir/all: CMakeFiles/albert-lib.dir/all +CMakeFiles/albert-bin_autogen.dir/all: lib/globalshortcut/CMakeFiles/globalshortcut.dir/all +CMakeFiles/albert-bin_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f CMakeFiles/albert-bin_autogen.dir/build.make CMakeFiles/albert-bin_autogen.dir/depend + $(MAKE) -f CMakeFiles/albert-bin_autogen.dir/build.make CMakeFiles/albert-bin_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=11 "Built target albert-bin_autogen" +.PHONY : CMakeFiles/albert-bin_autogen.dir/all + +# Build rule for subdir invocation for target. +CMakeFiles/albert-bin_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 15 + $(MAKE) -f CMakeFiles/Makefile2 CMakeFiles/albert-bin_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : CMakeFiles/albert-bin_autogen.dir/rule + +# Convenience name for target. +albert-bin_autogen: CMakeFiles/albert-bin_autogen.dir/rule + +.PHONY : albert-bin_autogen + +# clean rule for target. +CMakeFiles/albert-bin_autogen.dir/clean: + $(MAKE) -f CMakeFiles/albert-bin_autogen.dir/build.make CMakeFiles/albert-bin_autogen.dir/clean +.PHONY : CMakeFiles/albert-bin_autogen.dir/clean + +#============================================================================= +# Target rules for target CMakeFiles/albert-lib_autogen.dir + +# All Build rule for target. +CMakeFiles/albert-lib_autogen.dir/all: + $(MAKE) -f CMakeFiles/albert-lib_autogen.dir/build.make CMakeFiles/albert-lib_autogen.dir/depend + $(MAKE) -f CMakeFiles/albert-lib_autogen.dir/build.make CMakeFiles/albert-lib_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target albert-lib_autogen" +.PHONY : CMakeFiles/albert-lib_autogen.dir/all + +# Build rule for subdir invocation for target. +CMakeFiles/albert-lib_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 + $(MAKE) -f CMakeFiles/Makefile2 CMakeFiles/albert-lib_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : CMakeFiles/albert-lib_autogen.dir/rule + +# Convenience name for target. +albert-lib_autogen: CMakeFiles/albert-lib_autogen.dir/rule + +.PHONY : albert-lib_autogen + +# clean rule for target. +CMakeFiles/albert-lib_autogen.dir/clean: + $(MAKE) -f CMakeFiles/albert-lib_autogen.dir/build.make CMakeFiles/albert-lib_autogen.dir/clean +.PHONY : CMakeFiles/albert-lib_autogen.dir/clean + +#============================================================================= +# Target rules for target lib/globalshortcut/CMakeFiles/globalshortcut.dir + +# All Build rule for target. +lib/globalshortcut/CMakeFiles/globalshortcut.dir/all: lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/all + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=44,45,46 "Built target globalshortcut" +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut.dir/all + +# Build rule for subdir invocation for target. +lib/globalshortcut/CMakeFiles/globalshortcut.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 3 + $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/CMakeFiles/globalshortcut.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut.dir/rule + +# Convenience name for target. +globalshortcut: lib/globalshortcut/CMakeFiles/globalshortcut.dir/rule + +.PHONY : globalshortcut + +# clean rule for target. +lib/globalshortcut/CMakeFiles/globalshortcut.dir/clean: + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/clean +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut.dir/clean + +#============================================================================= +# Target rules for target lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir + +# All Build rule for target. +lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/all: + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/depend + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target globalshortcut_autogen" +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/all + +# Build rule for subdir invocation for target. +lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 + $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/rule + +# Convenience name for target. +globalshortcut_autogen: lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/rule + +.PHONY : globalshortcut_autogen + +# clean rule for target. +lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/clean: + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/clean +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/clean + +#============================================================================= +# Target rules for target lib/xdg/CMakeFiles/xdg.dir + +# All Build rule for target. +lib/xdg/CMakeFiles/xdg.dir/all: lib/xdg/CMakeFiles/xdg_autogen.dir/all + $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/depend + $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=97,98,99 "Built target xdg" +.PHONY : lib/xdg/CMakeFiles/xdg.dir/all + +# Build rule for subdir invocation for target. +lib/xdg/CMakeFiles/xdg.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 4 + $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/CMakeFiles/xdg.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : lib/xdg/CMakeFiles/xdg.dir/rule + +# Convenience name for target. +xdg: lib/xdg/CMakeFiles/xdg.dir/rule + +.PHONY : xdg + +# clean rule for target. +lib/xdg/CMakeFiles/xdg.dir/clean: + $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/clean +.PHONY : lib/xdg/CMakeFiles/xdg.dir/clean + +#============================================================================= +# Target rules for target lib/xdg/CMakeFiles/xdg_autogen.dir + +# All Build rule for target. +lib/xdg/CMakeFiles/xdg_autogen.dir/all: + $(MAKE) -f lib/xdg/CMakeFiles/xdg_autogen.dir/build.make lib/xdg/CMakeFiles/xdg_autogen.dir/depend + $(MAKE) -f lib/xdg/CMakeFiles/xdg_autogen.dir/build.make lib/xdg/CMakeFiles/xdg_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=100 "Built target xdg_autogen" +.PHONY : lib/xdg/CMakeFiles/xdg_autogen.dir/all + +# Build rule for subdir invocation for target. +lib/xdg/CMakeFiles/xdg_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 1 + $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/CMakeFiles/xdg_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : lib/xdg/CMakeFiles/xdg_autogen.dir/rule + +# Convenience name for target. +xdg_autogen: lib/xdg/CMakeFiles/xdg_autogen.dir/rule + +.PHONY : xdg_autogen + +# clean rule for target. +lib/xdg/CMakeFiles/xdg_autogen.dir/clean: + $(MAKE) -f lib/xdg/CMakeFiles/xdg_autogen.dir/build.make lib/xdg/CMakeFiles/xdg_autogen.dir/clean +.PHONY : lib/xdg/CMakeFiles/xdg_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir + +# All Build rule for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/all: CMakeFiles/albert-lib.dir/all +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/all: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/all + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=91,92,93,94,95,96 "Built target widgetboxmodel" +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/all + +# Build rule for subdir invocation for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 13 + $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/rule + +# Convenience name for target. +widgetboxmodel: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/rule + +.PHONY : widgetboxmodel + +# clean rule for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/clean: + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/clean +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/clean + +#============================================================================= +# Target rules for target plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir + +# All Build rule for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/all: CMakeFiles/albert-lib.dir/all + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/depend + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target widgetboxmodel_autogen" +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 7 + $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/rule + +# Convenience name for target. +widgetboxmodel_autogen: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/rule + +.PHONY : widgetboxmodel_autogen + +# clean rule for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/clean: + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/clean +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir + +# All Build rule for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/all: CMakeFiles/albert-lib.dir/all +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/all: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/all + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=63,64,65,66 "Built target qmlboxmodel" +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/all + +# Build rule for subdir invocation for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/rule + +# Convenience name for target. +qmlboxmodel: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/rule + +.PHONY : qmlboxmodel + +# clean rule for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/clean: + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/clean +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/clean + +#============================================================================= +# Target rules for target plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir + +# All Build rule for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/all: CMakeFiles/albert-lib.dir/all + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/depend + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=67 "Built target qmlboxmodel_autogen" +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 8 + $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/rule + +# Convenience name for target. +qmlboxmodel_autogen: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/rule + +.PHONY : qmlboxmodel_autogen + +# clean rule for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/clean: + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/clean +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/applications/CMakeFiles/applications.dir + +# All Build rule for target. +plugins/applications/CMakeFiles/applications.dir/all: CMakeFiles/albert-lib.dir/all +plugins/applications/CMakeFiles/applications.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/applications/CMakeFiles/applications.dir/all: plugins/applications/CMakeFiles/applications_autogen.dir/all + $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/depend + $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=19,20,21,22 "Built target applications" +.PHONY : plugins/applications/CMakeFiles/applications.dir/all + +# Build rule for subdir invocation for target. +plugins/applications/CMakeFiles/applications.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 16 + $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/CMakeFiles/applications.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/applications/CMakeFiles/applications.dir/rule + +# Convenience name for target. +applications: plugins/applications/CMakeFiles/applications.dir/rule + +.PHONY : applications + +# clean rule for target. +plugins/applications/CMakeFiles/applications.dir/clean: + $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/clean +.PHONY : plugins/applications/CMakeFiles/applications.dir/clean + +#============================================================================= +# Target rules for target plugins/applications/CMakeFiles/applications_autogen.dir + +# All Build rule for target. +plugins/applications/CMakeFiles/applications_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/applications/CMakeFiles/applications_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/applications/CMakeFiles/applications_autogen.dir/build.make plugins/applications/CMakeFiles/applications_autogen.dir/depend + $(MAKE) -f plugins/applications/CMakeFiles/applications_autogen.dir/build.make plugins/applications/CMakeFiles/applications_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=23 "Built target applications_autogen" +.PHONY : plugins/applications/CMakeFiles/applications_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/applications/CMakeFiles/applications_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/CMakeFiles/applications_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/applications/CMakeFiles/applications_autogen.dir/rule + +# Convenience name for target. +applications_autogen: plugins/applications/CMakeFiles/applications_autogen.dir/rule + +.PHONY : applications_autogen + +# clean rule for target. +plugins/applications/CMakeFiles/applications_autogen.dir/clean: + $(MAKE) -f plugins/applications/CMakeFiles/applications_autogen.dir/build.make plugins/applications/CMakeFiles/applications_autogen.dir/clean +.PHONY : plugins/applications/CMakeFiles/applications_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/calculator/CMakeFiles/calculator.dir + +# All Build rule for target. +plugins/calculator/CMakeFiles/calculator.dir/all: CMakeFiles/albert-lib.dir/all +plugins/calculator/CMakeFiles/calculator.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/calculator/CMakeFiles/calculator.dir/all: plugins/calculator/CMakeFiles/calculator_autogen.dir/all + $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/depend + $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=24,25,26,27 "Built target calculator" +.PHONY : plugins/calculator/CMakeFiles/calculator.dir/all + +# Build rule for subdir invocation for target. +plugins/calculator/CMakeFiles/calculator.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 15 + $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/CMakeFiles/calculator.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/calculator/CMakeFiles/calculator.dir/rule + +# Convenience name for target. +calculator: plugins/calculator/CMakeFiles/calculator.dir/rule + +.PHONY : calculator + +# clean rule for target. +plugins/calculator/CMakeFiles/calculator.dir/clean: + $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/clean +.PHONY : plugins/calculator/CMakeFiles/calculator.dir/clean + +#============================================================================= +# Target rules for target plugins/calculator/CMakeFiles/calculator_autogen.dir + +# All Build rule for target. +plugins/calculator/CMakeFiles/calculator_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/calculator/CMakeFiles/calculator_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make plugins/calculator/CMakeFiles/calculator_autogen.dir/depend + $(MAKE) -f plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make plugins/calculator/CMakeFiles/calculator_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target calculator_autogen" +.PHONY : plugins/calculator/CMakeFiles/calculator_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/calculator/CMakeFiles/calculator_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 11 + $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/CMakeFiles/calculator_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/calculator/CMakeFiles/calculator_autogen.dir/rule + +# Convenience name for target. +calculator_autogen: plugins/calculator/CMakeFiles/calculator_autogen.dir/rule + +.PHONY : calculator_autogen + +# clean rule for target. +plugins/calculator/CMakeFiles/calculator_autogen.dir/clean: + $(MAKE) -f plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make plugins/calculator/CMakeFiles/calculator_autogen.dir/clean +.PHONY : plugins/calculator/CMakeFiles/calculator_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/chromium/CMakeFiles/chromium.dir + +# All Build rule for target. +plugins/chromium/CMakeFiles/chromium.dir/all: CMakeFiles/albert-lib.dir/all +plugins/chromium/CMakeFiles/chromium.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/chromium/CMakeFiles/chromium.dir/all: plugins/chromium/CMakeFiles/chromium_autogen.dir/all + $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/depend + $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=28,29,30,31 "Built target chromium" +.PHONY : plugins/chromium/CMakeFiles/chromium.dir/all + +# Build rule for subdir invocation for target. +plugins/chromium/CMakeFiles/chromium.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 15 + $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/CMakeFiles/chromium.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/chromium/CMakeFiles/chromium.dir/rule + +# Convenience name for target. +chromium: plugins/chromium/CMakeFiles/chromium.dir/rule + +.PHONY : chromium + +# clean rule for target. +plugins/chromium/CMakeFiles/chromium.dir/clean: + $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/clean +.PHONY : plugins/chromium/CMakeFiles/chromium.dir/clean + +#============================================================================= +# Target rules for target plugins/chromium/CMakeFiles/chromium_autogen.dir + +# All Build rule for target. +plugins/chromium/CMakeFiles/chromium_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/chromium/CMakeFiles/chromium_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make plugins/chromium/CMakeFiles/chromium_autogen.dir/depend + $(MAKE) -f plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make plugins/chromium/CMakeFiles/chromium_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target chromium_autogen" +.PHONY : plugins/chromium/CMakeFiles/chromium_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/chromium/CMakeFiles/chromium_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 11 + $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/CMakeFiles/chromium_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/chromium/CMakeFiles/chromium_autogen.dir/rule + +# Convenience name for target. +chromium_autogen: plugins/chromium/CMakeFiles/chromium_autogen.dir/rule + +.PHONY : chromium_autogen + +# clean rule for target. +plugins/chromium/CMakeFiles/chromium_autogen.dir/clean: + $(MAKE) -f plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make plugins/chromium/CMakeFiles/chromium_autogen.dir/clean +.PHONY : plugins/chromium/CMakeFiles/chromium_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/files/CMakeFiles/files.dir + +# All Build rule for target. +plugins/files/CMakeFiles/files.dir/all: CMakeFiles/albert-lib.dir/all +plugins/files/CMakeFiles/files.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/files/CMakeFiles/files.dir/all: plugins/files/CMakeFiles/files_autogen.dir/all + $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/depend + $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=32,33,34,35,36,37,38 "Built target files" +.PHONY : plugins/files/CMakeFiles/files.dir/all + +# Build rule for subdir invocation for target. +plugins/files/CMakeFiles/files.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 19 + $(MAKE) -f CMakeFiles/Makefile2 plugins/files/CMakeFiles/files.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/files/CMakeFiles/files.dir/rule + +# Convenience name for target. +files: plugins/files/CMakeFiles/files.dir/rule + +.PHONY : files + +# clean rule for target. +plugins/files/CMakeFiles/files.dir/clean: + $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/clean +.PHONY : plugins/files/CMakeFiles/files.dir/clean + +#============================================================================= +# Target rules for target plugins/files/CMakeFiles/files_autogen.dir + +# All Build rule for target. +plugins/files/CMakeFiles/files_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/files/CMakeFiles/files_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/files/CMakeFiles/files_autogen.dir/build.make plugins/files/CMakeFiles/files_autogen.dir/depend + $(MAKE) -f plugins/files/CMakeFiles/files_autogen.dir/build.make plugins/files/CMakeFiles/files_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=39 "Built target files_autogen" +.PHONY : plugins/files/CMakeFiles/files_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/files/CMakeFiles/files_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/files/CMakeFiles/files_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/files/CMakeFiles/files_autogen.dir/rule + +# Convenience name for target. +files_autogen: plugins/files/CMakeFiles/files_autogen.dir/rule + +.PHONY : files_autogen + +# clean rule for target. +plugins/files/CMakeFiles/files_autogen.dir/clean: + $(MAKE) -f plugins/files/CMakeFiles/files_autogen.dir/build.make plugins/files/CMakeFiles/files_autogen.dir/clean +.PHONY : plugins/files/CMakeFiles/files_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir + +# All Build rule for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/all: CMakeFiles/albert-lib.dir/all +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/all: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/all + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=40,41,42,43 "Built target firefoxbookmarks" +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/all + +# Build rule for subdir invocation for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 15 + $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/rule + +# Convenience name for target. +firefoxbookmarks: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/rule + +.PHONY : firefoxbookmarks + +# clean rule for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/clean: + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/clean +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/clean + +#============================================================================= +# Target rules for target plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir + +# All Build rule for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/depend + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target firefoxbookmarks_autogen" +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 11 + $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/rule + +# Convenience name for target. +firefoxbookmarks_autogen: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/rule + +.PHONY : firefoxbookmarks_autogen + +# clean rule for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/clean: + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/clean +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/hashgenerator/CMakeFiles/hashgenerator.dir + +# All Build rule for target. +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/all: CMakeFiles/albert-lib.dir/all +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/all: plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/all + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=47,48,49,50 "Built target hashgenerator" +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator.dir/all + +# Build rule for subdir invocation for target. +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/CMakeFiles/hashgenerator.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator.dir/rule + +# Convenience name for target. +hashgenerator: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/rule + +.PHONY : hashgenerator + +# clean rule for target. +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/clean: + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/clean +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator.dir/clean + +#============================================================================= +# Target rules for target plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir + +# All Build rule for target. +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/all: CMakeFiles/albert-lib.dir/all + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/depend + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=51 "Built target hashgenerator_autogen" +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 8 + $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/rule + +# Convenience name for target. +hashgenerator_autogen: plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/rule + +.PHONY : hashgenerator_autogen + +# clean rule for target. +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/clean: + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/clean +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/mpris/CMakeFiles/mpris.dir + +# All Build rule for target. +plugins/mpris/CMakeFiles/mpris.dir/all: CMakeFiles/albert-lib.dir/all +plugins/mpris/CMakeFiles/mpris.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/mpris/CMakeFiles/mpris.dir/all: plugins/mpris/CMakeFiles/mpris_autogen.dir/all + $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/depend + $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=52,53,54,55,56 "Built target mpris" +.PHONY : plugins/mpris/CMakeFiles/mpris.dir/all + +# Build rule for subdir invocation for target. +plugins/mpris/CMakeFiles/mpris.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 16 + $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/CMakeFiles/mpris.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/mpris/CMakeFiles/mpris.dir/rule + +# Convenience name for target. +mpris: plugins/mpris/CMakeFiles/mpris.dir/rule + +.PHONY : mpris + +# clean rule for target. +plugins/mpris/CMakeFiles/mpris.dir/clean: + $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/clean +.PHONY : plugins/mpris/CMakeFiles/mpris.dir/clean + +#============================================================================= +# Target rules for target plugins/mpris/CMakeFiles/mpris_autogen.dir + +# All Build rule for target. +plugins/mpris/CMakeFiles/mpris_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/mpris/CMakeFiles/mpris_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make plugins/mpris/CMakeFiles/mpris_autogen.dir/depend + $(MAKE) -f plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make plugins/mpris/CMakeFiles/mpris_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target mpris_autogen" +.PHONY : plugins/mpris/CMakeFiles/mpris_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/mpris/CMakeFiles/mpris_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 11 + $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/CMakeFiles/mpris_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/mpris/CMakeFiles/mpris_autogen.dir/rule + +# Convenience name for target. +mpris_autogen: plugins/mpris/CMakeFiles/mpris_autogen.dir/rule + +.PHONY : mpris_autogen + +# clean rule for target. +plugins/mpris/CMakeFiles/mpris_autogen.dir/clean: + $(MAKE) -f plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make plugins/mpris/CMakeFiles/mpris_autogen.dir/clean +.PHONY : plugins/mpris/CMakeFiles/mpris_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/python/CMakeFiles/python.dir + +# All Build rule for target. +plugins/python/CMakeFiles/python.dir/all: CMakeFiles/albert-lib.dir/all +plugins/python/CMakeFiles/python.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/python/CMakeFiles/python.dir/all: plugins/python/CMakeFiles/python_autogen.dir/all + $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/depend + $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=57,58,59,60,61,62 "Built target python" +.PHONY : plugins/python/CMakeFiles/python.dir/all + +# Build rule for subdir invocation for target. +plugins/python/CMakeFiles/python.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 17 + $(MAKE) -f CMakeFiles/Makefile2 plugins/python/CMakeFiles/python.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/python/CMakeFiles/python.dir/rule + +# Convenience name for target. +python: plugins/python/CMakeFiles/python.dir/rule + +.PHONY : python + +# clean rule for target. +plugins/python/CMakeFiles/python.dir/clean: + $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/clean +.PHONY : plugins/python/CMakeFiles/python.dir/clean + +#============================================================================= +# Target rules for target plugins/python/CMakeFiles/python_autogen.dir + +# All Build rule for target. +plugins/python/CMakeFiles/python_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/python/CMakeFiles/python_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/python/CMakeFiles/python_autogen.dir/build.make plugins/python/CMakeFiles/python_autogen.dir/depend + $(MAKE) -f plugins/python/CMakeFiles/python_autogen.dir/build.make plugins/python/CMakeFiles/python_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target python_autogen" +.PHONY : plugins/python/CMakeFiles/python_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/python/CMakeFiles/python_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 11 + $(MAKE) -f CMakeFiles/Makefile2 plugins/python/CMakeFiles/python_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/python/CMakeFiles/python_autogen.dir/rule + +# Convenience name for target. +python_autogen: plugins/python/CMakeFiles/python_autogen.dir/rule + +.PHONY : python_autogen + +# clean rule for target. +plugins/python/CMakeFiles/python_autogen.dir/clean: + $(MAKE) -f plugins/python/CMakeFiles/python_autogen.dir/build.make plugins/python/CMakeFiles/python_autogen.dir/clean +.PHONY : plugins/python/CMakeFiles/python_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/snippets/CMakeFiles/snippets.dir + +# All Build rule for target. +plugins/snippets/CMakeFiles/snippets.dir/all: CMakeFiles/albert-lib.dir/all +plugins/snippets/CMakeFiles/snippets.dir/all: plugins/snippets/CMakeFiles/snippets_autogen.dir/all + $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/depend + $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=68,69,70,71 "Built target snippets" +.PHONY : plugins/snippets/CMakeFiles/snippets.dir/all + +# Build rule for subdir invocation for target. +plugins/snippets/CMakeFiles/snippets.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/CMakeFiles/snippets.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/snippets/CMakeFiles/snippets.dir/rule + +# Convenience name for target. +snippets: plugins/snippets/CMakeFiles/snippets.dir/rule + +.PHONY : snippets + +# clean rule for target. +plugins/snippets/CMakeFiles/snippets.dir/clean: + $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/clean +.PHONY : plugins/snippets/CMakeFiles/snippets.dir/clean + +#============================================================================= +# Target rules for target plugins/snippets/CMakeFiles/snippets_autogen.dir + +# All Build rule for target. +plugins/snippets/CMakeFiles/snippets_autogen.dir/all: CMakeFiles/albert-lib.dir/all + $(MAKE) -f plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make plugins/snippets/CMakeFiles/snippets_autogen.dir/depend + $(MAKE) -f plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make plugins/snippets/CMakeFiles/snippets_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=72 "Built target snippets_autogen" +.PHONY : plugins/snippets/CMakeFiles/snippets_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/snippets/CMakeFiles/snippets_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 8 + $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/CMakeFiles/snippets_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/snippets/CMakeFiles/snippets_autogen.dir/rule + +# Convenience name for target. +snippets_autogen: plugins/snippets/CMakeFiles/snippets_autogen.dir/rule + +.PHONY : snippets_autogen + +# clean rule for target. +plugins/snippets/CMakeFiles/snippets_autogen.dir/clean: + $(MAKE) -f plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make plugins/snippets/CMakeFiles/snippets_autogen.dir/clean +.PHONY : plugins/snippets/CMakeFiles/snippets_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/ssh/CMakeFiles/ssh.dir + +# All Build rule for target. +plugins/ssh/CMakeFiles/ssh.dir/all: CMakeFiles/albert-lib.dir/all +plugins/ssh/CMakeFiles/ssh.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/ssh/CMakeFiles/ssh.dir/all: plugins/ssh/CMakeFiles/ssh_autogen.dir/all + $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/depend + $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=73,74,75 "Built target ssh" +.PHONY : plugins/ssh/CMakeFiles/ssh.dir/all + +# Build rule for subdir invocation for target. +plugins/ssh/CMakeFiles/ssh.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 15 + $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/CMakeFiles/ssh.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/ssh/CMakeFiles/ssh.dir/rule + +# Convenience name for target. +ssh: plugins/ssh/CMakeFiles/ssh.dir/rule + +.PHONY : ssh + +# clean rule for target. +plugins/ssh/CMakeFiles/ssh.dir/clean: + $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/clean +.PHONY : plugins/ssh/CMakeFiles/ssh.dir/clean + +#============================================================================= +# Target rules for target plugins/ssh/CMakeFiles/ssh_autogen.dir + +# All Build rule for target. +plugins/ssh/CMakeFiles/ssh_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/ssh/CMakeFiles/ssh_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make plugins/ssh/CMakeFiles/ssh_autogen.dir/depend + $(MAKE) -f plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make plugins/ssh/CMakeFiles/ssh_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=76 "Built target ssh_autogen" +.PHONY : plugins/ssh/CMakeFiles/ssh_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/ssh/CMakeFiles/ssh_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/CMakeFiles/ssh_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/ssh/CMakeFiles/ssh_autogen.dir/rule + +# Convenience name for target. +ssh_autogen: plugins/ssh/CMakeFiles/ssh_autogen.dir/rule + +.PHONY : ssh_autogen + +# clean rule for target. +plugins/ssh/CMakeFiles/ssh_autogen.dir/clean: + $(MAKE) -f plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make plugins/ssh/CMakeFiles/ssh_autogen.dir/clean +.PHONY : plugins/ssh/CMakeFiles/ssh_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/system/CMakeFiles/system.dir + +# All Build rule for target. +plugins/system/CMakeFiles/system.dir/all: CMakeFiles/albert-lib.dir/all +plugins/system/CMakeFiles/system.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/system/CMakeFiles/system.dir/all: plugins/system/CMakeFiles/system_autogen.dir/all + $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/depend + $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=77,78,79,80 "Built target system" +.PHONY : plugins/system/CMakeFiles/system.dir/all + +# Build rule for subdir invocation for target. +plugins/system/CMakeFiles/system.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 16 + $(MAKE) -f CMakeFiles/Makefile2 plugins/system/CMakeFiles/system.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/system/CMakeFiles/system.dir/rule + +# Convenience name for target. +system: plugins/system/CMakeFiles/system.dir/rule + +.PHONY : system + +# clean rule for target. +plugins/system/CMakeFiles/system.dir/clean: + $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/clean +.PHONY : plugins/system/CMakeFiles/system.dir/clean + +#============================================================================= +# Target rules for target plugins/system/CMakeFiles/system_autogen.dir + +# All Build rule for target. +plugins/system/CMakeFiles/system_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/system/CMakeFiles/system_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/system/CMakeFiles/system_autogen.dir/build.make plugins/system/CMakeFiles/system_autogen.dir/depend + $(MAKE) -f plugins/system/CMakeFiles/system_autogen.dir/build.make plugins/system/CMakeFiles/system_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=81 "Built target system_autogen" +.PHONY : plugins/system/CMakeFiles/system_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/system/CMakeFiles/system_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/system/CMakeFiles/system_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/system/CMakeFiles/system_autogen.dir/rule + +# Convenience name for target. +system_autogen: plugins/system/CMakeFiles/system_autogen.dir/rule + +.PHONY : system_autogen + +# clean rule for target. +plugins/system/CMakeFiles/system_autogen.dir/clean: + $(MAKE) -f plugins/system/CMakeFiles/system_autogen.dir/build.make plugins/system/CMakeFiles/system_autogen.dir/clean +.PHONY : plugins/system/CMakeFiles/system_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/terminal/CMakeFiles/terminal.dir + +# All Build rule for target. +plugins/terminal/CMakeFiles/terminal.dir/all: CMakeFiles/albert-lib.dir/all +plugins/terminal/CMakeFiles/terminal.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/terminal/CMakeFiles/terminal.dir/all: plugins/terminal/CMakeFiles/terminal_autogen.dir/all + $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/depend + $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=82,83,84 "Built target terminal" +.PHONY : plugins/terminal/CMakeFiles/terminal.dir/all + +# Build rule for subdir invocation for target. +plugins/terminal/CMakeFiles/terminal.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 14 + $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/CMakeFiles/terminal.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/terminal/CMakeFiles/terminal.dir/rule + +# Convenience name for target. +terminal: plugins/terminal/CMakeFiles/terminal.dir/rule + +.PHONY : terminal + +# clean rule for target. +plugins/terminal/CMakeFiles/terminal.dir/clean: + $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/clean +.PHONY : plugins/terminal/CMakeFiles/terminal.dir/clean + +#============================================================================= +# Target rules for target plugins/terminal/CMakeFiles/terminal_autogen.dir + +# All Build rule for target. +plugins/terminal/CMakeFiles/terminal_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/terminal/CMakeFiles/terminal_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make plugins/terminal/CMakeFiles/terminal_autogen.dir/depend + $(MAKE) -f plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make plugins/terminal/CMakeFiles/terminal_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num= "Built target terminal_autogen" +.PHONY : plugins/terminal/CMakeFiles/terminal_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/terminal/CMakeFiles/terminal_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 11 + $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/CMakeFiles/terminal_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/terminal/CMakeFiles/terminal_autogen.dir/rule + +# Convenience name for target. +terminal_autogen: plugins/terminal/CMakeFiles/terminal_autogen.dir/rule + +.PHONY : terminal_autogen + +# clean rule for target. +plugins/terminal/CMakeFiles/terminal_autogen.dir/clean: + $(MAKE) -f plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make plugins/terminal/CMakeFiles/terminal_autogen.dir/clean +.PHONY : plugins/terminal/CMakeFiles/terminal_autogen.dir/clean + +#============================================================================= +# Target rules for target plugins/websearch/CMakeFiles/websearch.dir + +# All Build rule for target. +plugins/websearch/CMakeFiles/websearch.dir/all: CMakeFiles/albert-lib.dir/all +plugins/websearch/CMakeFiles/websearch.dir/all: lib/xdg/CMakeFiles/xdg.dir/all +plugins/websearch/CMakeFiles/websearch.dir/all: plugins/websearch/CMakeFiles/websearch_autogen.dir/all + $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/depend + $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=85,86,87,88,89 "Built target websearch" +.PHONY : plugins/websearch/CMakeFiles/websearch.dir/all + +# Build rule for subdir invocation for target. +plugins/websearch/CMakeFiles/websearch.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 17 + $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/CMakeFiles/websearch.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/websearch/CMakeFiles/websearch.dir/rule + +# Convenience name for target. +websearch: plugins/websearch/CMakeFiles/websearch.dir/rule + +.PHONY : websearch + +# clean rule for target. +plugins/websearch/CMakeFiles/websearch.dir/clean: + $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/clean +.PHONY : plugins/websearch/CMakeFiles/websearch.dir/clean + +#============================================================================= +# Target rules for target plugins/websearch/CMakeFiles/websearch_autogen.dir + +# All Build rule for target. +plugins/websearch/CMakeFiles/websearch_autogen.dir/all: CMakeFiles/albert-lib.dir/all +plugins/websearch/CMakeFiles/websearch_autogen.dir/all: lib/xdg/CMakeFiles/xdg.dir/all + $(MAKE) -f plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make plugins/websearch/CMakeFiles/websearch_autogen.dir/depend + $(MAKE) -f plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make plugins/websearch/CMakeFiles/websearch_autogen.dir/build + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=90 "Built target websearch_autogen" +.PHONY : plugins/websearch/CMakeFiles/websearch_autogen.dir/all + +# Build rule for subdir invocation for target. +plugins/websearch/CMakeFiles/websearch_autogen.dir/rule: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 12 + $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/CMakeFiles/websearch_autogen.dir/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : plugins/websearch/CMakeFiles/websearch_autogen.dir/rule + +# Convenience name for target. +websearch_autogen: plugins/websearch/CMakeFiles/websearch_autogen.dir/rule + +.PHONY : websearch_autogen + +# clean rule for target. +plugins/websearch/CMakeFiles/websearch_autogen.dir/clean: + $(MAKE) -f plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make plugins/websearch/CMakeFiles/websearch_autogen.dir/clean +.PHONY : plugins/websearch/CMakeFiles/websearch_autogen.dir/clean + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/CMakeFiles/TargetDirectories.txt b/build/CMakeFiles/TargetDirectories.txt new file mode 100644 index 0000000..a45122f --- /dev/null +++ b/build/CMakeFiles/TargetDirectories.txt @@ -0,0 +1,158 @@ +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/install/strip.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/install/local.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/install.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/list_install_components.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/rebuild_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/edit_cache.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir +/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir diff --git a/build/CMakeFiles/albert-bin.dir/DependInfo.cmake b/build/CMakeFiles/albert-bin.dir/DependInfo.cmake new file mode 100644 index 0000000..0504b7d --- /dev/null +++ b/build/CMakeFiles/albert-bin.dir/DependInfo.cmake @@ -0,0 +1,70 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/main.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/main.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/query.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/query.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "BUILD_WITH_QTCHARTS" + "MULTIARCH_TUPLE=\"x86_64-linux-gnu\"" + "QT_CHARTS_LIB" + "QT_CONCURRENT_LIB" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_NETWORK_LIB" + "QT_SQL_LIB" + "QT_WIDGETS_LIB" + "QT_X11EXTRAS_LIB" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "." + "../" + "albert-bin_autogen/include" + "../src/app" + "../src/app/settingswidget" + "../include" + "../lib/globalshortcut/include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtNetwork" + "/usr/include/x86_64-linux-gnu/qt5/QtSql" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtX11Extras" + "/usr/include/x86_64-linux-gnu/qt5/QtCharts" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/CMakeFiles/albert-bin.dir/build.make b/build/CMakeFiles/albert-bin.dir/build.make new file mode 100644 index 0000000..1bd783c --- /dev/null +++ b/build/CMakeFiles/albert-bin.dir/build.make @@ -0,0 +1,334 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include CMakeFiles/albert-bin.dir/depend.make + +# Include the progress variables for this target. +include CMakeFiles/albert-bin.dir/progress.make + +# Include the compile flags for this target's objects. +include CMakeFiles/albert-bin.dir/flags.make + +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: ../resources.qrc +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Info.json +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: ../resources/icons/albert.svg +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: ../resources/icons/gear.svg +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: ../resources/icons/plugin_notloaded.png +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: ../resources/icons/plugin_ok.png +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: ../resources/icons/plugin_error.png +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: ../resources/icons/unknown.svg +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for resources.qrc" + /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Info.json Debug + +CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o: albert-bin_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/mocs_compilation.cpp + +CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/mocs_compilation.cpp > CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.i + +CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/mocs_compilation.cpp -o CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.s + +CMakeFiles/albert-bin.dir/src/app/extension.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/extension.cpp.o: ../src/app/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object CMakeFiles/albert-bin.dir/src/app/extension.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extension.cpp + +CMakeFiles/albert-bin.dir/src/app/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/extension.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extension.cpp > CMakeFiles/albert-bin.dir/src/app/extension.cpp.i + +CMakeFiles/albert-bin.dir/src/app/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/extension.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extension.cpp -o CMakeFiles/albert-bin.dir/src/app/extension.cpp.s + +CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o: ../src/app/extensionmanager.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.cpp + +CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.cpp > CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.i + +CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.cpp -o CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.s + +CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o: ../src/app/frontendmanager.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.cpp + +CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.cpp > CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.i + +CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.cpp -o CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.s + +CMakeFiles/albert-bin.dir/src/app/main.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/main.cpp.o: ../src/app/main.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object CMakeFiles/albert-bin.dir/src/app/main.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/main.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/main.cpp + +CMakeFiles/albert-bin.dir/src/app/main.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/main.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/main.cpp > CMakeFiles/albert-bin.dir/src/app/main.cpp.i + +CMakeFiles/albert-bin.dir/src/app/main.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/main.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/main.cpp -o CMakeFiles/albert-bin.dir/src/app/main.cpp.s + +CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o: ../src/app/pluginspec.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Building CXX object CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.cpp + +CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.cpp > CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.i + +CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.cpp -o CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.s + +CMakeFiles/albert-bin.dir/src/app/query.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/query.cpp.o: ../src/app/query.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_8) "Building CXX object CMakeFiles/albert-bin.dir/src/app/query.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/query.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/query.cpp + +CMakeFiles/albert-bin.dir/src/app/query.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/query.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/query.cpp > CMakeFiles/albert-bin.dir/src/app/query.cpp.i + +CMakeFiles/albert-bin.dir/src/app/query.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/query.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/query.cpp -o CMakeFiles/albert-bin.dir/src/app/query.cpp.s + +CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o: ../src/app/queryexecution.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_9) "Building CXX object CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.cpp + +CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.cpp > CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.i + +CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.cpp -o CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.s + +CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o: ../src/app/querymanager.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_10) "Building CXX object CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.cpp + +CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.cpp > CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.i + +CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.cpp -o CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.s + +CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o: ../src/app/settingswidget/grabkeybutton.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_11) "Building CXX object CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.cpp + +CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.cpp > CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.i + +CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.cpp -o CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.s + +CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o: ../src/app/settingswidget/loadermodel.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_12) "Building CXX object CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.cpp + +CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.cpp > CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.i + +CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.cpp -o CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.s + +CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o: ../src/app/settingswidget/settingswidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_13) "Building CXX object CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.cpp + +CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.cpp > CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.i + +CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.cpp -o CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.s + +CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o: ../src/app/settingswidget/statswidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_14) "Building CXX object CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.cpp + +CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.cpp > CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.i + +CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.cpp -o CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.s + +CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o: ../src/app/trayicon.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_15) "Building CXX object CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.cpp + +CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.cpp > CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.i + +CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.cpp -o CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.s + +CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o: CMakeFiles/albert-bin.dir/flags.make +CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o: albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_16) "Building CXX object CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp + +CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp > CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.i + +CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp -o CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.s + +# Object files for target albert-bin +albert__bin_OBJECTS = \ +"CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/extension.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/main.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/query.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o" \ +"CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o" \ +"CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o" + +# External object files for target albert-bin +albert__bin_EXTERNAL_OBJECTS = + +bin/albert: CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/extension.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/main.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/query.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o +bin/albert: CMakeFiles/albert-bin.dir/build.make +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Network.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5.12.8 +bin/albert: lib/libalbert.so +bin/albert: lib/globalshortcut/libglobalshortcut.a +bin/albert: lib/libxdg.so +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Charts.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +bin/albert: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +bin/albert: CMakeFiles/albert-bin.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_17) "Linking CXX executable bin/albert" + $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/albert-bin.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +CMakeFiles/albert-bin.dir/build: bin/albert + +.PHONY : CMakeFiles/albert-bin.dir/build + +CMakeFiles/albert-bin.dir/clean: + $(CMAKE_COMMAND) -P CMakeFiles/albert-bin.dir/cmake_clean.cmake +.PHONY : CMakeFiles/albert-bin.dir/clean + +CMakeFiles/albert-bin.dir/depend: albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : CMakeFiles/albert-bin.dir/depend + diff --git a/build/CMakeFiles/albert-bin.dir/cmake_clean.cmake b/build/CMakeFiles/albert-bin.dir/cmake_clean.cmake new file mode 100644 index 0000000..7f2a526 --- /dev/null +++ b/build/CMakeFiles/albert-bin.dir/cmake_clean.cmake @@ -0,0 +1,28 @@ +file(REMOVE_RECURSE + "CMakeFiles/albert-bin_autogen.dir/AutogenUsed.txt" + "CMakeFiles/albert-bin_autogen.dir/ParseCache.txt" + "albert-bin_autogen" + "CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o" + "CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/extension.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/main.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/query.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o" + "CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o" + "albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp" + "bin/albert" + "bin/albert.pdb" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/albert-bin.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/CMakeFiles/albert-bin.dir/depend.make b/build/CMakeFiles/albert-bin.dir/depend.make new file mode 100644 index 0000000..1cc5a2a --- /dev/null +++ b/build/CMakeFiles/albert-bin.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for albert-bin. +# This may be replaced when dependencies are built. diff --git a/build/CMakeFiles/albert-bin.dir/flags.make b/build/CMakeFiles/albert-bin.dir/flags.make new file mode 100644 index 0000000..9598b76 --- /dev/null +++ b/build/CMakeFiles/albert-bin.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\"x86_64-linux-gnu\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts + diff --git a/build/CMakeFiles/albert-bin.dir/link.txt b/build/CMakeFiles/albert-bin.dir/link.txt new file mode 100644 index 0000000..7ae069f --- /dev/null +++ b/build/CMakeFiles/albert-bin.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -rdynamic CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o CMakeFiles/albert-bin.dir/src/app/extension.cpp.o CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o CMakeFiles/albert-bin.dir/src/app/main.cpp.o CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o CMakeFiles/albert-bin.dir/src/app/query.cpp.o CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o -o bin/albert -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Network.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5.12.8 lib/libalbert.so lib/globalshortcut/libglobalshortcut.a lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Charts.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 -lX11 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/CMakeFiles/albert-bin.dir/progress.make b/build/CMakeFiles/albert-bin.dir/progress.make new file mode 100644 index 0000000..6d145b1 --- /dev/null +++ b/build/CMakeFiles/albert-bin.dir/progress.make @@ -0,0 +1,18 @@ +CMAKE_PROGRESS_1 = +CMAKE_PROGRESS_2 = 1 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 2 +CMAKE_PROGRESS_5 = 3 +CMAKE_PROGRESS_6 = +CMAKE_PROGRESS_7 = 4 +CMAKE_PROGRESS_8 = 5 +CMAKE_PROGRESS_9 = +CMAKE_PROGRESS_10 = 6 +CMAKE_PROGRESS_11 = +CMAKE_PROGRESS_12 = 7 +CMAKE_PROGRESS_13 = 8 +CMAKE_PROGRESS_14 = +CMAKE_PROGRESS_15 = 9 +CMAKE_PROGRESS_16 = 10 +CMAKE_PROGRESS_17 = + diff --git a/build/CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Info.json b/build/CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Info.json new file mode 100644 index 0000000..5b99bf2 --- /dev/null +++ b/build/CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Info.json @@ -0,0 +1,27 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources/icons/albert.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources/icons/gear.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources/icons/plugin_notloaded.png", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources/icons/plugin_ok.png", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources/icons/plugin_error.png", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources/icons/unknown.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "resources" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_resources.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir/AutoRcc_resources_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources.qrc", + "VERBOSITY" : 0 +} diff --git a/build/CMakeFiles/albert-bin_autogen.dir/AutogenInfo.json b/build/CMakeFiles/albert-bin_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..2de9287 --- /dev/null +++ b/build/CMakeFiles/albert-bin_autogen.dir/AutogenInfo.json @@ -0,0 +1,192 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.h", + "MU", + "ISMKEKEPX5/moc_extensionmanager.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.h", + "MU", + "ISMKEKEPX5/moc_frontendmanager.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/logging.h", + "MU", + "ISMKEKEPX5/moc_logging.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.h", + "MU", + "ISMKEKEPX5/moc_pluginspec.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.h", + "MU", + "ISMKEKEPX5/moc_queryexecution.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.h", + "MU", + "ISMKEKEPX5/moc_querymanager.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.h", + "MU", + "2ELFKGE4VT/moc_grabkeybutton.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.h", + "MU", + "2ELFKGE4VT/moc_loadermodel.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.h", + "MU", + "2ELFKGE4VT/moc_settingswidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.h", + "MU", + "2ELFKGE4VT/moc_statswidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.h", + "MU", + "ISMKEKEPX5/moc_trayicon.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "BUILD_WITH_QTCHARTS", + "MULTIARCH_TUPLE=\"x86_64-linux-gnu\"", + "QT_CHARTS_LIB", + "QT_CONCURRENT_LIB", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_NETWORK_LIB", + "QT_SQL_LIB", + "QT_WIDGETS_LIB", + "QT_X11EXTRAS_LIB" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtNetwork", + "/usr/include/x86_64-linux-gnu/qt5/QtSql", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtX11Extras", + "/usr/include/x86_64-linux-gnu/qt5/QtCharts", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extension.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.cpp", + "MU" + ], + [ "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/main.cpp", "MU" ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.cpp", + "MU" + ], + [ "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/query.cpp", "MU" ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/CMakeFiles/albert-bin_autogen.dir/DependInfo.cmake b/build/CMakeFiles/albert-bin_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/CMakeFiles/albert-bin_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/CMakeFiles/albert-bin_autogen.dir/build.make b/build/CMakeFiles/albert-bin_autogen.dir/build.make new file mode 100644 index 0000000..c9340a2 --- /dev/null +++ b/build/CMakeFiles/albert-bin_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for albert-bin_autogen. + +# Include the progress variables for this target. +include CMakeFiles/albert-bin_autogen.dir/progress.make + +CMakeFiles/albert-bin_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target albert-bin" + /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir/AutogenInfo.json Debug + +albert-bin_autogen: CMakeFiles/albert-bin_autogen +albert-bin_autogen: CMakeFiles/albert-bin_autogen.dir/build.make + +.PHONY : albert-bin_autogen + +# Rule to build all files generated by this target. +CMakeFiles/albert-bin_autogen.dir/build: albert-bin_autogen + +.PHONY : CMakeFiles/albert-bin_autogen.dir/build + +CMakeFiles/albert-bin_autogen.dir/clean: + $(CMAKE_COMMAND) -P CMakeFiles/albert-bin_autogen.dir/cmake_clean.cmake +.PHONY : CMakeFiles/albert-bin_autogen.dir/clean + +CMakeFiles/albert-bin_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-bin_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : CMakeFiles/albert-bin_autogen.dir/depend + diff --git a/build/CMakeFiles/albert-bin_autogen.dir/cmake_clean.cmake b/build/CMakeFiles/albert-bin_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..ac63449 --- /dev/null +++ b/build/CMakeFiles/albert-bin_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/albert-bin_autogen" + "albert-bin_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/albert-bin_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/CMakeFiles/albert-bin_autogen.dir/progress.make b/build/CMakeFiles/albert-bin_autogen.dir/progress.make new file mode 100644 index 0000000..27952ed --- /dev/null +++ b/build/CMakeFiles/albert-bin_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 11 + diff --git a/build/CMakeFiles/albert-lib.dir/DependInfo.cmake b/build/CMakeFiles/albert-lib.dir/DependInfo.cmake new file mode 100644 index 0000000..da06972 --- /dev/null +++ b/build/CMakeFiles/albert-lib.dir/DependInfo.cmake @@ -0,0 +1,51 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/history.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/history.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/offlineindex.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/plugin.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardactions.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardindexitem.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standarditem.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "CORE" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_SQL_LIB" + "albert_lib_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "." + "../" + "albert-lib_autogen/include" + "../include" + "../include/albert" + "../include/albert/util" + "../src/lib" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtSql" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/CMakeFiles/albert-lib.dir/build.make b/build/CMakeFiles/albert-lib.dir/build.make new file mode 100644 index 0000000..0d4ec41 --- /dev/null +++ b/build/CMakeFiles/albert-lib.dir/build.make @@ -0,0 +1,236 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include CMakeFiles/albert-lib.dir/depend.make + +# Include the progress variables for this target. +include CMakeFiles/albert-lib.dir/progress.make + +# Include the compile flags for this target's objects. +include CMakeFiles/albert-lib.dir/flags.make + +CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o: albert-lib_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Building CXX object CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/mocs_compilation.cpp + +CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/mocs_compilation.cpp > CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.i + +CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/mocs_compilation.cpp -o CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o: ../src/lib/fuzzysearch.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.cpp + +CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.cpp > CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.cpp -o CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/history.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/history.cpp.o: ../src/lib/history.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/history.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/history.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/history.cpp + +CMakeFiles/albert-lib.dir/src/lib/history.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/history.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/history.cpp > CMakeFiles/albert-lib.dir/src/lib/history.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/history.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/history.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/history.cpp -o CMakeFiles/albert-lib.dir/src/lib/history.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o: ../src/lib/offlineindex.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/offlineindex.cpp + +CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/offlineindex.cpp > CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/offlineindex.cpp -o CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o: ../src/lib/plugin.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/plugin.cpp + +CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/plugin.cpp > CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/plugin.cpp -o CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o: ../src/lib/prefixsearch.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.cpp + +CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.cpp > CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.cpp -o CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o: ../src/lib/searchbase.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.cpp + +CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.cpp > CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.cpp -o CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o: ../src/lib/standardactions.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_8) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardactions.cpp + +CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardactions.cpp > CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardactions.cpp -o CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o: ../src/lib/standardindexitem.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_9) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardindexitem.cpp + +CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardindexitem.cpp > CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardindexitem.cpp -o CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.s + +CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o: CMakeFiles/albert-lib.dir/flags.make +CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o: ../src/lib/standarditem.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_10) "Building CXX object CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standarditem.cpp + +CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.i" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standarditem.cpp > CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.i + +CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.s" + /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standarditem.cpp -o CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.s + +# Object files for target albert-lib +albert__lib_OBJECTS = \ +"CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/history.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o" \ +"CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o" + +# External object files for target albert-lib +albert__lib_EXTERNAL_OBJECTS = + +lib/libalbert.so: CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/history.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o +lib/libalbert.so: CMakeFiles/albert-lib.dir/build.make +lib/libalbert.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libalbert.so: /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 +lib/libalbert.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libalbert.so: CMakeFiles/albert-lib.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_11) "Linking CXX shared library lib/libalbert.so" + $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/albert-lib.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +CMakeFiles/albert-lib.dir/build: lib/libalbert.so + +.PHONY : CMakeFiles/albert-lib.dir/build + +CMakeFiles/albert-lib.dir/clean: + $(CMAKE_COMMAND) -P CMakeFiles/albert-lib.dir/cmake_clean.cmake +.PHONY : CMakeFiles/albert-lib.dir/clean + +CMakeFiles/albert-lib.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : CMakeFiles/albert-lib.dir/depend + diff --git a/build/CMakeFiles/albert-lib.dir/cmake_clean.cmake b/build/CMakeFiles/albert-lib.dir/cmake_clean.cmake new file mode 100644 index 0000000..844f944 --- /dev/null +++ b/build/CMakeFiles/albert-lib.dir/cmake_clean.cmake @@ -0,0 +1,22 @@ +file(REMOVE_RECURSE + "CMakeFiles/albert-lib_autogen.dir/AutogenUsed.txt" + "CMakeFiles/albert-lib_autogen.dir/ParseCache.txt" + "albert-lib_autogen" + "CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/history.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o" + "CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o" + "lib/libalbert.pdb" + "lib/libalbert.so" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/albert-lib.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/CMakeFiles/albert-lib.dir/depend.make b/build/CMakeFiles/albert-lib.dir/depend.make new file mode 100644 index 0000000..5183d06 --- /dev/null +++ b/build/CMakeFiles/albert-lib.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for albert-lib. +# This may be replaced when dependencies are built. diff --git a/build/CMakeFiles/albert-lib.dir/flags.make b/build/CMakeFiles/albert-lib.dir/flags.make new file mode 100644 index 0000000..1902bf3 --- /dev/null +++ b/build/CMakeFiles/albert-lib.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql + diff --git a/build/CMakeFiles/albert-lib.dir/link.txt b/build/CMakeFiles/albert-lib.dir/link.txt new file mode 100644 index 0000000..474f465 --- /dev/null +++ b/build/CMakeFiles/albert-lib.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libalbert.so -o lib/libalbert.so CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o CMakeFiles/albert-lib.dir/src/lib/history.cpp.o CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o -Wl,-rpath,::::::: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/CMakeFiles/albert-lib.dir/progress.make b/build/CMakeFiles/albert-lib.dir/progress.make new file mode 100644 index 0000000..f151e80 --- /dev/null +++ b/build/CMakeFiles/albert-lib.dir/progress.make @@ -0,0 +1,12 @@ +CMAKE_PROGRESS_1 = 12 +CMAKE_PROGRESS_2 = +CMAKE_PROGRESS_3 = 13 +CMAKE_PROGRESS_4 = +CMAKE_PROGRESS_5 = 14 +CMAKE_PROGRESS_6 = 15 +CMAKE_PROGRESS_7 = +CMAKE_PROGRESS_8 = 16 +CMAKE_PROGRESS_9 = 17 +CMAKE_PROGRESS_10 = +CMAKE_PROGRESS_11 = 18 + diff --git a/build/CMakeFiles/albert-lib_autogen.dir/AutogenInfo.json b/build/CMakeFiles/albert-lib_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..2b5e84e --- /dev/null +++ b/build/CMakeFiles/albert-lib_autogen.dir/AutogenInfo.json @@ -0,0 +1,211 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/action.h", + "MU", + "NMUIJRV2Y4/moc_action.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/core_globals.h", + "MU", + "NMUIJRV2Y4/moc_core_globals.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/extension.h", + "MU", + "NMUIJRV2Y4/moc_extension.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/fallbackprovider.h", + "MU", + "NMUIJRV2Y4/moc_fallbackprovider.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/frontend.h", + "MU", + "NMUIJRV2Y4/moc_frontend.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/indexable.h", + "MU", + "NMUIJRV2Y4/moc_indexable.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/item.h", + "MU", + "NMUIJRV2Y4/moc_item.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/plugin.h", + "MU", + "NMUIJRV2Y4/moc_plugin.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/query.h", + "MU", + "NMUIJRV2Y4/moc_query.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/queryhandler.h", + "MU", + "NMUIJRV2Y4/moc_queryhandler.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util/history.h", + "MU", + "MFICXSPAVC/moc_history.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util/itemroles.h", + "MU", + "MFICXSPAVC/moc_itemroles.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util/offlineindex.h", + "MU", + "MFICXSPAVC/moc_offlineindex.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util/standardactions.h", + "MU", + "MFICXSPAVC/moc_standardactions.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util/standardindexitem.h", + "MU", + "MFICXSPAVC/moc_standardindexitem.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util/standarditem.h", + "MU", + "MFICXSPAVC/moc_standarditem.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.h", + "MU", + "46IEQ6DIVK/moc_fuzzysearch.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.h", + "MU", + "46IEQ6DIVK/moc_prefixsearch.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.h", + "MU", + "46IEQ6DIVK/moc_searchbase.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "CORE", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_SQL_LIB", + "albert_lib_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtSql", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/history.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/offlineindex.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/plugin.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardactions.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardindexitem.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standarditem.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/CMakeFiles/albert-lib_autogen.dir/DependInfo.cmake b/build/CMakeFiles/albert-lib_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/CMakeFiles/albert-lib_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/CMakeFiles/albert-lib_autogen.dir/build.make b/build/CMakeFiles/albert-lib_autogen.dir/build.make new file mode 100644 index 0000000..be4e0e7 --- /dev/null +++ b/build/CMakeFiles/albert-lib_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for albert-lib_autogen. + +# Include the progress variables for this target. +include CMakeFiles/albert-lib_autogen.dir/progress.make + +CMakeFiles/albert-lib_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target albert-lib" + /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib_autogen.dir/AutogenInfo.json Debug + +albert-lib_autogen: CMakeFiles/albert-lib_autogen +albert-lib_autogen: CMakeFiles/albert-lib_autogen.dir/build.make + +.PHONY : albert-lib_autogen + +# Rule to build all files generated by this target. +CMakeFiles/albert-lib_autogen.dir/build: albert-lib_autogen + +.PHONY : CMakeFiles/albert-lib_autogen.dir/build + +CMakeFiles/albert-lib_autogen.dir/clean: + $(CMAKE_COMMAND) -P CMakeFiles/albert-lib_autogen.dir/cmake_clean.cmake +.PHONY : CMakeFiles/albert-lib_autogen.dir/clean + +CMakeFiles/albert-lib_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : CMakeFiles/albert-lib_autogen.dir/depend + diff --git a/build/CMakeFiles/albert-lib_autogen.dir/cmake_clean.cmake b/build/CMakeFiles/albert-lib_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..91a5b56 --- /dev/null +++ b/build/CMakeFiles/albert-lib_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/albert-lib_autogen" + "albert-lib_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/albert-lib_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/CMakeFiles/albert-lib_autogen.dir/progress.make b/build/CMakeFiles/albert-lib_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/CMakeFiles/albert-lib_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/CMakeFiles/cmake.check_cache b/build/CMakeFiles/cmake.check_cache new file mode 100644 index 0000000..3dccd73 --- /dev/null +++ b/build/CMakeFiles/cmake.check_cache @@ -0,0 +1 @@ +# This file is generated by cmake for dependency checking of the CMakeCache.txt file diff --git a/build/CMakeFiles/progress.marks b/build/CMakeFiles/progress.marks new file mode 100644 index 0000000..29d6383 --- /dev/null +++ b/build/CMakeFiles/progress.marks @@ -0,0 +1 @@ +100 diff --git a/build/Makefile b/build/Makefile new file mode 100644 index 0000000..c7fef14 --- /dev/null +++ b/build/Makefile @@ -0,0 +1,1466 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/progress.marks + $(MAKE) -f CMakeFiles/Makefile2 all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + $(MAKE) -f CMakeFiles/Makefile2 clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + $(MAKE) -f CMakeFiles/Makefile2 preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + $(MAKE) -f CMakeFiles/Makefile2 preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +#============================================================================= +# Target rules for targets named albert-bin + +# Build rule for target. +albert-bin: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 albert-bin +.PHONY : albert-bin + +# fast build rule for target. +albert-bin/fast: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/build +.PHONY : albert-bin/fast + +#============================================================================= +# Target rules for targets named albert-lib + +# Build rule for target. +albert-lib: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 albert-lib +.PHONY : albert-lib + +# fast build rule for target. +albert-lib/fast: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/build +.PHONY : albert-lib/fast + +#============================================================================= +# Target rules for targets named albert-bin_autogen + +# Build rule for target. +albert-bin_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 albert-bin_autogen +.PHONY : albert-bin_autogen + +# fast build rule for target. +albert-bin_autogen/fast: + $(MAKE) -f CMakeFiles/albert-bin_autogen.dir/build.make CMakeFiles/albert-bin_autogen.dir/build +.PHONY : albert-bin_autogen/fast + +#============================================================================= +# Target rules for targets named albert-lib_autogen + +# Build rule for target. +albert-lib_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 albert-lib_autogen +.PHONY : albert-lib_autogen + +# fast build rule for target. +albert-lib_autogen/fast: + $(MAKE) -f CMakeFiles/albert-lib_autogen.dir/build.make CMakeFiles/albert-lib_autogen.dir/build +.PHONY : albert-lib_autogen/fast + +#============================================================================= +# Target rules for targets named globalshortcut + +# Build rule for target. +globalshortcut: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 globalshortcut +.PHONY : globalshortcut + +# fast build rule for target. +globalshortcut/fast: + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/build +.PHONY : globalshortcut/fast + +#============================================================================= +# Target rules for targets named globalshortcut_autogen + +# Build rule for target. +globalshortcut_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 globalshortcut_autogen +.PHONY : globalshortcut_autogen + +# fast build rule for target. +globalshortcut_autogen/fast: + $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build +.PHONY : globalshortcut_autogen/fast + +#============================================================================= +# Target rules for targets named xdg + +# Build rule for target. +xdg: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 xdg +.PHONY : xdg + +# fast build rule for target. +xdg/fast: + $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/build +.PHONY : xdg/fast + +#============================================================================= +# Target rules for targets named xdg_autogen + +# Build rule for target. +xdg_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 xdg_autogen +.PHONY : xdg_autogen + +# fast build rule for target. +xdg_autogen/fast: + $(MAKE) -f lib/xdg/CMakeFiles/xdg_autogen.dir/build.make lib/xdg/CMakeFiles/xdg_autogen.dir/build +.PHONY : xdg_autogen/fast + +#============================================================================= +# Target rules for targets named widgetboxmodel + +# Build rule for target. +widgetboxmodel: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 widgetboxmodel +.PHONY : widgetboxmodel + +# fast build rule for target. +widgetboxmodel/fast: + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build +.PHONY : widgetboxmodel/fast + +#============================================================================= +# Target rules for targets named widgetboxmodel_autogen + +# Build rule for target. +widgetboxmodel_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 widgetboxmodel_autogen +.PHONY : widgetboxmodel_autogen + +# fast build rule for target. +widgetboxmodel_autogen/fast: + $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build +.PHONY : widgetboxmodel_autogen/fast + +#============================================================================= +# Target rules for targets named qmlboxmodel + +# Build rule for target. +qmlboxmodel: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 qmlboxmodel +.PHONY : qmlboxmodel + +# fast build rule for target. +qmlboxmodel/fast: + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build +.PHONY : qmlboxmodel/fast + +#============================================================================= +# Target rules for targets named qmlboxmodel_autogen + +# Build rule for target. +qmlboxmodel_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 qmlboxmodel_autogen +.PHONY : qmlboxmodel_autogen + +# fast build rule for target. +qmlboxmodel_autogen/fast: + $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build +.PHONY : qmlboxmodel_autogen/fast + +#============================================================================= +# Target rules for targets named applications + +# Build rule for target. +applications: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 applications +.PHONY : applications + +# fast build rule for target. +applications/fast: + $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/build +.PHONY : applications/fast + +#============================================================================= +# Target rules for targets named applications_autogen + +# Build rule for target. +applications_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 applications_autogen +.PHONY : applications_autogen + +# fast build rule for target. +applications_autogen/fast: + $(MAKE) -f plugins/applications/CMakeFiles/applications_autogen.dir/build.make plugins/applications/CMakeFiles/applications_autogen.dir/build +.PHONY : applications_autogen/fast + +#============================================================================= +# Target rules for targets named calculator + +# Build rule for target. +calculator: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 calculator +.PHONY : calculator + +# fast build rule for target. +calculator/fast: + $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/build +.PHONY : calculator/fast + +#============================================================================= +# Target rules for targets named calculator_autogen + +# Build rule for target. +calculator_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 calculator_autogen +.PHONY : calculator_autogen + +# fast build rule for target. +calculator_autogen/fast: + $(MAKE) -f plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make plugins/calculator/CMakeFiles/calculator_autogen.dir/build +.PHONY : calculator_autogen/fast + +#============================================================================= +# Target rules for targets named chromium + +# Build rule for target. +chromium: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 chromium +.PHONY : chromium + +# fast build rule for target. +chromium/fast: + $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/build +.PHONY : chromium/fast + +#============================================================================= +# Target rules for targets named chromium_autogen + +# Build rule for target. +chromium_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 chromium_autogen +.PHONY : chromium_autogen + +# fast build rule for target. +chromium_autogen/fast: + $(MAKE) -f plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make plugins/chromium/CMakeFiles/chromium_autogen.dir/build +.PHONY : chromium_autogen/fast + +#============================================================================= +# Target rules for targets named files + +# Build rule for target. +files: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 files +.PHONY : files + +# fast build rule for target. +files/fast: + $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/build +.PHONY : files/fast + +#============================================================================= +# Target rules for targets named files_autogen + +# Build rule for target. +files_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 files_autogen +.PHONY : files_autogen + +# fast build rule for target. +files_autogen/fast: + $(MAKE) -f plugins/files/CMakeFiles/files_autogen.dir/build.make plugins/files/CMakeFiles/files_autogen.dir/build +.PHONY : files_autogen/fast + +#============================================================================= +# Target rules for targets named firefoxbookmarks + +# Build rule for target. +firefoxbookmarks: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 firefoxbookmarks +.PHONY : firefoxbookmarks + +# fast build rule for target. +firefoxbookmarks/fast: + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build +.PHONY : firefoxbookmarks/fast + +#============================================================================= +# Target rules for targets named firefoxbookmarks_autogen + +# Build rule for target. +firefoxbookmarks_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 firefoxbookmarks_autogen +.PHONY : firefoxbookmarks_autogen + +# fast build rule for target. +firefoxbookmarks_autogen/fast: + $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build +.PHONY : firefoxbookmarks_autogen/fast + +#============================================================================= +# Target rules for targets named hashgenerator + +# Build rule for target. +hashgenerator: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 hashgenerator +.PHONY : hashgenerator + +# fast build rule for target. +hashgenerator/fast: + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build +.PHONY : hashgenerator/fast + +#============================================================================= +# Target rules for targets named hashgenerator_autogen + +# Build rule for target. +hashgenerator_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 hashgenerator_autogen +.PHONY : hashgenerator_autogen + +# fast build rule for target. +hashgenerator_autogen/fast: + $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build +.PHONY : hashgenerator_autogen/fast + +#============================================================================= +# Target rules for targets named mpris + +# Build rule for target. +mpris: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 mpris +.PHONY : mpris + +# fast build rule for target. +mpris/fast: + $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/build +.PHONY : mpris/fast + +#============================================================================= +# Target rules for targets named mpris_autogen + +# Build rule for target. +mpris_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 mpris_autogen +.PHONY : mpris_autogen + +# fast build rule for target. +mpris_autogen/fast: + $(MAKE) -f plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make plugins/mpris/CMakeFiles/mpris_autogen.dir/build +.PHONY : mpris_autogen/fast + +#============================================================================= +# Target rules for targets named python + +# Build rule for target. +python: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 python +.PHONY : python + +# fast build rule for target. +python/fast: + $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/build +.PHONY : python/fast + +#============================================================================= +# Target rules for targets named python_autogen + +# Build rule for target. +python_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 python_autogen +.PHONY : python_autogen + +# fast build rule for target. +python_autogen/fast: + $(MAKE) -f plugins/python/CMakeFiles/python_autogen.dir/build.make plugins/python/CMakeFiles/python_autogen.dir/build +.PHONY : python_autogen/fast + +#============================================================================= +# Target rules for targets named snippets + +# Build rule for target. +snippets: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 snippets +.PHONY : snippets + +# fast build rule for target. +snippets/fast: + $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/build +.PHONY : snippets/fast + +#============================================================================= +# Target rules for targets named snippets_autogen + +# Build rule for target. +snippets_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 snippets_autogen +.PHONY : snippets_autogen + +# fast build rule for target. +snippets_autogen/fast: + $(MAKE) -f plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make plugins/snippets/CMakeFiles/snippets_autogen.dir/build +.PHONY : snippets_autogen/fast + +#============================================================================= +# Target rules for targets named ssh + +# Build rule for target. +ssh: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 ssh +.PHONY : ssh + +# fast build rule for target. +ssh/fast: + $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/build +.PHONY : ssh/fast + +#============================================================================= +# Target rules for targets named ssh_autogen + +# Build rule for target. +ssh_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 ssh_autogen +.PHONY : ssh_autogen + +# fast build rule for target. +ssh_autogen/fast: + $(MAKE) -f plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make plugins/ssh/CMakeFiles/ssh_autogen.dir/build +.PHONY : ssh_autogen/fast + +#============================================================================= +# Target rules for targets named system + +# Build rule for target. +system: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 system +.PHONY : system + +# fast build rule for target. +system/fast: + $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/build +.PHONY : system/fast + +#============================================================================= +# Target rules for targets named system_autogen + +# Build rule for target. +system_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 system_autogen +.PHONY : system_autogen + +# fast build rule for target. +system_autogen/fast: + $(MAKE) -f plugins/system/CMakeFiles/system_autogen.dir/build.make plugins/system/CMakeFiles/system_autogen.dir/build +.PHONY : system_autogen/fast + +#============================================================================= +# Target rules for targets named terminal + +# Build rule for target. +terminal: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 terminal +.PHONY : terminal + +# fast build rule for target. +terminal/fast: + $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/build +.PHONY : terminal/fast + +#============================================================================= +# Target rules for targets named terminal_autogen + +# Build rule for target. +terminal_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 terminal_autogen +.PHONY : terminal_autogen + +# fast build rule for target. +terminal_autogen/fast: + $(MAKE) -f plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make plugins/terminal/CMakeFiles/terminal_autogen.dir/build +.PHONY : terminal_autogen/fast + +#============================================================================= +# Target rules for targets named websearch + +# Build rule for target. +websearch: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 websearch +.PHONY : websearch + +# fast build rule for target. +websearch/fast: + $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/build +.PHONY : websearch/fast + +#============================================================================= +# Target rules for targets named websearch_autogen + +# Build rule for target. +websearch_autogen: cmake_check_build_system + $(MAKE) -f CMakeFiles/Makefile2 websearch_autogen +.PHONY : websearch_autogen + +# fast build rule for target. +websearch_autogen/fast: + $(MAKE) -f plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make plugins/websearch/CMakeFiles/websearch_autogen.dir/build +.PHONY : websearch_autogen/fast + +albert-bin_autogen/EWIEGA46WW/qrc_resources.o: albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o + +.PHONY : albert-bin_autogen/EWIEGA46WW/qrc_resources.o + +# target to build an object file +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o +.PHONY : albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o + +albert-bin_autogen/EWIEGA46WW/qrc_resources.i: albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.i + +.PHONY : albert-bin_autogen/EWIEGA46WW/qrc_resources.i + +# target to preprocess a source file +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.i +.PHONY : albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.i + +albert-bin_autogen/EWIEGA46WW/qrc_resources.s: albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.s + +.PHONY : albert-bin_autogen/EWIEGA46WW/qrc_resources.s + +# target to generate assembly for a file +albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.s +.PHONY : albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.s + +albert-bin_autogen/mocs_compilation.o: albert-bin_autogen/mocs_compilation.cpp.o + +.PHONY : albert-bin_autogen/mocs_compilation.o + +# target to build an object file +albert-bin_autogen/mocs_compilation.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o +.PHONY : albert-bin_autogen/mocs_compilation.cpp.o + +albert-bin_autogen/mocs_compilation.i: albert-bin_autogen/mocs_compilation.cpp.i + +.PHONY : albert-bin_autogen/mocs_compilation.i + +# target to preprocess a source file +albert-bin_autogen/mocs_compilation.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.i +.PHONY : albert-bin_autogen/mocs_compilation.cpp.i + +albert-bin_autogen/mocs_compilation.s: albert-bin_autogen/mocs_compilation.cpp.s + +.PHONY : albert-bin_autogen/mocs_compilation.s + +# target to generate assembly for a file +albert-bin_autogen/mocs_compilation.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.s +.PHONY : albert-bin_autogen/mocs_compilation.cpp.s + +albert-lib_autogen/mocs_compilation.o: albert-lib_autogen/mocs_compilation.cpp.o + +.PHONY : albert-lib_autogen/mocs_compilation.o + +# target to build an object file +albert-lib_autogen/mocs_compilation.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o +.PHONY : albert-lib_autogen/mocs_compilation.cpp.o + +albert-lib_autogen/mocs_compilation.i: albert-lib_autogen/mocs_compilation.cpp.i + +.PHONY : albert-lib_autogen/mocs_compilation.i + +# target to preprocess a source file +albert-lib_autogen/mocs_compilation.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.i +.PHONY : albert-lib_autogen/mocs_compilation.cpp.i + +albert-lib_autogen/mocs_compilation.s: albert-lib_autogen/mocs_compilation.cpp.s + +.PHONY : albert-lib_autogen/mocs_compilation.s + +# target to generate assembly for a file +albert-lib_autogen/mocs_compilation.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.s +.PHONY : albert-lib_autogen/mocs_compilation.cpp.s + +src/app/extension.o: src/app/extension.cpp.o + +.PHONY : src/app/extension.o + +# target to build an object file +src/app/extension.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/extension.cpp.o +.PHONY : src/app/extension.cpp.o + +src/app/extension.i: src/app/extension.cpp.i + +.PHONY : src/app/extension.i + +# target to preprocess a source file +src/app/extension.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/extension.cpp.i +.PHONY : src/app/extension.cpp.i + +src/app/extension.s: src/app/extension.cpp.s + +.PHONY : src/app/extension.s + +# target to generate assembly for a file +src/app/extension.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/extension.cpp.s +.PHONY : src/app/extension.cpp.s + +src/app/extensionmanager.o: src/app/extensionmanager.cpp.o + +.PHONY : src/app/extensionmanager.o + +# target to build an object file +src/app/extensionmanager.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o +.PHONY : src/app/extensionmanager.cpp.o + +src/app/extensionmanager.i: src/app/extensionmanager.cpp.i + +.PHONY : src/app/extensionmanager.i + +# target to preprocess a source file +src/app/extensionmanager.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.i +.PHONY : src/app/extensionmanager.cpp.i + +src/app/extensionmanager.s: src/app/extensionmanager.cpp.s + +.PHONY : src/app/extensionmanager.s + +# target to generate assembly for a file +src/app/extensionmanager.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.s +.PHONY : src/app/extensionmanager.cpp.s + +src/app/frontendmanager.o: src/app/frontendmanager.cpp.o + +.PHONY : src/app/frontendmanager.o + +# target to build an object file +src/app/frontendmanager.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o +.PHONY : src/app/frontendmanager.cpp.o + +src/app/frontendmanager.i: src/app/frontendmanager.cpp.i + +.PHONY : src/app/frontendmanager.i + +# target to preprocess a source file +src/app/frontendmanager.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.i +.PHONY : src/app/frontendmanager.cpp.i + +src/app/frontendmanager.s: src/app/frontendmanager.cpp.s + +.PHONY : src/app/frontendmanager.s + +# target to generate assembly for a file +src/app/frontendmanager.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.s +.PHONY : src/app/frontendmanager.cpp.s + +src/app/main.o: src/app/main.cpp.o + +.PHONY : src/app/main.o + +# target to build an object file +src/app/main.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/main.cpp.o +.PHONY : src/app/main.cpp.o + +src/app/main.i: src/app/main.cpp.i + +.PHONY : src/app/main.i + +# target to preprocess a source file +src/app/main.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/main.cpp.i +.PHONY : src/app/main.cpp.i + +src/app/main.s: src/app/main.cpp.s + +.PHONY : src/app/main.s + +# target to generate assembly for a file +src/app/main.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/main.cpp.s +.PHONY : src/app/main.cpp.s + +src/app/pluginspec.o: src/app/pluginspec.cpp.o + +.PHONY : src/app/pluginspec.o + +# target to build an object file +src/app/pluginspec.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o +.PHONY : src/app/pluginspec.cpp.o + +src/app/pluginspec.i: src/app/pluginspec.cpp.i + +.PHONY : src/app/pluginspec.i + +# target to preprocess a source file +src/app/pluginspec.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.i +.PHONY : src/app/pluginspec.cpp.i + +src/app/pluginspec.s: src/app/pluginspec.cpp.s + +.PHONY : src/app/pluginspec.s + +# target to generate assembly for a file +src/app/pluginspec.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.s +.PHONY : src/app/pluginspec.cpp.s + +src/app/query.o: src/app/query.cpp.o + +.PHONY : src/app/query.o + +# target to build an object file +src/app/query.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/query.cpp.o +.PHONY : src/app/query.cpp.o + +src/app/query.i: src/app/query.cpp.i + +.PHONY : src/app/query.i + +# target to preprocess a source file +src/app/query.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/query.cpp.i +.PHONY : src/app/query.cpp.i + +src/app/query.s: src/app/query.cpp.s + +.PHONY : src/app/query.s + +# target to generate assembly for a file +src/app/query.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/query.cpp.s +.PHONY : src/app/query.cpp.s + +src/app/queryexecution.o: src/app/queryexecution.cpp.o + +.PHONY : src/app/queryexecution.o + +# target to build an object file +src/app/queryexecution.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o +.PHONY : src/app/queryexecution.cpp.o + +src/app/queryexecution.i: src/app/queryexecution.cpp.i + +.PHONY : src/app/queryexecution.i + +# target to preprocess a source file +src/app/queryexecution.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.i +.PHONY : src/app/queryexecution.cpp.i + +src/app/queryexecution.s: src/app/queryexecution.cpp.s + +.PHONY : src/app/queryexecution.s + +# target to generate assembly for a file +src/app/queryexecution.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.s +.PHONY : src/app/queryexecution.cpp.s + +src/app/querymanager.o: src/app/querymanager.cpp.o + +.PHONY : src/app/querymanager.o + +# target to build an object file +src/app/querymanager.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o +.PHONY : src/app/querymanager.cpp.o + +src/app/querymanager.i: src/app/querymanager.cpp.i + +.PHONY : src/app/querymanager.i + +# target to preprocess a source file +src/app/querymanager.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.i +.PHONY : src/app/querymanager.cpp.i + +src/app/querymanager.s: src/app/querymanager.cpp.s + +.PHONY : src/app/querymanager.s + +# target to generate assembly for a file +src/app/querymanager.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.s +.PHONY : src/app/querymanager.cpp.s + +src/app/settingswidget/grabkeybutton.o: src/app/settingswidget/grabkeybutton.cpp.o + +.PHONY : src/app/settingswidget/grabkeybutton.o + +# target to build an object file +src/app/settingswidget/grabkeybutton.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o +.PHONY : src/app/settingswidget/grabkeybutton.cpp.o + +src/app/settingswidget/grabkeybutton.i: src/app/settingswidget/grabkeybutton.cpp.i + +.PHONY : src/app/settingswidget/grabkeybutton.i + +# target to preprocess a source file +src/app/settingswidget/grabkeybutton.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.i +.PHONY : src/app/settingswidget/grabkeybutton.cpp.i + +src/app/settingswidget/grabkeybutton.s: src/app/settingswidget/grabkeybutton.cpp.s + +.PHONY : src/app/settingswidget/grabkeybutton.s + +# target to generate assembly for a file +src/app/settingswidget/grabkeybutton.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.s +.PHONY : src/app/settingswidget/grabkeybutton.cpp.s + +src/app/settingswidget/loadermodel.o: src/app/settingswidget/loadermodel.cpp.o + +.PHONY : src/app/settingswidget/loadermodel.o + +# target to build an object file +src/app/settingswidget/loadermodel.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o +.PHONY : src/app/settingswidget/loadermodel.cpp.o + +src/app/settingswidget/loadermodel.i: src/app/settingswidget/loadermodel.cpp.i + +.PHONY : src/app/settingswidget/loadermodel.i + +# target to preprocess a source file +src/app/settingswidget/loadermodel.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.i +.PHONY : src/app/settingswidget/loadermodel.cpp.i + +src/app/settingswidget/loadermodel.s: src/app/settingswidget/loadermodel.cpp.s + +.PHONY : src/app/settingswidget/loadermodel.s + +# target to generate assembly for a file +src/app/settingswidget/loadermodel.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.s +.PHONY : src/app/settingswidget/loadermodel.cpp.s + +src/app/settingswidget/settingswidget.o: src/app/settingswidget/settingswidget.cpp.o + +.PHONY : src/app/settingswidget/settingswidget.o + +# target to build an object file +src/app/settingswidget/settingswidget.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o +.PHONY : src/app/settingswidget/settingswidget.cpp.o + +src/app/settingswidget/settingswidget.i: src/app/settingswidget/settingswidget.cpp.i + +.PHONY : src/app/settingswidget/settingswidget.i + +# target to preprocess a source file +src/app/settingswidget/settingswidget.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.i +.PHONY : src/app/settingswidget/settingswidget.cpp.i + +src/app/settingswidget/settingswidget.s: src/app/settingswidget/settingswidget.cpp.s + +.PHONY : src/app/settingswidget/settingswidget.s + +# target to generate assembly for a file +src/app/settingswidget/settingswidget.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.s +.PHONY : src/app/settingswidget/settingswidget.cpp.s + +src/app/settingswidget/statswidget.o: src/app/settingswidget/statswidget.cpp.o + +.PHONY : src/app/settingswidget/statswidget.o + +# target to build an object file +src/app/settingswidget/statswidget.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o +.PHONY : src/app/settingswidget/statswidget.cpp.o + +src/app/settingswidget/statswidget.i: src/app/settingswidget/statswidget.cpp.i + +.PHONY : src/app/settingswidget/statswidget.i + +# target to preprocess a source file +src/app/settingswidget/statswidget.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.i +.PHONY : src/app/settingswidget/statswidget.cpp.i + +src/app/settingswidget/statswidget.s: src/app/settingswidget/statswidget.cpp.s + +.PHONY : src/app/settingswidget/statswidget.s + +# target to generate assembly for a file +src/app/settingswidget/statswidget.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.s +.PHONY : src/app/settingswidget/statswidget.cpp.s + +src/app/trayicon.o: src/app/trayicon.cpp.o + +.PHONY : src/app/trayicon.o + +# target to build an object file +src/app/trayicon.cpp.o: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o +.PHONY : src/app/trayicon.cpp.o + +src/app/trayicon.i: src/app/trayicon.cpp.i + +.PHONY : src/app/trayicon.i + +# target to preprocess a source file +src/app/trayicon.cpp.i: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.i +.PHONY : src/app/trayicon.cpp.i + +src/app/trayicon.s: src/app/trayicon.cpp.s + +.PHONY : src/app/trayicon.s + +# target to generate assembly for a file +src/app/trayicon.cpp.s: + $(MAKE) -f CMakeFiles/albert-bin.dir/build.make CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.s +.PHONY : src/app/trayicon.cpp.s + +src/lib/fuzzysearch.o: src/lib/fuzzysearch.cpp.o + +.PHONY : src/lib/fuzzysearch.o + +# target to build an object file +src/lib/fuzzysearch.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o +.PHONY : src/lib/fuzzysearch.cpp.o + +src/lib/fuzzysearch.i: src/lib/fuzzysearch.cpp.i + +.PHONY : src/lib/fuzzysearch.i + +# target to preprocess a source file +src/lib/fuzzysearch.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.i +.PHONY : src/lib/fuzzysearch.cpp.i + +src/lib/fuzzysearch.s: src/lib/fuzzysearch.cpp.s + +.PHONY : src/lib/fuzzysearch.s + +# target to generate assembly for a file +src/lib/fuzzysearch.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.s +.PHONY : src/lib/fuzzysearch.cpp.s + +src/lib/history.o: src/lib/history.cpp.o + +.PHONY : src/lib/history.o + +# target to build an object file +src/lib/history.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/history.cpp.o +.PHONY : src/lib/history.cpp.o + +src/lib/history.i: src/lib/history.cpp.i + +.PHONY : src/lib/history.i + +# target to preprocess a source file +src/lib/history.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/history.cpp.i +.PHONY : src/lib/history.cpp.i + +src/lib/history.s: src/lib/history.cpp.s + +.PHONY : src/lib/history.s + +# target to generate assembly for a file +src/lib/history.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/history.cpp.s +.PHONY : src/lib/history.cpp.s + +src/lib/offlineindex.o: src/lib/offlineindex.cpp.o + +.PHONY : src/lib/offlineindex.o + +# target to build an object file +src/lib/offlineindex.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o +.PHONY : src/lib/offlineindex.cpp.o + +src/lib/offlineindex.i: src/lib/offlineindex.cpp.i + +.PHONY : src/lib/offlineindex.i + +# target to preprocess a source file +src/lib/offlineindex.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.i +.PHONY : src/lib/offlineindex.cpp.i + +src/lib/offlineindex.s: src/lib/offlineindex.cpp.s + +.PHONY : src/lib/offlineindex.s + +# target to generate assembly for a file +src/lib/offlineindex.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.s +.PHONY : src/lib/offlineindex.cpp.s + +src/lib/plugin.o: src/lib/plugin.cpp.o + +.PHONY : src/lib/plugin.o + +# target to build an object file +src/lib/plugin.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o +.PHONY : src/lib/plugin.cpp.o + +src/lib/plugin.i: src/lib/plugin.cpp.i + +.PHONY : src/lib/plugin.i + +# target to preprocess a source file +src/lib/plugin.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.i +.PHONY : src/lib/plugin.cpp.i + +src/lib/plugin.s: src/lib/plugin.cpp.s + +.PHONY : src/lib/plugin.s + +# target to generate assembly for a file +src/lib/plugin.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.s +.PHONY : src/lib/plugin.cpp.s + +src/lib/prefixsearch.o: src/lib/prefixsearch.cpp.o + +.PHONY : src/lib/prefixsearch.o + +# target to build an object file +src/lib/prefixsearch.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o +.PHONY : src/lib/prefixsearch.cpp.o + +src/lib/prefixsearch.i: src/lib/prefixsearch.cpp.i + +.PHONY : src/lib/prefixsearch.i + +# target to preprocess a source file +src/lib/prefixsearch.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.i +.PHONY : src/lib/prefixsearch.cpp.i + +src/lib/prefixsearch.s: src/lib/prefixsearch.cpp.s + +.PHONY : src/lib/prefixsearch.s + +# target to generate assembly for a file +src/lib/prefixsearch.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.s +.PHONY : src/lib/prefixsearch.cpp.s + +src/lib/searchbase.o: src/lib/searchbase.cpp.o + +.PHONY : src/lib/searchbase.o + +# target to build an object file +src/lib/searchbase.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o +.PHONY : src/lib/searchbase.cpp.o + +src/lib/searchbase.i: src/lib/searchbase.cpp.i + +.PHONY : src/lib/searchbase.i + +# target to preprocess a source file +src/lib/searchbase.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.i +.PHONY : src/lib/searchbase.cpp.i + +src/lib/searchbase.s: src/lib/searchbase.cpp.s + +.PHONY : src/lib/searchbase.s + +# target to generate assembly for a file +src/lib/searchbase.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.s +.PHONY : src/lib/searchbase.cpp.s + +src/lib/standardactions.o: src/lib/standardactions.cpp.o + +.PHONY : src/lib/standardactions.o + +# target to build an object file +src/lib/standardactions.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o +.PHONY : src/lib/standardactions.cpp.o + +src/lib/standardactions.i: src/lib/standardactions.cpp.i + +.PHONY : src/lib/standardactions.i + +# target to preprocess a source file +src/lib/standardactions.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.i +.PHONY : src/lib/standardactions.cpp.i + +src/lib/standardactions.s: src/lib/standardactions.cpp.s + +.PHONY : src/lib/standardactions.s + +# target to generate assembly for a file +src/lib/standardactions.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.s +.PHONY : src/lib/standardactions.cpp.s + +src/lib/standardindexitem.o: src/lib/standardindexitem.cpp.o + +.PHONY : src/lib/standardindexitem.o + +# target to build an object file +src/lib/standardindexitem.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o +.PHONY : src/lib/standardindexitem.cpp.o + +src/lib/standardindexitem.i: src/lib/standardindexitem.cpp.i + +.PHONY : src/lib/standardindexitem.i + +# target to preprocess a source file +src/lib/standardindexitem.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.i +.PHONY : src/lib/standardindexitem.cpp.i + +src/lib/standardindexitem.s: src/lib/standardindexitem.cpp.s + +.PHONY : src/lib/standardindexitem.s + +# target to generate assembly for a file +src/lib/standardindexitem.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.s +.PHONY : src/lib/standardindexitem.cpp.s + +src/lib/standarditem.o: src/lib/standarditem.cpp.o + +.PHONY : src/lib/standarditem.o + +# target to build an object file +src/lib/standarditem.cpp.o: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o +.PHONY : src/lib/standarditem.cpp.o + +src/lib/standarditem.i: src/lib/standarditem.cpp.i + +.PHONY : src/lib/standarditem.i + +# target to preprocess a source file +src/lib/standarditem.cpp.i: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.i +.PHONY : src/lib/standarditem.cpp.i + +src/lib/standarditem.s: src/lib/standarditem.cpp.s + +.PHONY : src/lib/standarditem.s + +# target to generate assembly for a file +src/lib/standarditem.cpp.s: + $(MAKE) -f CMakeFiles/albert-lib.dir/build.make CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.s +.PHONY : src/lib/standarditem.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... albert-bin" + @echo "... albert-lib" + @echo "... albert-bin_autogen" + @echo "... albert-lib_autogen" + @echo "... globalshortcut" + @echo "... globalshortcut_autogen" + @echo "... xdg" + @echo "... xdg_autogen" + @echo "... widgetboxmodel" + @echo "... widgetboxmodel_autogen" + @echo "... qmlboxmodel" + @echo "... qmlboxmodel_autogen" + @echo "... applications" + @echo "... applications_autogen" + @echo "... calculator" + @echo "... calculator_autogen" + @echo "... chromium" + @echo "... chromium_autogen" + @echo "... files" + @echo "... files_autogen" + @echo "... firefoxbookmarks" + @echo "... firefoxbookmarks_autogen" + @echo "... hashgenerator" + @echo "... hashgenerator_autogen" + @echo "... mpris" + @echo "... mpris_autogen" + @echo "... python" + @echo "... python_autogen" + @echo "... snippets" + @echo "... snippets_autogen" + @echo "... ssh" + @echo "... ssh_autogen" + @echo "... system" + @echo "... system_autogen" + @echo "... terminal" + @echo "... terminal_autogen" + @echo "... websearch" + @echo "... websearch_autogen" + @echo "... albert-bin_autogen/EWIEGA46WW/qrc_resources.o" + @echo "... albert-bin_autogen/EWIEGA46WW/qrc_resources.i" + @echo "... albert-bin_autogen/EWIEGA46WW/qrc_resources.s" + @echo "... albert-bin_autogen/mocs_compilation.o" + @echo "... albert-bin_autogen/mocs_compilation.i" + @echo "... albert-bin_autogen/mocs_compilation.s" + @echo "... albert-lib_autogen/mocs_compilation.o" + @echo "... albert-lib_autogen/mocs_compilation.i" + @echo "... albert-lib_autogen/mocs_compilation.s" + @echo "... src/app/extension.o" + @echo "... src/app/extension.i" + @echo "... src/app/extension.s" + @echo "... src/app/extensionmanager.o" + @echo "... src/app/extensionmanager.i" + @echo "... src/app/extensionmanager.s" + @echo "... src/app/frontendmanager.o" + @echo "... src/app/frontendmanager.i" + @echo "... src/app/frontendmanager.s" + @echo "... src/app/main.o" + @echo "... src/app/main.i" + @echo "... src/app/main.s" + @echo "... src/app/pluginspec.o" + @echo "... src/app/pluginspec.i" + @echo "... src/app/pluginspec.s" + @echo "... src/app/query.o" + @echo "... src/app/query.i" + @echo "... src/app/query.s" + @echo "... src/app/queryexecution.o" + @echo "... src/app/queryexecution.i" + @echo "... src/app/queryexecution.s" + @echo "... src/app/querymanager.o" + @echo "... src/app/querymanager.i" + @echo "... src/app/querymanager.s" + @echo "... src/app/settingswidget/grabkeybutton.o" + @echo "... src/app/settingswidget/grabkeybutton.i" + @echo "... src/app/settingswidget/grabkeybutton.s" + @echo "... src/app/settingswidget/loadermodel.o" + @echo "... src/app/settingswidget/loadermodel.i" + @echo "... src/app/settingswidget/loadermodel.s" + @echo "... src/app/settingswidget/settingswidget.o" + @echo "... src/app/settingswidget/settingswidget.i" + @echo "... src/app/settingswidget/settingswidget.s" + @echo "... src/app/settingswidget/statswidget.o" + @echo "... src/app/settingswidget/statswidget.i" + @echo "... src/app/settingswidget/statswidget.s" + @echo "... src/app/trayicon.o" + @echo "... src/app/trayicon.i" + @echo "... src/app/trayicon.s" + @echo "... src/lib/fuzzysearch.o" + @echo "... src/lib/fuzzysearch.i" + @echo "... src/lib/fuzzysearch.s" + @echo "... src/lib/history.o" + @echo "... src/lib/history.i" + @echo "... src/lib/history.s" + @echo "... src/lib/offlineindex.o" + @echo "... src/lib/offlineindex.i" + @echo "... src/lib/offlineindex.s" + @echo "... src/lib/plugin.o" + @echo "... src/lib/plugin.i" + @echo "... src/lib/plugin.s" + @echo "... src/lib/prefixsearch.o" + @echo "... src/lib/prefixsearch.i" + @echo "... src/lib/prefixsearch.s" + @echo "... src/lib/searchbase.o" + @echo "... src/lib/searchbase.i" + @echo "... src/lib/searchbase.s" + @echo "... src/lib/standardactions.o" + @echo "... src/lib/standardactions.i" + @echo "... src/lib/standardactions.s" + @echo "... src/lib/standardindexitem.o" + @echo "... src/lib/standardindexitem.i" + @echo "... src/lib/standardindexitem.s" + @echo "... src/lib/standarditem.o" + @echo "... src/lib/standarditem.i" + @echo "... src/lib/standarditem.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/cmake_install.cmake b/build/cmake_install.cmake new file mode 100644 index 0000000..d140ecb --- /dev/null +++ b/build/cmake_install.cmake @@ -0,0 +1,112 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libalbert.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libalbert.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libalbert.so" + RPATH "$ORIGIN") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libalbert.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libalbert.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libalbert.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libalbert.so" + OLD_RPATH ":::::::" + NEW_RPATH "$ORIGIN") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libalbert.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/albert" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/albert") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/albert" + RPATH "$ORIGIN/../lib/albert/") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/bin" TYPE EXECUTABLE FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/bin/albert") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/albert" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/albert") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/albert" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../lib/albert/") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/albert") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/share/icons/hicolor/scalable/apps" TYPE FILE FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/resources/icons/albert.svg") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/etc" TYPE DIRECTORY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/hamonikr/etc/") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/share/applications" TYPE FILE FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/hamonikr/albert.desktop") +endif() + +if(NOT CMAKE_INSTALL_LOCAL_ONLY) + # Include the install script for each subdirectory. + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/cmake_install.cmake") + +endif() + +if(CMAKE_INSTALL_COMPONENT) + set(CMAKE_INSTALL_MANIFEST "install_manifest_${CMAKE_INSTALL_COMPONENT}.txt") +else() + set(CMAKE_INSTALL_MANIFEST "install_manifest.txt") +endif() + +string(REPLACE ";" "\n" CMAKE_INSTALL_MANIFEST_CONTENT + "${CMAKE_INSTALL_MANIFEST_FILES}") +file(WRITE "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/${CMAKE_INSTALL_MANIFEST}" + "${CMAKE_INSTALL_MANIFEST_CONTENT}") diff --git a/build/compile_commands.json b/build/compile_commands.json new file mode 100644 index 0000000..271e30c --- /dev/null +++ b/build/compile_commands.json @@ -0,0 +1,532 @@ +[ +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/albert-bin_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/extensionmanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/extensionmanager.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/frontendmanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/frontendmanager.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/main.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/main.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/main.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/pluginspec.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/pluginspec.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/query.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/query.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/query.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/queryexecution.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/queryexecution.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/querymanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/querymanager.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/settingswidget/grabkeybutton.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/grabkeybutton.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/settingswidget/loadermodel.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/loadermodel.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/settingswidget/settingswidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/settingswidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/settingswidget/statswidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget/statswidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/src/app/trayicon.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/trayicon.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DBUILD_WITH_QTCHARTS -DMULTIARCH_TUPLE=\\\"x86_64-linux-gnu\\\" -DQT_CHARTS_LIB -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/app/settingswidget -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -isystem /usr/include/x86_64-linux-gnu/qt5/QtCharts -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/albert-bin.dir/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-bin_autogen/EWIEGA46WW/qrc_resources.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/albert-lib_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/fuzzysearch.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/fuzzysearch.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/history.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/history.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/history.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/offlineindex.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/offlineindex.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/offlineindex.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/plugin.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/plugin.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/plugin.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/prefixsearch.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/prefixsearch.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/searchbase.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/searchbase.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/standardactions.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardactions.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardactions.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/standardindexitem.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardindexitem.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standardindexitem.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DCORE -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -Dalbert_lib_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build -I/home/hamonikr/workspaces/tmp/albert-0.17.2 -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/albert-lib_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include/albert/util -I/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/albert-lib.dir/src/lib/standarditem.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standarditem.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/src/lib/standarditem.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DGLOBALSHORTCUT -DQT_CORE_LIB -DQT_GUI_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DGLOBALSHORTCUT -DQT_CORE_LIB -DQT_GUI_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DGLOBALSHORTCUT -DQT_CORE_LIB -DQT_GUI_LIB -DQT_X11EXTRAS_LIB -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 -o CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DXDG_DEF -Dxdg_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DXDG_DEF -Dxdg_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/xdg.dir/src/iconlookup.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/iconlookup.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/iconlookup.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DXDG_DEF -Dxdg_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 -o CMakeFiles/xdg.dir/src/themefileparser.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_QML_LIB -DQT_QUICK_LIB -DQT_WIDGETS_LIB -Dqmlboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtQml -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtQuick -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_QML_LIB -DQT_QUICK_LIB -DQT_WIDGETS_LIB -Dqmlboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtQml -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtQuick -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_QML_LIB -DQT_QUICK_LIB -DQT_WIDGETS_LIB -Dqmlboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtQml -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtQuick -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_QML_LIB -DQT_QUICK_LIB -DQT_WIDGETS_LIB -Dqmlboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtQml -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtQuick -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_QML_LIB -DQT_QUICK_LIB -DQT_WIDGETS_LIB -Dqmlboxmodel_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtQml -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtQuick -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dapplications_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dapplications_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/applications.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dapplications_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/applications.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dapplications_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dcalculator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dcalculator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/calculator.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dcalculator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/calculator.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dcalculator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dchromium_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dchromium_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/chromium.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dchromium_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/src/file.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/src/indexfile.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/src/indextreenode.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/src/mimetypedialog.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/src/standardfile.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dfirefoxbookmarks_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dfirefoxbookmarks_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dfirefoxbookmarks_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dfirefoxbookmarks_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dhashgenerator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dhashgenerator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dhashgenerator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/hashgenerator.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dhashgenerator_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_DBUS_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dmpris_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtDBus -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_DBUS_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dmpris_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtDBus -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/mpris.dir/src/command.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_DBUS_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dmpris_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtDBus -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/mpris.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_DBUS_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dmpris_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtDBus -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/mpris.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_DBUS_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dmpris_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtDBus -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/mpris.dir/src/item.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_DBUS_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dmpris_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtDBus -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dpython_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/python3.8 -isystem /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dpython_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/python3.8 -isystem /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/python.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dpython_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/python3.8 -isystem /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/python.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dpython_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/python3.8 -isystem /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/python.dir/src/modulesmodel.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dpython_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/python3.8 -isystem /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/python.dir/src/pythonmodulev1.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dpython_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/python3.8 -isystem /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dsnippets_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dsnippets_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/snippets.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dsnippets_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/snippets.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dsnippets_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dsnippets_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dssh_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dssh_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/ssh.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dssh_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/ssh.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dssh_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dsystem_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dsystem_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/system.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dsystem_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/system.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dsystem_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dterminal_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dterminal_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/terminal.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dterminal_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dwebsearch_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/mocs_compilation.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/mocs_compilation.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dwebsearch_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/websearch.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dwebsearch_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/websearch.dir/src/enginesmodel.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dwebsearch_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/websearch.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dwebsearch_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.cpp" +}, +{ + "directory": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "command": "/bin/x86_64-linux-gnu-g++-9 -DALBERT_VERSION=\\\"0.17.2\\\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dwebsearch_EXPORTS -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 -o CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp", + "file": "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp" +} +] \ No newline at end of file diff --git a/build/lib/globalshortcut/CMakeFiles/CMakeDirectoryInformation.cmake b/build/lib/globalshortcut/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/DependInfo.cmake b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/DependInfo.cmake new file mode 100644 index 0000000..ae10a2e --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/DependInfo.cmake @@ -0,0 +1,42 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "GLOBALSHORTCUT" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_X11EXTRAS_LIB" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "lib/globalshortcut" + "../lib/globalshortcut" + "lib/globalshortcut/globalshortcut_autogen/include" + "../lib/globalshortcut/include" + "../lib/globalshortcut/include/globalshortcut" + "../lib/globalshortcut/src" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtX11Extras" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make new file mode 100644 index 0000000..4356a24 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make @@ -0,0 +1,129 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend.make + +# Include the progress variables for this target. +include lib/globalshortcut/CMakeFiles/globalshortcut.dir/progress.make + +# Include the compile flags for this target's objects. +include lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o: lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make +lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o: lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Building CXX object lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp > CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.i + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp -o CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.s + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o: lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o: ../lib/globalshortcut/src/hotkeymanager.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager.cpp + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager.cpp > CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.i + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager.cpp -o CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.s + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o: lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o: ../lib/globalshortcut/src/hotkeymanager_x11.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.cpp + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.cpp > CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.i + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.cpp -o CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.s + +# Object files for target globalshortcut +globalshortcut_OBJECTS = \ +"CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o" \ +"CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o" + +# External object files for target globalshortcut +globalshortcut_EXTERNAL_OBJECTS = + +lib/globalshortcut/libglobalshortcut.a: lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o +lib/globalshortcut/libglobalshortcut.a: lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o +lib/globalshortcut/libglobalshortcut.a: lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o +lib/globalshortcut/libglobalshortcut.a: lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make +lib/globalshortcut/libglobalshortcut.a: lib/globalshortcut/CMakeFiles/globalshortcut.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Linking CXX static library libglobalshortcut.a" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && $(CMAKE_COMMAND) -P CMakeFiles/globalshortcut.dir/cmake_clean_target.cmake + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/globalshortcut.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +lib/globalshortcut/CMakeFiles/globalshortcut.dir/build: lib/globalshortcut/libglobalshortcut.a + +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut.dir/build + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && $(CMAKE_COMMAND) -P CMakeFiles/globalshortcut.dir/cmake_clean.cmake +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut.dir/clean + +lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend + diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean.cmake b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean.cmake new file mode 100644 index 0000000..8701d33 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean.cmake @@ -0,0 +1,15 @@ +file(REMOVE_RECURSE + "CMakeFiles/globalshortcut_autogen.dir/AutogenUsed.txt" + "CMakeFiles/globalshortcut_autogen.dir/ParseCache.txt" + "globalshortcut_autogen" + "CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o" + "CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o" + "CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o" + "libglobalshortcut.a" + "libglobalshortcut.pdb" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/globalshortcut.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean_target.cmake b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean_target.cmake new file mode 100644 index 0000000..c1fda66 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/cmake_clean_target.cmake @@ -0,0 +1,3 @@ +file(REMOVE_RECURSE + "libglobalshortcut.a" +) diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend.make b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend.make new file mode 100644 index 0000000..59c8312 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for globalshortcut. +# This may be replaced when dependencies are built. diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make new file mode 100644 index 0000000..ea663a2 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DGLOBALSHORTCUT -DQT_CORE_LIB -DQT_GUI_LIB -DQT_X11EXTRAS_LIB + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include/globalshortcut -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras + diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/link.txt b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/link.txt new file mode 100644 index 0000000..121aaf9 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/link.txt @@ -0,0 +1,2 @@ +/bin/ar qc libglobalshortcut.a CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o +/bin/ranlib libglobalshortcut.a diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/progress.make b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/progress.make new file mode 100644 index 0000000..f965c55 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut.dir/progress.make @@ -0,0 +1,5 @@ +CMAKE_PROGRESS_1 = 44 +CMAKE_PROGRESS_2 = +CMAKE_PROGRESS_3 = 45 +CMAKE_PROGRESS_4 = 46 + diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/AutogenInfo.json b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..4ff5425 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/AutogenInfo.json @@ -0,0 +1,101 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include/globalshortcut/globalshortcut_globals.h", + "MU", + "CNNQ6PPAUA/moc_globalshortcut_globals.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include/globalshortcut/hotkeymanager.h", + "MU", + "CNNQ6PPAUA/moc_hotkeymanager.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.h", + "MU", + "UVLADIE3JM/moc_hotkeymanager_x11.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "GLOBALSHORTCUT", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_X11EXTRAS_LIB" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/include/globalshortcut", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtX11Extras", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/globalshortcut_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut/src/hotkeymanager_x11.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/DependInfo.cmake b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make new file mode 100644 index 0000000..af732ca --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for globalshortcut_autogen. + +# Include the progress variables for this target. +include lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/progress.make + +lib/globalshortcut/CMakeFiles/globalshortcut_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target globalshortcut" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/AutogenInfo.json Debug + +globalshortcut_autogen: lib/globalshortcut/CMakeFiles/globalshortcut_autogen +globalshortcut_autogen: lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make + +.PHONY : globalshortcut_autogen + +# Rule to build all files generated by this target. +lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build: globalshortcut_autogen + +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build + +lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut && $(CMAKE_COMMAND) -P CMakeFiles/globalshortcut_autogen.dir/cmake_clean.cmake +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/clean + +lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/depend + diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/cmake_clean.cmake b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..8358915 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/globalshortcut_autogen" + "globalshortcut_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/globalshortcut_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/progress.make b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/lib/globalshortcut/CMakeFiles/progress.marks b/build/lib/globalshortcut/CMakeFiles/progress.marks new file mode 100644 index 0000000..00750ed --- /dev/null +++ b/build/lib/globalshortcut/CMakeFiles/progress.marks @@ -0,0 +1 @@ +3 diff --git a/build/lib/globalshortcut/Makefile b/build/lib/globalshortcut/Makefile new file mode 100644 index 0000000..b22ec8e --- /dev/null +++ b/build/lib/globalshortcut/Makefile @@ -0,0 +1,306 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/globalshortcut/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +lib/globalshortcut/CMakeFiles/globalshortcut.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/CMakeFiles/globalshortcut.dir/rule +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut.dir/rule + +# Convenience name for target. +globalshortcut: lib/globalshortcut/CMakeFiles/globalshortcut.dir/rule + +.PHONY : globalshortcut + +# fast build rule for target. +globalshortcut/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/build +.PHONY : globalshortcut/fast + +# Convenience name for target. +lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/rule +.PHONY : lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/rule + +# Convenience name for target. +globalshortcut_autogen: lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/rule + +.PHONY : globalshortcut_autogen + +# fast build rule for target. +globalshortcut_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut_autogen.dir/build +.PHONY : globalshortcut_autogen/fast + +globalshortcut_autogen/mocs_compilation.o: globalshortcut_autogen/mocs_compilation.cpp.o + +.PHONY : globalshortcut_autogen/mocs_compilation.o + +# target to build an object file +globalshortcut_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.o +.PHONY : globalshortcut_autogen/mocs_compilation.cpp.o + +globalshortcut_autogen/mocs_compilation.i: globalshortcut_autogen/mocs_compilation.cpp.i + +.PHONY : globalshortcut_autogen/mocs_compilation.i + +# target to preprocess a source file +globalshortcut_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.i +.PHONY : globalshortcut_autogen/mocs_compilation.cpp.i + +globalshortcut_autogen/mocs_compilation.s: globalshortcut_autogen/mocs_compilation.cpp.s + +.PHONY : globalshortcut_autogen/mocs_compilation.s + +# target to generate assembly for a file +globalshortcut_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/globalshortcut_autogen/mocs_compilation.cpp.s +.PHONY : globalshortcut_autogen/mocs_compilation.cpp.s + +src/hotkeymanager.o: src/hotkeymanager.cpp.o + +.PHONY : src/hotkeymanager.o + +# target to build an object file +src/hotkeymanager.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.o +.PHONY : src/hotkeymanager.cpp.o + +src/hotkeymanager.i: src/hotkeymanager.cpp.i + +.PHONY : src/hotkeymanager.i + +# target to preprocess a source file +src/hotkeymanager.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.i +.PHONY : src/hotkeymanager.cpp.i + +src/hotkeymanager.s: src/hotkeymanager.cpp.s + +.PHONY : src/hotkeymanager.s + +# target to generate assembly for a file +src/hotkeymanager.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager.cpp.s +.PHONY : src/hotkeymanager.cpp.s + +src/hotkeymanager_x11.o: src/hotkeymanager_x11.cpp.o + +.PHONY : src/hotkeymanager_x11.o + +# target to build an object file +src/hotkeymanager_x11.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.o +.PHONY : src/hotkeymanager_x11.cpp.o + +src/hotkeymanager_x11.i: src/hotkeymanager_x11.cpp.i + +.PHONY : src/hotkeymanager_x11.i + +# target to preprocess a source file +src/hotkeymanager_x11.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.i +.PHONY : src/hotkeymanager_x11.cpp.i + +src/hotkeymanager_x11.s: src/hotkeymanager_x11.cpp.s + +.PHONY : src/hotkeymanager_x11.s + +# target to generate assembly for a file +src/hotkeymanager_x11.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/globalshortcut/CMakeFiles/globalshortcut.dir/build.make lib/globalshortcut/CMakeFiles/globalshortcut.dir/src/hotkeymanager_x11.cpp.s +.PHONY : src/hotkeymanager_x11.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... globalshortcut" + @echo "... globalshortcut_autogen" + @echo "... globalshortcut_autogen/mocs_compilation.o" + @echo "... globalshortcut_autogen/mocs_compilation.i" + @echo "... globalshortcut_autogen/mocs_compilation.s" + @echo "... src/hotkeymanager.o" + @echo "... src/hotkeymanager.i" + @echo "... src/hotkeymanager.s" + @echo "... src/hotkeymanager_x11.o" + @echo "... src/hotkeymanager_x11.i" + @echo "... src/hotkeymanager_x11.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/lib/globalshortcut/cmake_install.cmake b/build/lib/globalshortcut/cmake_install.cmake new file mode 100644 index 0000000..c3f0a8a --- /dev/null +++ b/build/lib/globalshortcut/cmake_install.cmake @@ -0,0 +1,39 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/globalshortcut + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + diff --git a/build/lib/xdg/CMakeFiles/CMakeDirectoryInformation.cmake b/build/lib/xdg/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/lib/xdg/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/lib/xdg/CMakeFiles/progress.marks b/build/lib/xdg/CMakeFiles/progress.marks new file mode 100644 index 0000000..b8626c4 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/progress.marks @@ -0,0 +1 @@ +4 diff --git a/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake b/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake new file mode 100644 index 0000000..c593f5c --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake @@ -0,0 +1,41 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/iconlookup.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "XDG_DEF" + "xdg_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "lib/xdg" + "../lib/xdg" + "lib/xdg/xdg_autogen/include" + "../lib/xdg/include" + "../lib/xdg/include/xdg" + "../lib/xdg/src" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/lib/xdg/CMakeFiles/xdg.dir/build.make b/build/lib/xdg/CMakeFiles/xdg.dir/build.make new file mode 100644 index 0000000..58814a2 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg.dir/build.make @@ -0,0 +1,130 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include lib/xdg/CMakeFiles/xdg.dir/depend.make + +# Include the progress variables for this target. +include lib/xdg/CMakeFiles/xdg.dir/progress.make + +# Include the compile flags for this target's objects. +include lib/xdg/CMakeFiles/xdg.dir/flags.make + +lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o: lib/xdg/CMakeFiles/xdg.dir/flags.make +lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o: lib/xdg/xdg_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Building CXX object lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/mocs_compilation.cpp + +lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/mocs_compilation.cpp > CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.i + +lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/mocs_compilation.cpp -o CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.s + +lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.o: lib/xdg/CMakeFiles/xdg.dir/flags.make +lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.o: ../lib/xdg/src/iconlookup.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/xdg.dir/src/iconlookup.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/iconlookup.cpp + +lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/xdg.dir/src/iconlookup.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/iconlookup.cpp > CMakeFiles/xdg.dir/src/iconlookup.cpp.i + +lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/xdg.dir/src/iconlookup.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/iconlookup.cpp -o CMakeFiles/xdg.dir/src/iconlookup.cpp.s + +lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.o: lib/xdg/CMakeFiles/xdg.dir/flags.make +lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.o: ../lib/xdg/src/themefileparser.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/xdg.dir/src/themefileparser.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.cpp + +lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/xdg.dir/src/themefileparser.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.cpp > CMakeFiles/xdg.dir/src/themefileparser.cpp.i + +lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/xdg.dir/src/themefileparser.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.cpp -o CMakeFiles/xdg.dir/src/themefileparser.cpp.s + +# Object files for target xdg +xdg_OBJECTS = \ +"CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/xdg.dir/src/iconlookup.cpp.o" \ +"CMakeFiles/xdg.dir/src/themefileparser.cpp.o" + +# External object files for target xdg +xdg_EXTERNAL_OBJECTS = + +lib/libxdg.so: lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o +lib/libxdg.so: lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.o +lib/libxdg.so: lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.o +lib/libxdg.so: lib/xdg/CMakeFiles/xdg.dir/build.make +lib/libxdg.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libxdg.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libxdg.so: lib/xdg/CMakeFiles/xdg.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Linking CXX shared library ../libxdg.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/xdg.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +lib/xdg/CMakeFiles/xdg.dir/build: lib/libxdg.so + +.PHONY : lib/xdg/CMakeFiles/xdg.dir/build + +lib/xdg/CMakeFiles/xdg.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && $(CMAKE_COMMAND) -P CMakeFiles/xdg.dir/cmake_clean.cmake +.PHONY : lib/xdg/CMakeFiles/xdg.dir/clean + +lib/xdg/CMakeFiles/xdg.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : lib/xdg/CMakeFiles/xdg.dir/depend + diff --git a/build/lib/xdg/CMakeFiles/xdg.dir/cmake_clean.cmake b/build/lib/xdg/CMakeFiles/xdg.dir/cmake_clean.cmake new file mode 100644 index 0000000..53a0538 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg.dir/cmake_clean.cmake @@ -0,0 +1,15 @@ +file(REMOVE_RECURSE + "../libxdg.pdb" + "../libxdg.so" + "CMakeFiles/xdg_autogen.dir/AutogenUsed.txt" + "CMakeFiles/xdg_autogen.dir/ParseCache.txt" + "xdg_autogen" + "CMakeFiles/xdg.dir/src/iconlookup.cpp.o" + "CMakeFiles/xdg.dir/src/themefileparser.cpp.o" + "CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/xdg.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/lib/xdg/CMakeFiles/xdg.dir/depend.make b/build/lib/xdg/CMakeFiles/xdg.dir/depend.make new file mode 100644 index 0000000..6985a41 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for xdg. +# This may be replaced when dependencies are built. diff --git a/build/lib/xdg/CMakeFiles/xdg.dir/flags.make b/build/lib/xdg/CMakeFiles/xdg.dir/flags.make new file mode 100644 index 0000000..d5eae83 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DXDG_DEF -Dxdg_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include/xdg -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ + diff --git a/build/lib/xdg/CMakeFiles/xdg.dir/link.txt b/build/lib/xdg/CMakeFiles/xdg.dir/link.txt new file mode 100644 index 0000000..c9bcb3d --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libxdg.so -o ../libxdg.so CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o CMakeFiles/xdg.dir/src/iconlookup.cpp.o CMakeFiles/xdg.dir/src/themefileparser.cpp.o /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/lib/xdg/CMakeFiles/xdg.dir/progress.make b/build/lib/xdg/CMakeFiles/xdg.dir/progress.make new file mode 100644 index 0000000..10f99ce --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg.dir/progress.make @@ -0,0 +1,5 @@ +CMAKE_PROGRESS_1 = 97 +CMAKE_PROGRESS_2 = 98 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 99 + diff --git a/build/lib/xdg/CMakeFiles/xdg_autogen.dir/AutogenInfo.json b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..2d7db93 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/AutogenInfo.json @@ -0,0 +1,100 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include/xdg/iconlookup.h", + "MU", + "E6LI5OXSPA/moc_iconlookup.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include/xdg/xdg_globals.h", + "MU", + "E6LI5OXSPA/moc_xdg_globals.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.h", + "MU", + "UVLADIE3JM/moc_themefileparser.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "XDG_DEF", + "xdg_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include/xdg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/xdg_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/iconlookup.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/src/themefileparser.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/lib/xdg/CMakeFiles/xdg_autogen.dir/DependInfo.cmake b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/lib/xdg/CMakeFiles/xdg_autogen.dir/build.make b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/build.make new file mode 100644 index 0000000..75daf17 --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for xdg_autogen. + +# Include the progress variables for this target. +include lib/xdg/CMakeFiles/xdg_autogen.dir/progress.make + +lib/xdg/CMakeFiles/xdg_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target xdg" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg_autogen.dir/AutogenInfo.json Debug + +xdg_autogen: lib/xdg/CMakeFiles/xdg_autogen +xdg_autogen: lib/xdg/CMakeFiles/xdg_autogen.dir/build.make + +.PHONY : xdg_autogen + +# Rule to build all files generated by this target. +lib/xdg/CMakeFiles/xdg_autogen.dir/build: xdg_autogen + +.PHONY : lib/xdg/CMakeFiles/xdg_autogen.dir/build + +lib/xdg/CMakeFiles/xdg_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg && $(CMAKE_COMMAND) -P CMakeFiles/xdg_autogen.dir/cmake_clean.cmake +.PHONY : lib/xdg/CMakeFiles/xdg_autogen.dir/clean + +lib/xdg/CMakeFiles/xdg_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : lib/xdg/CMakeFiles/xdg_autogen.dir/depend + diff --git a/build/lib/xdg/CMakeFiles/xdg_autogen.dir/cmake_clean.cmake b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..e61e59b --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/xdg_autogen" + "xdg_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/xdg_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/lib/xdg/CMakeFiles/xdg_autogen.dir/progress.make b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/progress.make new file mode 100644 index 0000000..7ad5bcb --- /dev/null +++ b/build/lib/xdg/CMakeFiles/xdg_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 100 + diff --git a/build/lib/xdg/Makefile b/build/lib/xdg/Makefile new file mode 100644 index 0000000..556cebd --- /dev/null +++ b/build/lib/xdg/Makefile @@ -0,0 +1,306 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +lib/xdg/CMakeFiles/xdg.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/CMakeFiles/xdg.dir/rule +.PHONY : lib/xdg/CMakeFiles/xdg.dir/rule + +# Convenience name for target. +xdg: lib/xdg/CMakeFiles/xdg.dir/rule + +.PHONY : xdg + +# fast build rule for target. +xdg/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/build +.PHONY : xdg/fast + +# Convenience name for target. +lib/xdg/CMakeFiles/xdg_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 lib/xdg/CMakeFiles/xdg_autogen.dir/rule +.PHONY : lib/xdg/CMakeFiles/xdg_autogen.dir/rule + +# Convenience name for target. +xdg_autogen: lib/xdg/CMakeFiles/xdg_autogen.dir/rule + +.PHONY : xdg_autogen + +# fast build rule for target. +xdg_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg_autogen.dir/build.make lib/xdg/CMakeFiles/xdg_autogen.dir/build +.PHONY : xdg_autogen/fast + +src/iconlookup.o: src/iconlookup.cpp.o + +.PHONY : src/iconlookup.o + +# target to build an object file +src/iconlookup.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.o +.PHONY : src/iconlookup.cpp.o + +src/iconlookup.i: src/iconlookup.cpp.i + +.PHONY : src/iconlookup.i + +# target to preprocess a source file +src/iconlookup.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.i +.PHONY : src/iconlookup.cpp.i + +src/iconlookup.s: src/iconlookup.cpp.s + +.PHONY : src/iconlookup.s + +# target to generate assembly for a file +src/iconlookup.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/src/iconlookup.cpp.s +.PHONY : src/iconlookup.cpp.s + +src/themefileparser.o: src/themefileparser.cpp.o + +.PHONY : src/themefileparser.o + +# target to build an object file +src/themefileparser.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.o +.PHONY : src/themefileparser.cpp.o + +src/themefileparser.i: src/themefileparser.cpp.i + +.PHONY : src/themefileparser.i + +# target to preprocess a source file +src/themefileparser.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.i +.PHONY : src/themefileparser.cpp.i + +src/themefileparser.s: src/themefileparser.cpp.s + +.PHONY : src/themefileparser.s + +# target to generate assembly for a file +src/themefileparser.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/src/themefileparser.cpp.s +.PHONY : src/themefileparser.cpp.s + +xdg_autogen/mocs_compilation.o: xdg_autogen/mocs_compilation.cpp.o + +.PHONY : xdg_autogen/mocs_compilation.o + +# target to build an object file +xdg_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.o +.PHONY : xdg_autogen/mocs_compilation.cpp.o + +xdg_autogen/mocs_compilation.i: xdg_autogen/mocs_compilation.cpp.i + +.PHONY : xdg_autogen/mocs_compilation.i + +# target to preprocess a source file +xdg_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.i +.PHONY : xdg_autogen/mocs_compilation.cpp.i + +xdg_autogen/mocs_compilation.s: xdg_autogen/mocs_compilation.cpp.s + +.PHONY : xdg_autogen/mocs_compilation.s + +# target to generate assembly for a file +xdg_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f lib/xdg/CMakeFiles/xdg.dir/build.make lib/xdg/CMakeFiles/xdg.dir/xdg_autogen/mocs_compilation.cpp.s +.PHONY : xdg_autogen/mocs_compilation.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... xdg" + @echo "... xdg_autogen" + @echo "... src/iconlookup.o" + @echo "... src/iconlookup.i" + @echo "... src/iconlookup.s" + @echo "... src/themefileparser.o" + @echo "... src/themefileparser.i" + @echo "... src/themefileparser.s" + @echo "... xdg_autogen/mocs_compilation.o" + @echo "... xdg_autogen/mocs_compilation.i" + @echo "... xdg_autogen/mocs_compilation.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/lib/xdg/cmake_install.cmake b/build/lib/xdg/cmake_install.cmake new file mode 100644 index 0000000..0322481 --- /dev/null +++ b/build/lib/xdg/cmake_install.cmake @@ -0,0 +1,58 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libxdg.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libxdg.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libxdg.so" + RPATH "") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libxdg.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libxdg.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libxdg.so") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/libxdg.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/CMakeFiles/progress.marks b/build/plugins/CMakeFiles/progress.marks new file mode 100644 index 0000000..8cf5c1a --- /dev/null +++ b/build/plugins/CMakeFiles/progress.marks @@ -0,0 +1 @@ +86 diff --git a/build/plugins/Makefile b/build/plugins/Makefile new file mode 100644 index 0000000..bbb1554 --- /dev/null +++ b/build/plugins/Makefile @@ -0,0 +1,184 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/applications/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/applications/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/applications/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/applications/CMakeFiles/applications.dir/DependInfo.cmake b/build/plugins/applications/CMakeFiles/applications.dir/DependInfo.cmake new file mode 100644 index 0000000..081f77f --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications.dir/DependInfo.cmake @@ -0,0 +1,47 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CONCURRENT_LIB" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "applications_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/applications" + "../plugins/applications" + "plugins/applications/applications_autogen/include" + "../plugins/applications/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/applications/CMakeFiles/applications.dir/build.make b/build/plugins/applications/CMakeFiles/applications.dir/build.make new file mode 100644 index 0000000..a1db081 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications.dir/build.make @@ -0,0 +1,156 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/applications/CMakeFiles/applications.dir/depend.make + +# Include the progress variables for this target. +include plugins/applications/CMakeFiles/applications.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/applications/CMakeFiles/applications.dir/flags.make + +plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp: ../plugins/applications/applications.qrc +plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp: plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Info.json +plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp: ../plugins/applications/resources/application-x-executable.svg +plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for applications.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Info.json Debug + +plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o: plugins/applications/CMakeFiles/applications.dir/flags.make +plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o: plugins/applications/applications_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/mocs_compilation.cpp + +plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/mocs_compilation.cpp > CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.i + +plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/mocs_compilation.cpp -o CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.s + +plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.o: plugins/applications/CMakeFiles/applications.dir/flags.make +plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.o: ../plugins/applications/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/applications.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.cpp + +plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/applications.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.cpp > CMakeFiles/applications.dir/src/configwidget.cpp.i + +plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/applications.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.cpp -o CMakeFiles/applications.dir/src/configwidget.cpp.s + +plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.o: plugins/applications/CMakeFiles/applications.dir/flags.make +plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.o: ../plugins/applications/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/applications.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.cpp + +plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/applications.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.cpp > CMakeFiles/applications.dir/src/extension.cpp.i + +plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/applications.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.cpp -o CMakeFiles/applications.dir/src/extension.cpp.s + +plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o: plugins/applications/CMakeFiles/applications.dir/flags.make +plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o: plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp + +plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp > CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.i + +plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp -o CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.s + +# Object files for target applications +applications_OBJECTS = \ +"CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/applications.dir/src/configwidget.cpp.o" \ +"CMakeFiles/applications.dir/src/extension.cpp.o" \ +"CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o" + +# External object files for target applications +applications_EXTERNAL_OBJECTS = + +lib/libapplications.so: plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o +lib/libapplications.so: plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.o +lib/libapplications.so: plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.o +lib/libapplications.so: plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o +lib/libapplications.so: plugins/applications/CMakeFiles/applications.dir/build.make +lib/libapplications.so: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 +lib/libapplications.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libapplications.so: lib/libalbert.so +lib/libapplications.so: lib/libxdg.so +lib/libapplications.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libapplications.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libapplications.so: plugins/applications/CMakeFiles/applications.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Linking CXX shared library ../../lib/libapplications.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/applications.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/applications/CMakeFiles/applications.dir/build: lib/libapplications.so + +.PHONY : plugins/applications/CMakeFiles/applications.dir/build + +plugins/applications/CMakeFiles/applications.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && $(CMAKE_COMMAND) -P CMakeFiles/applications.dir/cmake_clean.cmake +.PHONY : plugins/applications/CMakeFiles/applications.dir/clean + +plugins/applications/CMakeFiles/applications.dir/depend: plugins/applications/applications_autogen/EWIEGA46WW/qrc_applications.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/applications/CMakeFiles/applications.dir/depend + diff --git a/build/plugins/applications/CMakeFiles/applications.dir/cmake_clean.cmake b/build/plugins/applications/CMakeFiles/applications.dir/cmake_clean.cmake new file mode 100644 index 0000000..2116c76 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications.dir/cmake_clean.cmake @@ -0,0 +1,17 @@ +file(REMOVE_RECURSE + "../../lib/libapplications.pdb" + "../../lib/libapplications.so" + "CMakeFiles/applications_autogen.dir/AutogenUsed.txt" + "CMakeFiles/applications_autogen.dir/ParseCache.txt" + "applications_autogen" + "CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o" + "CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o" + "CMakeFiles/applications.dir/src/configwidget.cpp.o" + "CMakeFiles/applications.dir/src/extension.cpp.o" + "applications_autogen/EWIEGA46WW/qrc_applications.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/applications.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/applications/CMakeFiles/applications.dir/depend.make b/build/plugins/applications/CMakeFiles/applications.dir/depend.make new file mode 100644 index 0000000..6d7d669 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for applications. +# This may be replaced when dependencies are built. diff --git a/build/plugins/applications/CMakeFiles/applications.dir/flags.make b/build/plugins/applications/CMakeFiles/applications.dir/flags.make new file mode 100644 index 0000000..365d0e6 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dapplications_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui + diff --git a/build/plugins/applications/CMakeFiles/applications.dir/link.txt b/build/plugins/applications/CMakeFiles/applications.dir/link.txt new file mode 100644 index 0000000..99f92f9 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libapplications.so -o ../../lib/libapplications.so CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o CMakeFiles/applications.dir/src/configwidget.cpp.o CMakeFiles/applications.dir/src/extension.cpp.o CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/applications/CMakeFiles/applications.dir/progress.make b/build/plugins/applications/CMakeFiles/applications.dir/progress.make new file mode 100644 index 0000000..dfcdd29 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications.dir/progress.make @@ -0,0 +1,7 @@ +CMAKE_PROGRESS_1 = 19 +CMAKE_PROGRESS_2 = 20 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 21 +CMAKE_PROGRESS_5 = 22 +CMAKE_PROGRESS_6 = + diff --git a/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Info.json b/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Info.json new file mode 100644 index 0000000..e04237c --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/resources/application-x-executable.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "applications" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_applications.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutoRcc_applications_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/applications.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutogenInfo.json b/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..9184a1e --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutogenInfo.json @@ -0,0 +1,98 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CONCURRENT_LIB", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "applications_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/applications_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/applications/CMakeFiles/applications_autogen.dir/DependInfo.cmake b/build/plugins/applications/CMakeFiles/applications_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/applications/CMakeFiles/applications_autogen.dir/build.make b/build/plugins/applications/CMakeFiles/applications_autogen.dir/build.make new file mode 100644 index 0000000..ace57ad --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for applications_autogen. + +# Include the progress variables for this target. +include plugins/applications/CMakeFiles/applications_autogen.dir/progress.make + +plugins/applications/CMakeFiles/applications_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target applications" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir/AutogenInfo.json Debug + +applications_autogen: plugins/applications/CMakeFiles/applications_autogen +applications_autogen: plugins/applications/CMakeFiles/applications_autogen.dir/build.make + +.PHONY : applications_autogen + +# Rule to build all files generated by this target. +plugins/applications/CMakeFiles/applications_autogen.dir/build: applications_autogen + +.PHONY : plugins/applications/CMakeFiles/applications_autogen.dir/build + +plugins/applications/CMakeFiles/applications_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications && $(CMAKE_COMMAND) -P CMakeFiles/applications_autogen.dir/cmake_clean.cmake +.PHONY : plugins/applications/CMakeFiles/applications_autogen.dir/clean + +plugins/applications/CMakeFiles/applications_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/applications_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/applications/CMakeFiles/applications_autogen.dir/depend + diff --git a/build/plugins/applications/CMakeFiles/applications_autogen.dir/cmake_clean.cmake b/build/plugins/applications/CMakeFiles/applications_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..3b733b5 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/applications_autogen" + "applications_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/applications_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/applications/CMakeFiles/applications_autogen.dir/progress.make b/build/plugins/applications/CMakeFiles/applications_autogen.dir/progress.make new file mode 100644 index 0000000..42585f9 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/applications_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 23 + diff --git a/build/plugins/applications/CMakeFiles/progress.marks b/build/plugins/applications/CMakeFiles/progress.marks new file mode 100644 index 0000000..b6a7d89 --- /dev/null +++ b/build/plugins/applications/CMakeFiles/progress.marks @@ -0,0 +1 @@ +16 diff --git a/build/plugins/applications/Makefile b/build/plugins/applications/Makefile new file mode 100644 index 0000000..f794168 --- /dev/null +++ b/build/plugins/applications/Makefile @@ -0,0 +1,336 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/applications/CMakeFiles/applications.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/CMakeFiles/applications.dir/rule +.PHONY : plugins/applications/CMakeFiles/applications.dir/rule + +# Convenience name for target. +applications: plugins/applications/CMakeFiles/applications.dir/rule + +.PHONY : applications + +# fast build rule for target. +applications/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/build +.PHONY : applications/fast + +# Convenience name for target. +plugins/applications/CMakeFiles/applications_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/applications/CMakeFiles/applications_autogen.dir/rule +.PHONY : plugins/applications/CMakeFiles/applications_autogen.dir/rule + +# Convenience name for target. +applications_autogen: plugins/applications/CMakeFiles/applications_autogen.dir/rule + +.PHONY : applications_autogen + +# fast build rule for target. +applications_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications_autogen.dir/build.make plugins/applications/CMakeFiles/applications_autogen.dir/build +.PHONY : applications_autogen/fast + +applications_autogen/EWIEGA46WW/qrc_applications.o: applications_autogen/EWIEGA46WW/qrc_applications.cpp.o + +.PHONY : applications_autogen/EWIEGA46WW/qrc_applications.o + +# target to build an object file +applications_autogen/EWIEGA46WW/qrc_applications.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.o +.PHONY : applications_autogen/EWIEGA46WW/qrc_applications.cpp.o + +applications_autogen/EWIEGA46WW/qrc_applications.i: applications_autogen/EWIEGA46WW/qrc_applications.cpp.i + +.PHONY : applications_autogen/EWIEGA46WW/qrc_applications.i + +# target to preprocess a source file +applications_autogen/EWIEGA46WW/qrc_applications.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.i +.PHONY : applications_autogen/EWIEGA46WW/qrc_applications.cpp.i + +applications_autogen/EWIEGA46WW/qrc_applications.s: applications_autogen/EWIEGA46WW/qrc_applications.cpp.s + +.PHONY : applications_autogen/EWIEGA46WW/qrc_applications.s + +# target to generate assembly for a file +applications_autogen/EWIEGA46WW/qrc_applications.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/applications_autogen/EWIEGA46WW/qrc_applications.cpp.s +.PHONY : applications_autogen/EWIEGA46WW/qrc_applications.cpp.s + +applications_autogen/mocs_compilation.o: applications_autogen/mocs_compilation.cpp.o + +.PHONY : applications_autogen/mocs_compilation.o + +# target to build an object file +applications_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.o +.PHONY : applications_autogen/mocs_compilation.cpp.o + +applications_autogen/mocs_compilation.i: applications_autogen/mocs_compilation.cpp.i + +.PHONY : applications_autogen/mocs_compilation.i + +# target to preprocess a source file +applications_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.i +.PHONY : applications_autogen/mocs_compilation.cpp.i + +applications_autogen/mocs_compilation.s: applications_autogen/mocs_compilation.cpp.s + +.PHONY : applications_autogen/mocs_compilation.s + +# target to generate assembly for a file +applications_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/applications_autogen/mocs_compilation.cpp.s +.PHONY : applications_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/applications/CMakeFiles/applications.dir/build.make plugins/applications/CMakeFiles/applications.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... applications" + @echo "... applications_autogen" + @echo "... applications_autogen/EWIEGA46WW/qrc_applications.o" + @echo "... applications_autogen/EWIEGA46WW/qrc_applications.i" + @echo "... applications_autogen/EWIEGA46WW/qrc_applications.s" + @echo "... applications_autogen/mocs_compilation.o" + @echo "... applications_autogen/mocs_compilation.i" + @echo "... applications_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/applications/cmake_install.cmake b/build/plugins/applications/cmake_install.cmake new file mode 100644 index 0000000..ed5ee49 --- /dev/null +++ b/build/plugins/applications/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/applications + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libapplications.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libapplications.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libapplications.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libapplications.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libapplications.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libapplications.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libapplications.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libapplications.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/calculator/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/calculator/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/calculator/CMakeFiles/calculator.dir/DependInfo.cmake b/build/plugins/calculator/CMakeFiles/calculator.dir/DependInfo.cmake new file mode 100644 index 0000000..3644542 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator.dir/DependInfo.cmake @@ -0,0 +1,45 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "calculator_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/calculator" + "../plugins/calculator" + "plugins/calculator/calculator_autogen/include" + "../plugins/calculator/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/calculator/CMakeFiles/calculator.dir/build.make b/build/plugins/calculator/CMakeFiles/calculator.dir/build.make new file mode 100644 index 0000000..be2e815 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator.dir/build.make @@ -0,0 +1,155 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/calculator/CMakeFiles/calculator.dir/depend.make + +# Include the progress variables for this target. +include plugins/calculator/CMakeFiles/calculator.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/calculator/CMakeFiles/calculator.dir/flags.make + +plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp: ../plugins/calculator/calculator.qrc +plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp: plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Info.json +plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp: ../plugins/calculator/resources/calc.svg +plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for calculator.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Info.json Debug + +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o: plugins/calculator/CMakeFiles/calculator.dir/flags.make +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o: plugins/calculator/calculator_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/mocs_compilation.cpp + +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/mocs_compilation.cpp > CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.i + +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/mocs_compilation.cpp -o CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.s + +plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.o: plugins/calculator/CMakeFiles/calculator.dir/flags.make +plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.o: ../plugins/calculator/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/calculator.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.cpp + +plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/calculator.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.cpp > CMakeFiles/calculator.dir/src/configwidget.cpp.i + +plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/calculator.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.cpp -o CMakeFiles/calculator.dir/src/configwidget.cpp.s + +plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.o: plugins/calculator/CMakeFiles/calculator.dir/flags.make +plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.o: ../plugins/calculator/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/calculator.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.cpp + +plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/calculator.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.cpp > CMakeFiles/calculator.dir/src/extension.cpp.i + +plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/calculator.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.cpp -o CMakeFiles/calculator.dir/src/extension.cpp.s + +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o: plugins/calculator/CMakeFiles/calculator.dir/flags.make +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o: plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp + +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp > CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.i + +plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp -o CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.s + +# Object files for target calculator +calculator_OBJECTS = \ +"CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/calculator.dir/src/configwidget.cpp.o" \ +"CMakeFiles/calculator.dir/src/extension.cpp.o" \ +"CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o" + +# External object files for target calculator +calculator_EXTERNAL_OBJECTS = + +lib/libcalculator.so: plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o +lib/libcalculator.so: plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.o +lib/libcalculator.so: plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.o +lib/libcalculator.so: plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o +lib/libcalculator.so: plugins/calculator/CMakeFiles/calculator.dir/build.make +lib/libcalculator.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libcalculator.so: lib/libalbert.so +lib/libcalculator.so: lib/libxdg.so +lib/libcalculator.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libcalculator.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libcalculator.so: plugins/calculator/CMakeFiles/calculator.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Linking CXX shared library ../../lib/libcalculator.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/calculator.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/calculator/CMakeFiles/calculator.dir/build: lib/libcalculator.so + +.PHONY : plugins/calculator/CMakeFiles/calculator.dir/build + +plugins/calculator/CMakeFiles/calculator.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && $(CMAKE_COMMAND) -P CMakeFiles/calculator.dir/cmake_clean.cmake +.PHONY : plugins/calculator/CMakeFiles/calculator.dir/clean + +plugins/calculator/CMakeFiles/calculator.dir/depend: plugins/calculator/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/calculator/CMakeFiles/calculator.dir/depend + diff --git a/build/plugins/calculator/CMakeFiles/calculator.dir/cmake_clean.cmake b/build/plugins/calculator/CMakeFiles/calculator.dir/cmake_clean.cmake new file mode 100644 index 0000000..fbac1b6 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator.dir/cmake_clean.cmake @@ -0,0 +1,17 @@ +file(REMOVE_RECURSE + "../../lib/libcalculator.pdb" + "../../lib/libcalculator.so" + "CMakeFiles/calculator_autogen.dir/AutogenUsed.txt" + "CMakeFiles/calculator_autogen.dir/ParseCache.txt" + "calculator_autogen" + "CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o" + "CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o" + "CMakeFiles/calculator.dir/src/configwidget.cpp.o" + "CMakeFiles/calculator.dir/src/extension.cpp.o" + "calculator_autogen/EWIEGA46WW/qrc_calculator.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/calculator.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/calculator/CMakeFiles/calculator.dir/depend.make b/build/plugins/calculator/CMakeFiles/calculator.dir/depend.make new file mode 100644 index 0000000..491f927 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for calculator. +# This may be replaced when dependencies are built. diff --git a/build/plugins/calculator/CMakeFiles/calculator.dir/flags.make b/build/plugins/calculator/CMakeFiles/calculator.dir/flags.make new file mode 100644 index 0000000..bc1ebc1 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dcalculator_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ + diff --git a/build/plugins/calculator/CMakeFiles/calculator.dir/link.txt b/build/plugins/calculator/CMakeFiles/calculator.dir/link.txt new file mode 100644 index 0000000..e782317 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libcalculator.so -o ../../lib/libcalculator.so CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o CMakeFiles/calculator.dir/src/configwidget.cpp.o CMakeFiles/calculator.dir/src/extension.cpp.o CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so -lmuparser ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/calculator/CMakeFiles/calculator.dir/progress.make b/build/plugins/calculator/CMakeFiles/calculator.dir/progress.make new file mode 100644 index 0000000..764cc85 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator.dir/progress.make @@ -0,0 +1,7 @@ +CMAKE_PROGRESS_1 = 24 +CMAKE_PROGRESS_2 = +CMAKE_PROGRESS_3 = 25 +CMAKE_PROGRESS_4 = +CMAKE_PROGRESS_5 = 26 +CMAKE_PROGRESS_6 = 27 + diff --git a/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Info.json b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Info.json new file mode 100644 index 0000000..94a6aa1 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/resources/calc.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "calculator" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_calculator.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutoRcc_calculator_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/calculator.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutogenInfo.json b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..3910ef8 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutogenInfo.json @@ -0,0 +1,96 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "calculator_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/calculator_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/DependInfo.cmake b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make new file mode 100644 index 0000000..62ed793 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for calculator_autogen. + +# Include the progress variables for this target. +include plugins/calculator/CMakeFiles/calculator_autogen.dir/progress.make + +plugins/calculator/CMakeFiles/calculator_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target calculator" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/AutogenInfo.json Debug + +calculator_autogen: plugins/calculator/CMakeFiles/calculator_autogen +calculator_autogen: plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make + +.PHONY : calculator_autogen + +# Rule to build all files generated by this target. +plugins/calculator/CMakeFiles/calculator_autogen.dir/build: calculator_autogen + +.PHONY : plugins/calculator/CMakeFiles/calculator_autogen.dir/build + +plugins/calculator/CMakeFiles/calculator_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator && $(CMAKE_COMMAND) -P CMakeFiles/calculator_autogen.dir/cmake_clean.cmake +.PHONY : plugins/calculator/CMakeFiles/calculator_autogen.dir/clean + +plugins/calculator/CMakeFiles/calculator_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/calculator/CMakeFiles/calculator_autogen.dir/depend + diff --git a/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/cmake_clean.cmake b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..ddc2893 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/calculator_autogen" + "calculator_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/calculator_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/progress.make b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/calculator_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/plugins/calculator/CMakeFiles/progress.marks b/build/plugins/calculator/CMakeFiles/progress.marks new file mode 100644 index 0000000..60d3b2f --- /dev/null +++ b/build/plugins/calculator/CMakeFiles/progress.marks @@ -0,0 +1 @@ +15 diff --git a/build/plugins/calculator/Makefile b/build/plugins/calculator/Makefile new file mode 100644 index 0000000..fcd00ac --- /dev/null +++ b/build/plugins/calculator/Makefile @@ -0,0 +1,336 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/calculator/CMakeFiles/calculator.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/CMakeFiles/calculator.dir/rule +.PHONY : plugins/calculator/CMakeFiles/calculator.dir/rule + +# Convenience name for target. +calculator: plugins/calculator/CMakeFiles/calculator.dir/rule + +.PHONY : calculator + +# fast build rule for target. +calculator/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/build +.PHONY : calculator/fast + +# Convenience name for target. +plugins/calculator/CMakeFiles/calculator_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/calculator/CMakeFiles/calculator_autogen.dir/rule +.PHONY : plugins/calculator/CMakeFiles/calculator_autogen.dir/rule + +# Convenience name for target. +calculator_autogen: plugins/calculator/CMakeFiles/calculator_autogen.dir/rule + +.PHONY : calculator_autogen + +# fast build rule for target. +calculator_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator_autogen.dir/build.make plugins/calculator/CMakeFiles/calculator_autogen.dir/build +.PHONY : calculator_autogen/fast + +calculator_autogen/EWIEGA46WW/qrc_calculator.o: calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o + +.PHONY : calculator_autogen/EWIEGA46WW/qrc_calculator.o + +# target to build an object file +calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o +.PHONY : calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.o + +calculator_autogen/EWIEGA46WW/qrc_calculator.i: calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.i + +.PHONY : calculator_autogen/EWIEGA46WW/qrc_calculator.i + +# target to preprocess a source file +calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.i +.PHONY : calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.i + +calculator_autogen/EWIEGA46WW/qrc_calculator.s: calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.s + +.PHONY : calculator_autogen/EWIEGA46WW/qrc_calculator.s + +# target to generate assembly for a file +calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.s +.PHONY : calculator_autogen/EWIEGA46WW/qrc_calculator.cpp.s + +calculator_autogen/mocs_compilation.o: calculator_autogen/mocs_compilation.cpp.o + +.PHONY : calculator_autogen/mocs_compilation.o + +# target to build an object file +calculator_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.o +.PHONY : calculator_autogen/mocs_compilation.cpp.o + +calculator_autogen/mocs_compilation.i: calculator_autogen/mocs_compilation.cpp.i + +.PHONY : calculator_autogen/mocs_compilation.i + +# target to preprocess a source file +calculator_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.i +.PHONY : calculator_autogen/mocs_compilation.cpp.i + +calculator_autogen/mocs_compilation.s: calculator_autogen/mocs_compilation.cpp.s + +.PHONY : calculator_autogen/mocs_compilation.s + +# target to generate assembly for a file +calculator_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/calculator_autogen/mocs_compilation.cpp.s +.PHONY : calculator_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/calculator/CMakeFiles/calculator.dir/build.make plugins/calculator/CMakeFiles/calculator.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... calculator" + @echo "... calculator_autogen" + @echo "... calculator_autogen/EWIEGA46WW/qrc_calculator.o" + @echo "... calculator_autogen/EWIEGA46WW/qrc_calculator.i" + @echo "... calculator_autogen/EWIEGA46WW/qrc_calculator.s" + @echo "... calculator_autogen/mocs_compilation.o" + @echo "... calculator_autogen/mocs_compilation.i" + @echo "... calculator_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/calculator/cmake_install.cmake b/build/plugins/calculator/cmake_install.cmake new file mode 100644 index 0000000..d326c77 --- /dev/null +++ b/build/plugins/calculator/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/calculator + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libcalculator.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libcalculator.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libcalculator.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libcalculator.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libcalculator.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libcalculator.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libcalculator.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libcalculator.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/chromium/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/chromium/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/chromium/CMakeFiles/chromium.dir/DependInfo.cmake b/build/plugins/chromium/CMakeFiles/chromium.dir/DependInfo.cmake new file mode 100644 index 0000000..5a2690b --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium.dir/DependInfo.cmake @@ -0,0 +1,46 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CONCURRENT_LIB" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "chromium_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/chromium" + "../plugins/chromium" + "plugins/chromium/chromium_autogen/include" + "../plugins/chromium/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/chromium/CMakeFiles/chromium.dir/build.make b/build/plugins/chromium/CMakeFiles/chromium.dir/build.make new file mode 100644 index 0000000..9e1fe77 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium.dir/build.make @@ -0,0 +1,141 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/chromium/CMakeFiles/chromium.dir/depend.make + +# Include the progress variables for this target. +include plugins/chromium/CMakeFiles/chromium.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/chromium/CMakeFiles/chromium.dir/flags.make + +plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp: ../plugins/chromium/chromium.qrc +plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp: plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Info.json +plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp: ../plugins/chromium/resources/favicon.png +plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for chromium.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Info.json Debug + +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o: plugins/chromium/CMakeFiles/chromium.dir/flags.make +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o: plugins/chromium/chromium_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/mocs_compilation.cpp + +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/mocs_compilation.cpp > CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.i + +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/mocs_compilation.cpp -o CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.s + +plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.o: plugins/chromium/CMakeFiles/chromium.dir/flags.make +plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.o: ../plugins/chromium/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/chromium.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.cpp + +plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/chromium.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.cpp > CMakeFiles/chromium.dir/src/extension.cpp.i + +plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/chromium.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.cpp -o CMakeFiles/chromium.dir/src/extension.cpp.s + +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o: plugins/chromium/CMakeFiles/chromium.dir/flags.make +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o: plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp + +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp > CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.i + +plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp -o CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.s + +# Object files for target chromium +chromium_OBJECTS = \ +"CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/chromium.dir/src/extension.cpp.o" \ +"CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o" + +# External object files for target chromium +chromium_EXTERNAL_OBJECTS = + +lib/libchromium.so: plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o +lib/libchromium.so: plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.o +lib/libchromium.so: plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o +lib/libchromium.so: plugins/chromium/CMakeFiles/chromium.dir/build.make +lib/libchromium.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libchromium.so: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 +lib/libchromium.so: lib/libalbert.so +lib/libchromium.so: lib/libxdg.so +lib/libchromium.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libchromium.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libchromium.so: plugins/chromium/CMakeFiles/chromium.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Linking CXX shared library ../../lib/libchromium.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/chromium.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/chromium/CMakeFiles/chromium.dir/build: lib/libchromium.so + +.PHONY : plugins/chromium/CMakeFiles/chromium.dir/build + +plugins/chromium/CMakeFiles/chromium.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && $(CMAKE_COMMAND) -P CMakeFiles/chromium.dir/cmake_clean.cmake +.PHONY : plugins/chromium/CMakeFiles/chromium.dir/clean + +plugins/chromium/CMakeFiles/chromium.dir/depend: plugins/chromium/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/chromium/CMakeFiles/chromium.dir/depend + diff --git a/build/plugins/chromium/CMakeFiles/chromium.dir/cmake_clean.cmake b/build/plugins/chromium/CMakeFiles/chromium.dir/cmake_clean.cmake new file mode 100644 index 0000000..623f1c1 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium.dir/cmake_clean.cmake @@ -0,0 +1,16 @@ +file(REMOVE_RECURSE + "../../lib/libchromium.pdb" + "../../lib/libchromium.so" + "CMakeFiles/chromium_autogen.dir/AutogenUsed.txt" + "CMakeFiles/chromium_autogen.dir/ParseCache.txt" + "chromium_autogen" + "CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o" + "CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o" + "CMakeFiles/chromium.dir/src/extension.cpp.o" + "chromium_autogen/EWIEGA46WW/qrc_chromium.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/chromium.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/chromium/CMakeFiles/chromium.dir/depend.make b/build/plugins/chromium/CMakeFiles/chromium.dir/depend.make new file mode 100644 index 0000000..e922000 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for chromium. +# This may be replaced when dependencies are built. diff --git a/build/plugins/chromium/CMakeFiles/chromium.dir/flags.make b/build/plugins/chromium/CMakeFiles/chromium.dir/flags.make new file mode 100644 index 0000000..8d0c1b3 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dchromium_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent + diff --git a/build/plugins/chromium/CMakeFiles/chromium.dir/link.txt b/build/plugins/chromium/CMakeFiles/chromium.dir/link.txt new file mode 100644 index 0000000..cc3ec91 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libchromium.so -o ../../lib/libchromium.so CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o CMakeFiles/chromium.dir/src/extension.cpp.o CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/chromium/CMakeFiles/chromium.dir/progress.make b/build/plugins/chromium/CMakeFiles/chromium.dir/progress.make new file mode 100644 index 0000000..3b83fcd --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium.dir/progress.make @@ -0,0 +1,6 @@ +CMAKE_PROGRESS_1 = 28 +CMAKE_PROGRESS_2 = 29 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 30 +CMAKE_PROGRESS_5 = 31 + diff --git a/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Info.json b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Info.json new file mode 100644 index 0000000..0a98ff5 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/resources/favicon.png" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "chromium" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_chromium.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutoRcc_chromium_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/chromium.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutogenInfo.json b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..4241652 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutogenInfo.json @@ -0,0 +1,89 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CONCURRENT_LIB", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "chromium_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/chromium_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/DependInfo.cmake b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make new file mode 100644 index 0000000..02046ea --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for chromium_autogen. + +# Include the progress variables for this target. +include plugins/chromium/CMakeFiles/chromium_autogen.dir/progress.make + +plugins/chromium/CMakeFiles/chromium_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target chromium" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/AutogenInfo.json Debug + +chromium_autogen: plugins/chromium/CMakeFiles/chromium_autogen +chromium_autogen: plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make + +.PHONY : chromium_autogen + +# Rule to build all files generated by this target. +plugins/chromium/CMakeFiles/chromium_autogen.dir/build: chromium_autogen + +.PHONY : plugins/chromium/CMakeFiles/chromium_autogen.dir/build + +plugins/chromium/CMakeFiles/chromium_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium && $(CMAKE_COMMAND) -P CMakeFiles/chromium_autogen.dir/cmake_clean.cmake +.PHONY : plugins/chromium/CMakeFiles/chromium_autogen.dir/clean + +plugins/chromium/CMakeFiles/chromium_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/chromium/CMakeFiles/chromium_autogen.dir/depend + diff --git a/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/cmake_clean.cmake b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..130af52 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/chromium_autogen" + "chromium_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/chromium_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/progress.make b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/chromium_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/plugins/chromium/CMakeFiles/progress.marks b/build/plugins/chromium/CMakeFiles/progress.marks new file mode 100644 index 0000000..60d3b2f --- /dev/null +++ b/build/plugins/chromium/CMakeFiles/progress.marks @@ -0,0 +1 @@ +15 diff --git a/build/plugins/chromium/Makefile b/build/plugins/chromium/Makefile new file mode 100644 index 0000000..d3fa868 --- /dev/null +++ b/build/plugins/chromium/Makefile @@ -0,0 +1,306 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/chromium/CMakeFiles/chromium.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/CMakeFiles/chromium.dir/rule +.PHONY : plugins/chromium/CMakeFiles/chromium.dir/rule + +# Convenience name for target. +chromium: plugins/chromium/CMakeFiles/chromium.dir/rule + +.PHONY : chromium + +# fast build rule for target. +chromium/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/build +.PHONY : chromium/fast + +# Convenience name for target. +plugins/chromium/CMakeFiles/chromium_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/chromium/CMakeFiles/chromium_autogen.dir/rule +.PHONY : plugins/chromium/CMakeFiles/chromium_autogen.dir/rule + +# Convenience name for target. +chromium_autogen: plugins/chromium/CMakeFiles/chromium_autogen.dir/rule + +.PHONY : chromium_autogen + +# fast build rule for target. +chromium_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium_autogen.dir/build.make plugins/chromium/CMakeFiles/chromium_autogen.dir/build +.PHONY : chromium_autogen/fast + +chromium_autogen/EWIEGA46WW/qrc_chromium.o: chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o + +.PHONY : chromium_autogen/EWIEGA46WW/qrc_chromium.o + +# target to build an object file +chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o +.PHONY : chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.o + +chromium_autogen/EWIEGA46WW/qrc_chromium.i: chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.i + +.PHONY : chromium_autogen/EWIEGA46WW/qrc_chromium.i + +# target to preprocess a source file +chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.i +.PHONY : chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.i + +chromium_autogen/EWIEGA46WW/qrc_chromium.s: chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.s + +.PHONY : chromium_autogen/EWIEGA46WW/qrc_chromium.s + +# target to generate assembly for a file +chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.s +.PHONY : chromium_autogen/EWIEGA46WW/qrc_chromium.cpp.s + +chromium_autogen/mocs_compilation.o: chromium_autogen/mocs_compilation.cpp.o + +.PHONY : chromium_autogen/mocs_compilation.o + +# target to build an object file +chromium_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.o +.PHONY : chromium_autogen/mocs_compilation.cpp.o + +chromium_autogen/mocs_compilation.i: chromium_autogen/mocs_compilation.cpp.i + +.PHONY : chromium_autogen/mocs_compilation.i + +# target to preprocess a source file +chromium_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.i +.PHONY : chromium_autogen/mocs_compilation.cpp.i + +chromium_autogen/mocs_compilation.s: chromium_autogen/mocs_compilation.cpp.s + +.PHONY : chromium_autogen/mocs_compilation.s + +# target to generate assembly for a file +chromium_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/chromium_autogen/mocs_compilation.cpp.s +.PHONY : chromium_autogen/mocs_compilation.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/chromium/CMakeFiles/chromium.dir/build.make plugins/chromium/CMakeFiles/chromium.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... chromium" + @echo "... chromium_autogen" + @echo "... chromium_autogen/EWIEGA46WW/qrc_chromium.o" + @echo "... chromium_autogen/EWIEGA46WW/qrc_chromium.i" + @echo "... chromium_autogen/EWIEGA46WW/qrc_chromium.s" + @echo "... chromium_autogen/mocs_compilation.o" + @echo "... chromium_autogen/mocs_compilation.i" + @echo "... chromium_autogen/mocs_compilation.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/chromium/cmake_install.cmake b/build/plugins/chromium/cmake_install.cmake new file mode 100644 index 0000000..ec82ab2 --- /dev/null +++ b/build/plugins/chromium/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/chromium + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libchromium.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libchromium.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libchromium.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libchromium.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libchromium.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libchromium.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libchromium.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libchromium.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/cmake_install.cmake b/build/plugins/cmake_install.cmake new file mode 100644 index 0000000..3095953 --- /dev/null +++ b/build/plugins/cmake_install.cmake @@ -0,0 +1,59 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if(NOT CMAKE_INSTALL_LOCAL_ONLY) + # Include the install script for each subdirectory. + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/applications/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/calculator/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/chromium/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/cmake_install.cmake") + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/cmake_install.cmake") + +endif() + diff --git a/build/plugins/files/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/files/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/files/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/files/CMakeFiles/files.dir/DependInfo.cmake b/build/plugins/files/CMakeFiles/files.dir/DependInfo.cmake new file mode 100644 index 0000000..836dca6 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files.dir/DependInfo.cmake @@ -0,0 +1,52 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/src/file.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CONCURRENT_LIB" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "files_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/files" + "../plugins/files" + "plugins/files/files_autogen/include" + "../plugins/files/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/files/CMakeFiles/files.dir/build.make b/build/plugins/files/CMakeFiles/files.dir/build.make new file mode 100644 index 0000000..b7945b4 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files.dir/build.make @@ -0,0 +1,231 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/files/CMakeFiles/files.dir/depend.make + +# Include the progress variables for this target. +include plugins/files/CMakeFiles/files.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/files/CMakeFiles/files.dir/flags.make + +plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp: ../plugins/files/files.qrc +plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp: plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Info.json +plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp: ../plugins/files/resources/inode-directory.svg +plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for files.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Info.json Debug + +plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o: plugins/files/files_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/mocs_compilation.cpp + +plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/mocs_compilation.cpp > CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.i + +plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/mocs_compilation.cpp -o CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.s + +plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.o: ../plugins/files/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.cpp + +plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.cpp > CMakeFiles/files.dir/src/configwidget.cpp.i + +plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.cpp -o CMakeFiles/files.dir/src/configwidget.cpp.s + +plugins/files/CMakeFiles/files.dir/src/extension.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/src/extension.cpp.o: ../plugins/files/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/files/CMakeFiles/files.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.cpp + +plugins/files/CMakeFiles/files.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.cpp > CMakeFiles/files.dir/src/extension.cpp.i + +plugins/files/CMakeFiles/files.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.cpp -o CMakeFiles/files.dir/src/extension.cpp.s + +plugins/files/CMakeFiles/files.dir/src/file.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/src/file.cpp.o: ../plugins/files/src/file.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/files/CMakeFiles/files.dir/src/file.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/src/file.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.cpp + +plugins/files/CMakeFiles/files.dir/src/file.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/src/file.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.cpp > CMakeFiles/files.dir/src/file.cpp.i + +plugins/files/CMakeFiles/files.dir/src/file.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/src/file.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.cpp -o CMakeFiles/files.dir/src/file.cpp.s + +plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.o: ../plugins/files/src/indexfile.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/src/indexfile.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.cpp + +plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/src/indexfile.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.cpp > CMakeFiles/files.dir/src/indexfile.cpp.i + +plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/src/indexfile.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.cpp -o CMakeFiles/files.dir/src/indexfile.cpp.s + +plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.o: ../plugins/files/src/indextreenode.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Building CXX object plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/src/indextreenode.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.cpp + +plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/src/indextreenode.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.cpp > CMakeFiles/files.dir/src/indextreenode.cpp.i + +plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/src/indextreenode.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.cpp -o CMakeFiles/files.dir/src/indextreenode.cpp.s + +plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.o: ../plugins/files/src/mimetypedialog.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_8) "Building CXX object plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/src/mimetypedialog.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.cpp + +plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/src/mimetypedialog.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.cpp > CMakeFiles/files.dir/src/mimetypedialog.cpp.i + +plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/src/mimetypedialog.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.cpp -o CMakeFiles/files.dir/src/mimetypedialog.cpp.s + +plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.o: ../plugins/files/src/standardfile.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_9) "Building CXX object plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/src/standardfile.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.cpp + +plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/src/standardfile.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.cpp > CMakeFiles/files.dir/src/standardfile.cpp.i + +plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/src/standardfile.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.cpp -o CMakeFiles/files.dir/src/standardfile.cpp.s + +plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o: plugins/files/CMakeFiles/files.dir/flags.make +plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o: plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_10) "Building CXX object plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp + +plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp > CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.i + +plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp -o CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.s + +# Object files for target files +files_OBJECTS = \ +"CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/files.dir/src/configwidget.cpp.o" \ +"CMakeFiles/files.dir/src/extension.cpp.o" \ +"CMakeFiles/files.dir/src/file.cpp.o" \ +"CMakeFiles/files.dir/src/indexfile.cpp.o" \ +"CMakeFiles/files.dir/src/indextreenode.cpp.o" \ +"CMakeFiles/files.dir/src/mimetypedialog.cpp.o" \ +"CMakeFiles/files.dir/src/standardfile.cpp.o" \ +"CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o" + +# External object files for target files +files_EXTERNAL_OBJECTS = + +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/src/extension.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/src/file.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/build.make +lib/libfiles.so: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 +lib/libfiles.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libfiles.so: lib/libalbert.so +lib/libfiles.so: lib/libxdg.so +lib/libfiles.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libfiles.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libfiles.so: plugins/files/CMakeFiles/files.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_11) "Linking CXX shared library ../../lib/libfiles.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/files.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/files/CMakeFiles/files.dir/build: lib/libfiles.so + +.PHONY : plugins/files/CMakeFiles/files.dir/build + +plugins/files/CMakeFiles/files.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && $(CMAKE_COMMAND) -P CMakeFiles/files.dir/cmake_clean.cmake +.PHONY : plugins/files/CMakeFiles/files.dir/clean + +plugins/files/CMakeFiles/files.dir/depend: plugins/files/files_autogen/EWIEGA46WW/qrc_files.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/files/CMakeFiles/files.dir/depend + diff --git a/build/plugins/files/CMakeFiles/files.dir/cmake_clean.cmake b/build/plugins/files/CMakeFiles/files.dir/cmake_clean.cmake new file mode 100644 index 0000000..9303ab0 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files.dir/cmake_clean.cmake @@ -0,0 +1,22 @@ +file(REMOVE_RECURSE + "../../lib/libfiles.pdb" + "../../lib/libfiles.so" + "CMakeFiles/files_autogen.dir/AutogenUsed.txt" + "CMakeFiles/files_autogen.dir/ParseCache.txt" + "files_autogen" + "CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o" + "CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o" + "CMakeFiles/files.dir/src/configwidget.cpp.o" + "CMakeFiles/files.dir/src/extension.cpp.o" + "CMakeFiles/files.dir/src/file.cpp.o" + "CMakeFiles/files.dir/src/indexfile.cpp.o" + "CMakeFiles/files.dir/src/indextreenode.cpp.o" + "CMakeFiles/files.dir/src/mimetypedialog.cpp.o" + "CMakeFiles/files.dir/src/standardfile.cpp.o" + "files_autogen/EWIEGA46WW/qrc_files.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/files.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/files/CMakeFiles/files.dir/depend.make b/build/plugins/files/CMakeFiles/files.dir/depend.make new file mode 100644 index 0000000..e2272fc --- /dev/null +++ b/build/plugins/files/CMakeFiles/files.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for files. +# This may be replaced when dependencies are built. diff --git a/build/plugins/files/CMakeFiles/files.dir/flags.make b/build/plugins/files/CMakeFiles/files.dir/flags.make new file mode 100644 index 0000000..7e53090 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dfiles_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui + diff --git a/build/plugins/files/CMakeFiles/files.dir/link.txt b/build/plugins/files/CMakeFiles/files.dir/link.txt new file mode 100644 index 0000000..efd809c --- /dev/null +++ b/build/plugins/files/CMakeFiles/files.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libfiles.so -o ../../lib/libfiles.so CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o CMakeFiles/files.dir/src/configwidget.cpp.o CMakeFiles/files.dir/src/extension.cpp.o CMakeFiles/files.dir/src/file.cpp.o CMakeFiles/files.dir/src/indexfile.cpp.o CMakeFiles/files.dir/src/indextreenode.cpp.o CMakeFiles/files.dir/src/mimetypedialog.cpp.o CMakeFiles/files.dir/src/standardfile.cpp.o CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/files/CMakeFiles/files.dir/progress.make b/build/plugins/files/CMakeFiles/files.dir/progress.make new file mode 100644 index 0000000..0de9760 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files.dir/progress.make @@ -0,0 +1,12 @@ +CMAKE_PROGRESS_1 = 32 +CMAKE_PROGRESS_2 = +CMAKE_PROGRESS_3 = 33 +CMAKE_PROGRESS_4 = 34 +CMAKE_PROGRESS_5 = +CMAKE_PROGRESS_6 = 35 +CMAKE_PROGRESS_7 = 36 +CMAKE_PROGRESS_8 = +CMAKE_PROGRESS_9 = 37 +CMAKE_PROGRESS_10 = +CMAKE_PROGRESS_11 = 38 + diff --git a/build/plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Info.json b/build/plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Info.json new file mode 100644 index 0000000..0fc6bf6 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/resources/inode-directory.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "files" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_files.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir/AutoRcc_files_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/files.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/files/CMakeFiles/files_autogen.dir/AutogenInfo.json b/build/plugins/files/CMakeFiles/files_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..9cac07a --- /dev/null +++ b/build/plugins/files/CMakeFiles/files_autogen.dir/AutogenInfo.json @@ -0,0 +1,143 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.h", + "MU", + "UVLADIE3JM/moc_file.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.h", + "MU", + "UVLADIE3JM/moc_indexfile.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.h", + "MU", + "UVLADIE3JM/moc_indextreenode.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.h", + "MU", + "UVLADIE3JM/moc_mimetypedialog.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.h", + "MU", + "UVLADIE3JM/moc_standardfile.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CONCURRENT_LIB", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "files_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/files_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/extension.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/file.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indexfile.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/indextreenode.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/mimetypedialog.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files/src/standardfile.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/files/CMakeFiles/files_autogen.dir/DependInfo.cmake b/build/plugins/files/CMakeFiles/files_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/files/CMakeFiles/files_autogen.dir/build.make b/build/plugins/files/CMakeFiles/files_autogen.dir/build.make new file mode 100644 index 0000000..2f39e6a --- /dev/null +++ b/build/plugins/files/CMakeFiles/files_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for files_autogen. + +# Include the progress variables for this target. +include plugins/files/CMakeFiles/files_autogen.dir/progress.make + +plugins/files/CMakeFiles/files_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target files" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir/AutogenInfo.json Debug + +files_autogen: plugins/files/CMakeFiles/files_autogen +files_autogen: plugins/files/CMakeFiles/files_autogen.dir/build.make + +.PHONY : files_autogen + +# Rule to build all files generated by this target. +plugins/files/CMakeFiles/files_autogen.dir/build: files_autogen + +.PHONY : plugins/files/CMakeFiles/files_autogen.dir/build + +plugins/files/CMakeFiles/files_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files && $(CMAKE_COMMAND) -P CMakeFiles/files_autogen.dir/cmake_clean.cmake +.PHONY : plugins/files/CMakeFiles/files_autogen.dir/clean + +plugins/files/CMakeFiles/files_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/files_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/files/CMakeFiles/files_autogen.dir/depend + diff --git a/build/plugins/files/CMakeFiles/files_autogen.dir/cmake_clean.cmake b/build/plugins/files/CMakeFiles/files_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..804ca09 --- /dev/null +++ b/build/plugins/files/CMakeFiles/files_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/files_autogen" + "files_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/files_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/files/CMakeFiles/files_autogen.dir/progress.make b/build/plugins/files/CMakeFiles/files_autogen.dir/progress.make new file mode 100644 index 0000000..303dfaf --- /dev/null +++ b/build/plugins/files/CMakeFiles/files_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 39 + diff --git a/build/plugins/files/CMakeFiles/progress.marks b/build/plugins/files/CMakeFiles/progress.marks new file mode 100644 index 0000000..d6b2404 --- /dev/null +++ b/build/plugins/files/CMakeFiles/progress.marks @@ -0,0 +1 @@ +19 diff --git a/build/plugins/files/Makefile b/build/plugins/files/Makefile new file mode 100644 index 0000000..144d54e --- /dev/null +++ b/build/plugins/files/Makefile @@ -0,0 +1,486 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/files/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/files/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/files/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/files/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/files/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/files/CMakeFiles/files.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/files/CMakeFiles/files.dir/rule +.PHONY : plugins/files/CMakeFiles/files.dir/rule + +# Convenience name for target. +files: plugins/files/CMakeFiles/files.dir/rule + +.PHONY : files + +# fast build rule for target. +files/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/build +.PHONY : files/fast + +# Convenience name for target. +plugins/files/CMakeFiles/files_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/files/CMakeFiles/files_autogen.dir/rule +.PHONY : plugins/files/CMakeFiles/files_autogen.dir/rule + +# Convenience name for target. +files_autogen: plugins/files/CMakeFiles/files_autogen.dir/rule + +.PHONY : files_autogen + +# fast build rule for target. +files_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files_autogen.dir/build.make plugins/files/CMakeFiles/files_autogen.dir/build +.PHONY : files_autogen/fast + +files_autogen/EWIEGA46WW/qrc_files.o: files_autogen/EWIEGA46WW/qrc_files.cpp.o + +.PHONY : files_autogen/EWIEGA46WW/qrc_files.o + +# target to build an object file +files_autogen/EWIEGA46WW/qrc_files.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.o +.PHONY : files_autogen/EWIEGA46WW/qrc_files.cpp.o + +files_autogen/EWIEGA46WW/qrc_files.i: files_autogen/EWIEGA46WW/qrc_files.cpp.i + +.PHONY : files_autogen/EWIEGA46WW/qrc_files.i + +# target to preprocess a source file +files_autogen/EWIEGA46WW/qrc_files.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.i +.PHONY : files_autogen/EWIEGA46WW/qrc_files.cpp.i + +files_autogen/EWIEGA46WW/qrc_files.s: files_autogen/EWIEGA46WW/qrc_files.cpp.s + +.PHONY : files_autogen/EWIEGA46WW/qrc_files.s + +# target to generate assembly for a file +files_autogen/EWIEGA46WW/qrc_files.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/files_autogen/EWIEGA46WW/qrc_files.cpp.s +.PHONY : files_autogen/EWIEGA46WW/qrc_files.cpp.s + +files_autogen/mocs_compilation.o: files_autogen/mocs_compilation.cpp.o + +.PHONY : files_autogen/mocs_compilation.o + +# target to build an object file +files_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.o +.PHONY : files_autogen/mocs_compilation.cpp.o + +files_autogen/mocs_compilation.i: files_autogen/mocs_compilation.cpp.i + +.PHONY : files_autogen/mocs_compilation.i + +# target to preprocess a source file +files_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.i +.PHONY : files_autogen/mocs_compilation.cpp.i + +files_autogen/mocs_compilation.s: files_autogen/mocs_compilation.cpp.s + +.PHONY : files_autogen/mocs_compilation.s + +# target to generate assembly for a file +files_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/files_autogen/mocs_compilation.cpp.s +.PHONY : files_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +src/file.o: src/file.cpp.o + +.PHONY : src/file.o + +# target to build an object file +src/file.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/file.cpp.o +.PHONY : src/file.cpp.o + +src/file.i: src/file.cpp.i + +.PHONY : src/file.i + +# target to preprocess a source file +src/file.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/file.cpp.i +.PHONY : src/file.cpp.i + +src/file.s: src/file.cpp.s + +.PHONY : src/file.s + +# target to generate assembly for a file +src/file.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/file.cpp.s +.PHONY : src/file.cpp.s + +src/indexfile.o: src/indexfile.cpp.o + +.PHONY : src/indexfile.o + +# target to build an object file +src/indexfile.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.o +.PHONY : src/indexfile.cpp.o + +src/indexfile.i: src/indexfile.cpp.i + +.PHONY : src/indexfile.i + +# target to preprocess a source file +src/indexfile.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.i +.PHONY : src/indexfile.cpp.i + +src/indexfile.s: src/indexfile.cpp.s + +.PHONY : src/indexfile.s + +# target to generate assembly for a file +src/indexfile.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/indexfile.cpp.s +.PHONY : src/indexfile.cpp.s + +src/indextreenode.o: src/indextreenode.cpp.o + +.PHONY : src/indextreenode.o + +# target to build an object file +src/indextreenode.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.o +.PHONY : src/indextreenode.cpp.o + +src/indextreenode.i: src/indextreenode.cpp.i + +.PHONY : src/indextreenode.i + +# target to preprocess a source file +src/indextreenode.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.i +.PHONY : src/indextreenode.cpp.i + +src/indextreenode.s: src/indextreenode.cpp.s + +.PHONY : src/indextreenode.s + +# target to generate assembly for a file +src/indextreenode.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/indextreenode.cpp.s +.PHONY : src/indextreenode.cpp.s + +src/mimetypedialog.o: src/mimetypedialog.cpp.o + +.PHONY : src/mimetypedialog.o + +# target to build an object file +src/mimetypedialog.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.o +.PHONY : src/mimetypedialog.cpp.o + +src/mimetypedialog.i: src/mimetypedialog.cpp.i + +.PHONY : src/mimetypedialog.i + +# target to preprocess a source file +src/mimetypedialog.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.i +.PHONY : src/mimetypedialog.cpp.i + +src/mimetypedialog.s: src/mimetypedialog.cpp.s + +.PHONY : src/mimetypedialog.s + +# target to generate assembly for a file +src/mimetypedialog.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/mimetypedialog.cpp.s +.PHONY : src/mimetypedialog.cpp.s + +src/standardfile.o: src/standardfile.cpp.o + +.PHONY : src/standardfile.o + +# target to build an object file +src/standardfile.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.o +.PHONY : src/standardfile.cpp.o + +src/standardfile.i: src/standardfile.cpp.i + +.PHONY : src/standardfile.i + +# target to preprocess a source file +src/standardfile.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.i +.PHONY : src/standardfile.cpp.i + +src/standardfile.s: src/standardfile.cpp.s + +.PHONY : src/standardfile.s + +# target to generate assembly for a file +src/standardfile.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/files/CMakeFiles/files.dir/build.make plugins/files/CMakeFiles/files.dir/src/standardfile.cpp.s +.PHONY : src/standardfile.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... files" + @echo "... files_autogen" + @echo "... files_autogen/EWIEGA46WW/qrc_files.o" + @echo "... files_autogen/EWIEGA46WW/qrc_files.i" + @echo "... files_autogen/EWIEGA46WW/qrc_files.s" + @echo "... files_autogen/mocs_compilation.o" + @echo "... files_autogen/mocs_compilation.i" + @echo "... files_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... src/file.o" + @echo "... src/file.i" + @echo "... src/file.s" + @echo "... src/indexfile.o" + @echo "... src/indexfile.i" + @echo "... src/indexfile.s" + @echo "... src/indextreenode.o" + @echo "... src/indextreenode.i" + @echo "... src/indextreenode.s" + @echo "... src/mimetypedialog.o" + @echo "... src/mimetypedialog.i" + @echo "... src/mimetypedialog.s" + @echo "... src/standardfile.o" + @echo "... src/standardfile.i" + @echo "... src/standardfile.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/files/cmake_install.cmake b/build/plugins/files/cmake_install.cmake new file mode 100644 index 0000000..fd6cccf --- /dev/null +++ b/build/plugins/files/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/files + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfiles.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfiles.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfiles.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libfiles.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfiles.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfiles.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfiles.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfiles.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/firefoxbookmarks/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/DependInfo.cmake b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/DependInfo.cmake new file mode 100644 index 0000000..aadafe4 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/DependInfo.cmake @@ -0,0 +1,49 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CONCURRENT_LIB" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_SQL_LIB" + "QT_WIDGETS_LIB" + "firefoxbookmarks_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/firefoxbookmarks" + "../plugins/firefoxbookmarks" + "plugins/firefoxbookmarks/firefoxbookmarks_autogen/include" + "../plugins/firefoxbookmarks/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtSql" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make new file mode 100644 index 0000000..8166bbc --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make @@ -0,0 +1,157 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend.make + +# Include the progress variables for this target. +include plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make + +plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp: ../plugins/firefoxbookmarks/firefoxbookmarks.qrc +plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Info.json +plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp: ../plugins/firefoxbookmarks/resources/favicon.png +plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for firefoxbookmarks.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Info.json Debug + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o: plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp > CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.i + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp -o CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.s + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o: ../plugins/firefoxbookmarks/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.cpp + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.cpp > CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.i + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.cpp -o CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.s + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o: ../plugins/firefoxbookmarks/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.cpp + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.cpp > CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.i + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.cpp -o CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.s + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o: plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp > CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.i + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp -o CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.s + +# Object files for target firefoxbookmarks +firefoxbookmarks_OBJECTS = \ +"CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o" \ +"CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o" \ +"CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o" + +# External object files for target firefoxbookmarks +firefoxbookmarks_EXTERNAL_OBJECTS = + +lib/libfirefoxbookmarks.so: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o +lib/libfirefoxbookmarks.so: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o +lib/libfirefoxbookmarks.so: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o +lib/libfirefoxbookmarks.so: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o +lib/libfirefoxbookmarks.so: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make +lib/libfirefoxbookmarks.so: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 +lib/libfirefoxbookmarks.so: /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 +lib/libfirefoxbookmarks.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libfirefoxbookmarks.so: lib/libalbert.so +lib/libfirefoxbookmarks.so: lib/libxdg.so +lib/libfirefoxbookmarks.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libfirefoxbookmarks.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libfirefoxbookmarks.so: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Linking CXX shared library ../../lib/libfirefoxbookmarks.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/firefoxbookmarks.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build: lib/libfirefoxbookmarks.so + +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && $(CMAKE_COMMAND) -P CMakeFiles/firefoxbookmarks.dir/cmake_clean.cmake +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/clean + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend: plugins/firefoxbookmarks/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend + diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/cmake_clean.cmake b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/cmake_clean.cmake new file mode 100644 index 0000000..3247788 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/cmake_clean.cmake @@ -0,0 +1,17 @@ +file(REMOVE_RECURSE + "../../lib/libfirefoxbookmarks.pdb" + "../../lib/libfirefoxbookmarks.so" + "CMakeFiles/firefoxbookmarks_autogen.dir/AutogenUsed.txt" + "CMakeFiles/firefoxbookmarks_autogen.dir/ParseCache.txt" + "firefoxbookmarks_autogen" + "CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o" + "CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o" + "CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o" + "CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o" + "firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/firefoxbookmarks.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend.make b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend.make new file mode 100644 index 0000000..c33e4e5 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for firefoxbookmarks. +# This may be replaced when dependencies are built. diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make new file mode 100644 index 0000000..9d3eb22 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dfirefoxbookmarks_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui + diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/link.txt b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/link.txt new file mode 100644 index 0000000..aa8b74c --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libfirefoxbookmarks.so -o ../../lib/libfirefoxbookmarks.so CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/progress.make b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/progress.make new file mode 100644 index 0000000..dcc87c0 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/progress.make @@ -0,0 +1,7 @@ +CMAKE_PROGRESS_1 = +CMAKE_PROGRESS_2 = 40 +CMAKE_PROGRESS_3 = 41 +CMAKE_PROGRESS_4 = +CMAKE_PROGRESS_5 = 42 +CMAKE_PROGRESS_6 = 43 + diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Info.json b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Info.json new file mode 100644 index 0000000..7fc53da --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/resources/favicon.png" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "firefoxbookmarks" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_firefoxbookmarks.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutoRcc_firefoxbookmarks_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/firefoxbookmarks.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutogenInfo.json b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..e06a0bd --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutogenInfo.json @@ -0,0 +1,100 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CONCURRENT_LIB", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_SQL_LIB", + "QT_WIDGETS_LIB", + "firefoxbookmarks_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtSql", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/firefoxbookmarks_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/DependInfo.cmake b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make new file mode 100644 index 0000000..65f17a0 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for firefoxbookmarks_autogen. + +# Include the progress variables for this target. +include plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/progress.make + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target firefoxbookmarks" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/AutogenInfo.json Debug + +firefoxbookmarks_autogen: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen +firefoxbookmarks_autogen: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make + +.PHONY : firefoxbookmarks_autogen + +# Rule to build all files generated by this target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build: firefoxbookmarks_autogen + +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks && $(CMAKE_COMMAND) -P CMakeFiles/firefoxbookmarks_autogen.dir/cmake_clean.cmake +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/clean + +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/depend + diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/cmake_clean.cmake b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..8cde9ea --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/firefoxbookmarks_autogen" + "firefoxbookmarks_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/firefoxbookmarks_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/progress.make b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/plugins/firefoxbookmarks/CMakeFiles/progress.marks b/build/plugins/firefoxbookmarks/CMakeFiles/progress.marks new file mode 100644 index 0000000..60d3b2f --- /dev/null +++ b/build/plugins/firefoxbookmarks/CMakeFiles/progress.marks @@ -0,0 +1 @@ +15 diff --git a/build/plugins/firefoxbookmarks/Makefile b/build/plugins/firefoxbookmarks/Makefile new file mode 100644 index 0000000..ee87ec2 --- /dev/null +++ b/build/plugins/firefoxbookmarks/Makefile @@ -0,0 +1,336 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/firefoxbookmarks/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/rule +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/rule + +# Convenience name for target. +firefoxbookmarks: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/rule + +.PHONY : firefoxbookmarks + +# fast build rule for target. +firefoxbookmarks/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build +.PHONY : firefoxbookmarks/fast + +# Convenience name for target. +plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/rule +.PHONY : plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/rule + +# Convenience name for target. +firefoxbookmarks_autogen: plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/rule + +.PHONY : firefoxbookmarks_autogen + +# fast build rule for target. +firefoxbookmarks_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks_autogen.dir/build +.PHONY : firefoxbookmarks_autogen/fast + +firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.o: firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o + +.PHONY : firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.o + +# target to build an object file +firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o +.PHONY : firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.o + +firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.i: firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.i + +.PHONY : firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.i + +# target to preprocess a source file +firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.i +.PHONY : firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.i + +firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.s: firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.s + +.PHONY : firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.s + +# target to generate assembly for a file +firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.s +.PHONY : firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.cpp.s + +firefoxbookmarks_autogen/mocs_compilation.o: firefoxbookmarks_autogen/mocs_compilation.cpp.o + +.PHONY : firefoxbookmarks_autogen/mocs_compilation.o + +# target to build an object file +firefoxbookmarks_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.o +.PHONY : firefoxbookmarks_autogen/mocs_compilation.cpp.o + +firefoxbookmarks_autogen/mocs_compilation.i: firefoxbookmarks_autogen/mocs_compilation.cpp.i + +.PHONY : firefoxbookmarks_autogen/mocs_compilation.i + +# target to preprocess a source file +firefoxbookmarks_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.i +.PHONY : firefoxbookmarks_autogen/mocs_compilation.cpp.i + +firefoxbookmarks_autogen/mocs_compilation.s: firefoxbookmarks_autogen/mocs_compilation.cpp.s + +.PHONY : firefoxbookmarks_autogen/mocs_compilation.s + +# target to generate assembly for a file +firefoxbookmarks_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/firefoxbookmarks_autogen/mocs_compilation.cpp.s +.PHONY : firefoxbookmarks_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/build.make plugins/firefoxbookmarks/CMakeFiles/firefoxbookmarks.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... firefoxbookmarks" + @echo "... firefoxbookmarks_autogen" + @echo "... firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.o" + @echo "... firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.i" + @echo "... firefoxbookmarks_autogen/EWIEGA46WW/qrc_firefoxbookmarks.s" + @echo "... firefoxbookmarks_autogen/mocs_compilation.o" + @echo "... firefoxbookmarks_autogen/mocs_compilation.i" + @echo "... firefoxbookmarks_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/firefoxbookmarks/cmake_install.cmake b/build/plugins/firefoxbookmarks/cmake_install.cmake new file mode 100644 index 0000000..5b865c1 --- /dev/null +++ b/build/plugins/firefoxbookmarks/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/firefoxbookmarks + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfirefoxbookmarks.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfirefoxbookmarks.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfirefoxbookmarks.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libfirefoxbookmarks.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfirefoxbookmarks.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfirefoxbookmarks.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfirefoxbookmarks.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libfirefoxbookmarks.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/hashgenerator/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/hashgenerator/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/DependInfo.cmake b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/DependInfo.cmake new file mode 100644 index 0000000..18bfaf5 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/DependInfo.cmake @@ -0,0 +1,43 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "hashgenerator_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/hashgenerator" + "../plugins/hashgenerator" + "plugins/hashgenerator/hashgenerator_autogen/include" + "../plugins/hashgenerator/src" + "../include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make new file mode 100644 index 0000000..8b58bf3 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make @@ -0,0 +1,154 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend.make + +# Include the progress variables for this target. +include plugins/hashgenerator/CMakeFiles/hashgenerator.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make + +plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp: ../plugins/hashgenerator/hashgenerator.qrc +plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp: plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Info.json +plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp: ../plugins/hashgenerator/resources/hash.svg +plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for hashgenerator.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Info.json Debug + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o: plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp > CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.i + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp -o CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.s + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o: ../plugins/hashgenerator/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.cpp + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/hashgenerator.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.cpp > CMakeFiles/hashgenerator.dir/src/configwidget.cpp.i + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/hashgenerator.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.cpp -o CMakeFiles/hashgenerator.dir/src/configwidget.cpp.s + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.o: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.o: ../plugins/hashgenerator/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/hashgenerator.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.cpp + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/hashgenerator.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.cpp > CMakeFiles/hashgenerator.dir/src/extension.cpp.i + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/hashgenerator.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.cpp -o CMakeFiles/hashgenerator.dir/src/extension.cpp.s + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o: plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp > CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.i + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp -o CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.s + +# Object files for target hashgenerator +hashgenerator_OBJECTS = \ +"CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o" \ +"CMakeFiles/hashgenerator.dir/src/extension.cpp.o" \ +"CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o" + +# External object files for target hashgenerator +hashgenerator_EXTERNAL_OBJECTS = + +lib/libhashgenerator.so: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o +lib/libhashgenerator.so: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o +lib/libhashgenerator.so: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.o +lib/libhashgenerator.so: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o +lib/libhashgenerator.so: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make +lib/libhashgenerator.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libhashgenerator.so: lib/libalbert.so +lib/libhashgenerator.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libhashgenerator.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libhashgenerator.so: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Linking CXX shared library ../../lib/libhashgenerator.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/hashgenerator.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build: lib/libhashgenerator.so + +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && $(CMAKE_COMMAND) -P CMakeFiles/hashgenerator.dir/cmake_clean.cmake +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator.dir/clean + +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend: plugins/hashgenerator/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend + diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/cmake_clean.cmake b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/cmake_clean.cmake new file mode 100644 index 0000000..5ec9abc --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/cmake_clean.cmake @@ -0,0 +1,17 @@ +file(REMOVE_RECURSE + "../../lib/libhashgenerator.pdb" + "../../lib/libhashgenerator.so" + "CMakeFiles/hashgenerator_autogen.dir/AutogenUsed.txt" + "CMakeFiles/hashgenerator_autogen.dir/ParseCache.txt" + "hashgenerator_autogen" + "CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o" + "CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o" + "CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o" + "CMakeFiles/hashgenerator.dir/src/extension.cpp.o" + "hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/hashgenerator.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend.make b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend.make new file mode 100644 index 0000000..f2e0db7 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for hashgenerator. +# This may be replaced when dependencies are built. diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make new file mode 100644 index 0000000..eecbdc6 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dhashgenerator_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ + diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/link.txt b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/link.txt new file mode 100644 index 0000000..36017e0 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libhashgenerator.so -o ../../lib/libhashgenerator.so CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o CMakeFiles/hashgenerator.dir/src/extension.cpp.o CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/progress.make b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/progress.make new file mode 100644 index 0000000..89bc99f --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator.dir/progress.make @@ -0,0 +1,7 @@ +CMAKE_PROGRESS_1 = 47 +CMAKE_PROGRESS_2 = 48 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 49 +CMAKE_PROGRESS_5 = 50 +CMAKE_PROGRESS_6 = + diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Info.json b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Info.json new file mode 100644 index 0000000..7ff92ce --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/resources/hash.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "hashgenerator" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_hashgenerator.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutoRcc_hashgenerator_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/hashgenerator.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutogenInfo.json b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..00e7e63 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutogenInfo.json @@ -0,0 +1,95 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "hashgenerator_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/hashgenerator_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/DependInfo.cmake b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make new file mode 100644 index 0000000..bacd0d0 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for hashgenerator_autogen. + +# Include the progress variables for this target. +include plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/progress.make + +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target hashgenerator" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/AutogenInfo.json Debug + +hashgenerator_autogen: plugins/hashgenerator/CMakeFiles/hashgenerator_autogen +hashgenerator_autogen: plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make + +.PHONY : hashgenerator_autogen + +# Rule to build all files generated by this target. +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build: hashgenerator_autogen + +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build + +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator && $(CMAKE_COMMAND) -P CMakeFiles/hashgenerator_autogen.dir/cmake_clean.cmake +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/clean + +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/depend + diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/cmake_clean.cmake b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..6702235 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/hashgenerator_autogen" + "hashgenerator_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/hashgenerator_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/progress.make b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/progress.make new file mode 100644 index 0000000..f03392a --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 51 + diff --git a/build/plugins/hashgenerator/CMakeFiles/progress.marks b/build/plugins/hashgenerator/CMakeFiles/progress.marks new file mode 100644 index 0000000..48082f7 --- /dev/null +++ b/build/plugins/hashgenerator/CMakeFiles/progress.marks @@ -0,0 +1 @@ +12 diff --git a/build/plugins/hashgenerator/Makefile b/build/plugins/hashgenerator/Makefile new file mode 100644 index 0000000..424ffe4 --- /dev/null +++ b/build/plugins/hashgenerator/Makefile @@ -0,0 +1,336 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/hashgenerator/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/hashgenerator/CMakeFiles/hashgenerator.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/CMakeFiles/hashgenerator.dir/rule +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator.dir/rule + +# Convenience name for target. +hashgenerator: plugins/hashgenerator/CMakeFiles/hashgenerator.dir/rule + +.PHONY : hashgenerator + +# fast build rule for target. +hashgenerator/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build +.PHONY : hashgenerator/fast + +# Convenience name for target. +plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/rule +.PHONY : plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/rule + +# Convenience name for target. +hashgenerator_autogen: plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/rule + +.PHONY : hashgenerator_autogen + +# fast build rule for target. +hashgenerator_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator_autogen.dir/build +.PHONY : hashgenerator_autogen/fast + +hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.o: hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o + +.PHONY : hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.o + +# target to build an object file +hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o +.PHONY : hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.o + +hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.i: hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.i + +.PHONY : hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.i + +# target to preprocess a source file +hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.i +.PHONY : hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.i + +hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.s: hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.s + +.PHONY : hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.s + +# target to generate assembly for a file +hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.s +.PHONY : hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.cpp.s + +hashgenerator_autogen/mocs_compilation.o: hashgenerator_autogen/mocs_compilation.cpp.o + +.PHONY : hashgenerator_autogen/mocs_compilation.o + +# target to build an object file +hashgenerator_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.o +.PHONY : hashgenerator_autogen/mocs_compilation.cpp.o + +hashgenerator_autogen/mocs_compilation.i: hashgenerator_autogen/mocs_compilation.cpp.i + +.PHONY : hashgenerator_autogen/mocs_compilation.i + +# target to preprocess a source file +hashgenerator_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.i +.PHONY : hashgenerator_autogen/mocs_compilation.cpp.i + +hashgenerator_autogen/mocs_compilation.s: hashgenerator_autogen/mocs_compilation.cpp.s + +.PHONY : hashgenerator_autogen/mocs_compilation.s + +# target to generate assembly for a file +hashgenerator_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/hashgenerator_autogen/mocs_compilation.cpp.s +.PHONY : hashgenerator_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/hashgenerator/CMakeFiles/hashgenerator.dir/build.make plugins/hashgenerator/CMakeFiles/hashgenerator.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... hashgenerator" + @echo "... hashgenerator_autogen" + @echo "... hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.o" + @echo "... hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.i" + @echo "... hashgenerator_autogen/EWIEGA46WW/qrc_hashgenerator.s" + @echo "... hashgenerator_autogen/mocs_compilation.o" + @echo "... hashgenerator_autogen/mocs_compilation.i" + @echo "... hashgenerator_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/hashgenerator/cmake_install.cmake b/build/plugins/hashgenerator/cmake_install.cmake new file mode 100644 index 0000000..c648347 --- /dev/null +++ b/build/plugins/hashgenerator/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/hashgenerator + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libhashgenerator.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libhashgenerator.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libhashgenerator.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libhashgenerator.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libhashgenerator.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libhashgenerator.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libhashgenerator.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libhashgenerator.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/mpris/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/mpris/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/mpris/CMakeFiles/mpris.dir/DependInfo.cmake b/build/plugins/mpris/CMakeFiles/mpris.dir/DependInfo.cmake new file mode 100644 index 0000000..f2cbbe7 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris.dir/DependInfo.cmake @@ -0,0 +1,49 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_DBUS_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "mpris_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/mpris" + "../plugins/mpris" + "plugins/mpris/mpris_autogen/include" + "../plugins/mpris/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtDBus" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/mpris/CMakeFiles/mpris.dir/build.make b/build/plugins/mpris/CMakeFiles/mpris.dir/build.make new file mode 100644 index 0000000..5de359d --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris.dir/build.make @@ -0,0 +1,190 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/mpris/CMakeFiles/mpris.dir/depend.make + +# Include the progress variables for this target. +include plugins/mpris/CMakeFiles/mpris.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/mpris/CMakeFiles/mpris.dir/flags.make + +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: ../plugins/mpris/mpris.qrc +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Info.json +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: ../plugins/mpris/resources/1485099690_playback-pause.svg +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: ../plugins/mpris/resources/1485099680_playback-play.svg +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: ../plugins/mpris/resources/1485099683_playback-fast-forward.svg +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: ../plugins/mpris/resources/1485099687_playback-rewind.svg +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: ../plugins/mpris/resources/1485100510_primitive-square.svg +plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for mpris.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Info.json Debug + +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o: plugins/mpris/CMakeFiles/mpris.dir/flags.make +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o: plugins/mpris/mpris_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/mocs_compilation.cpp + +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/mocs_compilation.cpp > CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.i + +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/mocs_compilation.cpp -o CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.s + +plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.o: plugins/mpris/CMakeFiles/mpris.dir/flags.make +plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.o: ../plugins/mpris/src/command.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/mpris.dir/src/command.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.cpp + +plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/mpris.dir/src/command.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.cpp > CMakeFiles/mpris.dir/src/command.cpp.i + +plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/mpris.dir/src/command.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.cpp -o CMakeFiles/mpris.dir/src/command.cpp.s + +plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.o: plugins/mpris/CMakeFiles/mpris.dir/flags.make +plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.o: ../plugins/mpris/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/mpris.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.cpp + +plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/mpris.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.cpp > CMakeFiles/mpris.dir/src/configwidget.cpp.i + +plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/mpris.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.cpp -o CMakeFiles/mpris.dir/src/configwidget.cpp.s + +plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.o: plugins/mpris/CMakeFiles/mpris.dir/flags.make +plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.o: ../plugins/mpris/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/mpris.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.cpp + +plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/mpris.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.cpp > CMakeFiles/mpris.dir/src/extension.cpp.i + +plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/mpris.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.cpp -o CMakeFiles/mpris.dir/src/extension.cpp.s + +plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.o: plugins/mpris/CMakeFiles/mpris.dir/flags.make +plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.o: ../plugins/mpris/src/item.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/mpris.dir/src/item.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.cpp + +plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/mpris.dir/src/item.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.cpp > CMakeFiles/mpris.dir/src/item.cpp.i + +plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/mpris.dir/src/item.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.cpp -o CMakeFiles/mpris.dir/src/item.cpp.s + +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o: plugins/mpris/CMakeFiles/mpris.dir/flags.make +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o: plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Building CXX object plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp + +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp > CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.i + +plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp -o CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.s + +# Object files for target mpris +mpris_OBJECTS = \ +"CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/mpris.dir/src/command.cpp.o" \ +"CMakeFiles/mpris.dir/src/configwidget.cpp.o" \ +"CMakeFiles/mpris.dir/src/extension.cpp.o" \ +"CMakeFiles/mpris.dir/src/item.cpp.o" \ +"CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o" + +# External object files for target mpris +mpris_EXTERNAL_OBJECTS = + +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.o +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.o +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.o +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.o +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/build.make +lib/libmpris.so: /usr/lib/x86_64-linux-gnu/libQt5DBus.so.5.12.8 +lib/libmpris.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libmpris.so: lib/libalbert.so +lib/libmpris.so: lib/libxdg.so +lib/libmpris.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libmpris.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libmpris.so: plugins/mpris/CMakeFiles/mpris.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_8) "Linking CXX shared library ../../lib/libmpris.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/mpris.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/mpris/CMakeFiles/mpris.dir/build: lib/libmpris.so + +.PHONY : plugins/mpris/CMakeFiles/mpris.dir/build + +plugins/mpris/CMakeFiles/mpris.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && $(CMAKE_COMMAND) -P CMakeFiles/mpris.dir/cmake_clean.cmake +.PHONY : plugins/mpris/CMakeFiles/mpris.dir/clean + +plugins/mpris/CMakeFiles/mpris.dir/depend: plugins/mpris/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/mpris/CMakeFiles/mpris.dir/depend + diff --git a/build/plugins/mpris/CMakeFiles/mpris.dir/cmake_clean.cmake b/build/plugins/mpris/CMakeFiles/mpris.dir/cmake_clean.cmake new file mode 100644 index 0000000..f8eaf40 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris.dir/cmake_clean.cmake @@ -0,0 +1,19 @@ +file(REMOVE_RECURSE + "../../lib/libmpris.pdb" + "../../lib/libmpris.so" + "CMakeFiles/mpris_autogen.dir/AutogenUsed.txt" + "CMakeFiles/mpris_autogen.dir/ParseCache.txt" + "mpris_autogen" + "CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o" + "CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o" + "CMakeFiles/mpris.dir/src/command.cpp.o" + "CMakeFiles/mpris.dir/src/configwidget.cpp.o" + "CMakeFiles/mpris.dir/src/extension.cpp.o" + "CMakeFiles/mpris.dir/src/item.cpp.o" + "mpris_autogen/EWIEGA46WW/qrc_mpris.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/mpris.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/mpris/CMakeFiles/mpris.dir/depend.make b/build/plugins/mpris/CMakeFiles/mpris.dir/depend.make new file mode 100644 index 0000000..70ab52b --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for mpris. +# This may be replaced when dependencies are built. diff --git a/build/plugins/mpris/CMakeFiles/mpris.dir/flags.make b/build/plugins/mpris/CMakeFiles/mpris.dir/flags.make new file mode 100644 index 0000000..7ba69cf --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_DBUS_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dmpris_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtDBus -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui + diff --git a/build/plugins/mpris/CMakeFiles/mpris.dir/link.txt b/build/plugins/mpris/CMakeFiles/mpris.dir/link.txt new file mode 100644 index 0000000..ccd362c --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libmpris.so -o ../../lib/libmpris.so CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o CMakeFiles/mpris.dir/src/command.cpp.o CMakeFiles/mpris.dir/src/configwidget.cpp.o CMakeFiles/mpris.dir/src/extension.cpp.o CMakeFiles/mpris.dir/src/item.cpp.o CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5DBus.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/mpris/CMakeFiles/mpris.dir/progress.make b/build/plugins/mpris/CMakeFiles/mpris.dir/progress.make new file mode 100644 index 0000000..867ade3 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris.dir/progress.make @@ -0,0 +1,9 @@ +CMAKE_PROGRESS_1 = +CMAKE_PROGRESS_2 = 52 +CMAKE_PROGRESS_3 = 53 +CMAKE_PROGRESS_4 = +CMAKE_PROGRESS_5 = 54 +CMAKE_PROGRESS_6 = 55 +CMAKE_PROGRESS_7 = +CMAKE_PROGRESS_8 = 56 + diff --git a/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Info.json b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Info.json new file mode 100644 index 0000000..5bd5d42 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Info.json @@ -0,0 +1,26 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/resources/1485099690_playback-pause.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/resources/1485099680_playback-play.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/resources/1485099683_playback-fast-forward.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/resources/1485099687_playback-rewind.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/resources/1485100510_primitive-square.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "mpris" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_mpris.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutoRcc_mpris_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/mpris.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutogenInfo.json b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..bf2944e --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutogenInfo.json @@ -0,0 +1,121 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.h", + "MU", + "UVLADIE3JM/moc_command.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.h", + "MU", + "UVLADIE3JM/moc_item.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/player.h", + "MU", + "UVLADIE3JM/moc_player.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_DBUS_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "mpris_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtDBus", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/mpris_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/command.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/extension.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris/src/item.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/DependInfo.cmake b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make new file mode 100644 index 0000000..76167c3 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for mpris_autogen. + +# Include the progress variables for this target. +include plugins/mpris/CMakeFiles/mpris_autogen.dir/progress.make + +plugins/mpris/CMakeFiles/mpris_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target mpris" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/AutogenInfo.json Debug + +mpris_autogen: plugins/mpris/CMakeFiles/mpris_autogen +mpris_autogen: plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make + +.PHONY : mpris_autogen + +# Rule to build all files generated by this target. +plugins/mpris/CMakeFiles/mpris_autogen.dir/build: mpris_autogen + +.PHONY : plugins/mpris/CMakeFiles/mpris_autogen.dir/build + +plugins/mpris/CMakeFiles/mpris_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris && $(CMAKE_COMMAND) -P CMakeFiles/mpris_autogen.dir/cmake_clean.cmake +.PHONY : plugins/mpris/CMakeFiles/mpris_autogen.dir/clean + +plugins/mpris/CMakeFiles/mpris_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/mpris/CMakeFiles/mpris_autogen.dir/depend + diff --git a/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/cmake_clean.cmake b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..3025028 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/mpris_autogen" + "mpris_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/mpris_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/progress.make b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/mpris_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/plugins/mpris/CMakeFiles/progress.marks b/build/plugins/mpris/CMakeFiles/progress.marks new file mode 100644 index 0000000..b6a7d89 --- /dev/null +++ b/build/plugins/mpris/CMakeFiles/progress.marks @@ -0,0 +1 @@ +16 diff --git a/build/plugins/mpris/Makefile b/build/plugins/mpris/Makefile new file mode 100644 index 0000000..90d26bf --- /dev/null +++ b/build/plugins/mpris/Makefile @@ -0,0 +1,396 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/mpris/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/mpris/CMakeFiles/mpris.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/CMakeFiles/mpris.dir/rule +.PHONY : plugins/mpris/CMakeFiles/mpris.dir/rule + +# Convenience name for target. +mpris: plugins/mpris/CMakeFiles/mpris.dir/rule + +.PHONY : mpris + +# fast build rule for target. +mpris/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/build +.PHONY : mpris/fast + +# Convenience name for target. +plugins/mpris/CMakeFiles/mpris_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/mpris/CMakeFiles/mpris_autogen.dir/rule +.PHONY : plugins/mpris/CMakeFiles/mpris_autogen.dir/rule + +# Convenience name for target. +mpris_autogen: plugins/mpris/CMakeFiles/mpris_autogen.dir/rule + +.PHONY : mpris_autogen + +# fast build rule for target. +mpris_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris_autogen.dir/build.make plugins/mpris/CMakeFiles/mpris_autogen.dir/build +.PHONY : mpris_autogen/fast + +mpris_autogen/EWIEGA46WW/qrc_mpris.o: mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o + +.PHONY : mpris_autogen/EWIEGA46WW/qrc_mpris.o + +# target to build an object file +mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o +.PHONY : mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.o + +mpris_autogen/EWIEGA46WW/qrc_mpris.i: mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.i + +.PHONY : mpris_autogen/EWIEGA46WW/qrc_mpris.i + +# target to preprocess a source file +mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.i +.PHONY : mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.i + +mpris_autogen/EWIEGA46WW/qrc_mpris.s: mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.s + +.PHONY : mpris_autogen/EWIEGA46WW/qrc_mpris.s + +# target to generate assembly for a file +mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.s +.PHONY : mpris_autogen/EWIEGA46WW/qrc_mpris.cpp.s + +mpris_autogen/mocs_compilation.o: mpris_autogen/mocs_compilation.cpp.o + +.PHONY : mpris_autogen/mocs_compilation.o + +# target to build an object file +mpris_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.o +.PHONY : mpris_autogen/mocs_compilation.cpp.o + +mpris_autogen/mocs_compilation.i: mpris_autogen/mocs_compilation.cpp.i + +.PHONY : mpris_autogen/mocs_compilation.i + +# target to preprocess a source file +mpris_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.i +.PHONY : mpris_autogen/mocs_compilation.cpp.i + +mpris_autogen/mocs_compilation.s: mpris_autogen/mocs_compilation.cpp.s + +.PHONY : mpris_autogen/mocs_compilation.s + +# target to generate assembly for a file +mpris_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/mpris_autogen/mocs_compilation.cpp.s +.PHONY : mpris_autogen/mocs_compilation.cpp.s + +src/command.o: src/command.cpp.o + +.PHONY : src/command.o + +# target to build an object file +src/command.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.o +.PHONY : src/command.cpp.o + +src/command.i: src/command.cpp.i + +.PHONY : src/command.i + +# target to preprocess a source file +src/command.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.i +.PHONY : src/command.cpp.i + +src/command.s: src/command.cpp.s + +.PHONY : src/command.s + +# target to generate assembly for a file +src/command.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/command.cpp.s +.PHONY : src/command.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +src/item.o: src/item.cpp.o + +.PHONY : src/item.o + +# target to build an object file +src/item.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.o +.PHONY : src/item.cpp.o + +src/item.i: src/item.cpp.i + +.PHONY : src/item.i + +# target to preprocess a source file +src/item.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.i +.PHONY : src/item.cpp.i + +src/item.s: src/item.cpp.s + +.PHONY : src/item.s + +# target to generate assembly for a file +src/item.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/mpris/CMakeFiles/mpris.dir/build.make plugins/mpris/CMakeFiles/mpris.dir/src/item.cpp.s +.PHONY : src/item.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... install/strip" + @echo "... mpris" + @echo "... mpris_autogen" + @echo "... mpris_autogen/EWIEGA46WW/qrc_mpris.o" + @echo "... mpris_autogen/EWIEGA46WW/qrc_mpris.i" + @echo "... mpris_autogen/EWIEGA46WW/qrc_mpris.s" + @echo "... mpris_autogen/mocs_compilation.o" + @echo "... mpris_autogen/mocs_compilation.i" + @echo "... mpris_autogen/mocs_compilation.s" + @echo "... src/command.o" + @echo "... src/command.i" + @echo "... src/command.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... src/item.o" + @echo "... src/item.i" + @echo "... src/item.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/mpris/cmake_install.cmake b/build/plugins/mpris/cmake_install.cmake new file mode 100644 index 0000000..b31f77e --- /dev/null +++ b/build/plugins/mpris/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/mpris + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libmpris.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libmpris.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libmpris.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libmpris.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libmpris.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libmpris.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libmpris.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libmpris.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/python/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/python/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/python/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/python/CMakeFiles/progress.marks b/build/plugins/python/CMakeFiles/progress.marks new file mode 100644 index 0000000..98d9bcb --- /dev/null +++ b/build/plugins/python/CMakeFiles/progress.marks @@ -0,0 +1 @@ +17 diff --git a/build/plugins/python/CMakeFiles/python.dir/DependInfo.cmake b/build/plugins/python/CMakeFiles/python.dir/DependInfo.cmake new file mode 100644 index 0000000..e95ab2a --- /dev/null +++ b/build/plugins/python/CMakeFiles/python.dir/DependInfo.cmake @@ -0,0 +1,49 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "python_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/python" + "../plugins/python" + "plugins/python/python_autogen/include" + "../plugins/python/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/python3.8" + "../plugins/python/pybind11/include" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/python/CMakeFiles/python.dir/build.make b/build/plugins/python/CMakeFiles/python.dir/build.make new file mode 100644 index 0000000..764cb91 --- /dev/null +++ b/build/plugins/python/CMakeFiles/python.dir/build.make @@ -0,0 +1,186 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/python/CMakeFiles/python.dir/depend.make + +# Include the progress variables for this target. +include plugins/python/CMakeFiles/python.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/python/CMakeFiles/python.dir/flags.make + +plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp: ../plugins/python/python.qrc +plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp: plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Info.json +plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp: ../plugins/python/resources/text-x-python.svg +plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for python.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Info.json Debug + +plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o: plugins/python/CMakeFiles/python.dir/flags.make +plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o: plugins/python/python_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/mocs_compilation.cpp + +plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/mocs_compilation.cpp > CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.i + +plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/mocs_compilation.cpp -o CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.s + +plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.o: plugins/python/CMakeFiles/python.dir/flags.make +plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.o: ../plugins/python/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/python.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.cpp + +plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/python.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.cpp > CMakeFiles/python.dir/src/configwidget.cpp.i + +plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/python.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.cpp -o CMakeFiles/python.dir/src/configwidget.cpp.s + +plugins/python/CMakeFiles/python.dir/src/extension.cpp.o: plugins/python/CMakeFiles/python.dir/flags.make +plugins/python/CMakeFiles/python.dir/src/extension.cpp.o: ../plugins/python/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/python/CMakeFiles/python.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/python.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.cpp + +plugins/python/CMakeFiles/python.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/python.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.cpp > CMakeFiles/python.dir/src/extension.cpp.i + +plugins/python/CMakeFiles/python.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/python.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.cpp -o CMakeFiles/python.dir/src/extension.cpp.s + +plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.o: plugins/python/CMakeFiles/python.dir/flags.make +plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.o: ../plugins/python/src/modulesmodel.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/python.dir/src/modulesmodel.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.cpp + +plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/python.dir/src/modulesmodel.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.cpp > CMakeFiles/python.dir/src/modulesmodel.cpp.i + +plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/python.dir/src/modulesmodel.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.cpp -o CMakeFiles/python.dir/src/modulesmodel.cpp.s + +plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.o: plugins/python/CMakeFiles/python.dir/flags.make +plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.o: ../plugins/python/src/pythonmodulev1.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/python.dir/src/pythonmodulev1.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.cpp + +plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/python.dir/src/pythonmodulev1.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.cpp > CMakeFiles/python.dir/src/pythonmodulev1.cpp.i + +plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/python.dir/src/pythonmodulev1.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.cpp -o CMakeFiles/python.dir/src/pythonmodulev1.cpp.s + +plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o: plugins/python/CMakeFiles/python.dir/flags.make +plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o: plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Building CXX object plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp + +plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp > CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.i + +plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp -o CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.s + +# Object files for target python +python_OBJECTS = \ +"CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/python.dir/src/configwidget.cpp.o" \ +"CMakeFiles/python.dir/src/extension.cpp.o" \ +"CMakeFiles/python.dir/src/modulesmodel.cpp.o" \ +"CMakeFiles/python.dir/src/pythonmodulev1.cpp.o" \ +"CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o" + +# External object files for target python +python_EXTERNAL_OBJECTS = + +lib/libpython.so: plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o +lib/libpython.so: plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.o +lib/libpython.so: plugins/python/CMakeFiles/python.dir/src/extension.cpp.o +lib/libpython.so: plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.o +lib/libpython.so: plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.o +lib/libpython.so: plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o +lib/libpython.so: plugins/python/CMakeFiles/python.dir/build.make +lib/libpython.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libpython.so: lib/libalbert.so +lib/libpython.so: lib/libxdg.so +lib/libpython.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libpython.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libpython.so: /usr/lib/x86_64-linux-gnu/libpython3.8.so +lib/libpython.so: plugins/python/CMakeFiles/python.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_8) "Linking CXX shared library ../../lib/libpython.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/python.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/python/CMakeFiles/python.dir/build: lib/libpython.so + +.PHONY : plugins/python/CMakeFiles/python.dir/build + +plugins/python/CMakeFiles/python.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && $(CMAKE_COMMAND) -P CMakeFiles/python.dir/cmake_clean.cmake +.PHONY : plugins/python/CMakeFiles/python.dir/clean + +plugins/python/CMakeFiles/python.dir/depend: plugins/python/python_autogen/EWIEGA46WW/qrc_python.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/python/CMakeFiles/python.dir/depend + diff --git a/build/plugins/python/CMakeFiles/python.dir/cmake_clean.cmake b/build/plugins/python/CMakeFiles/python.dir/cmake_clean.cmake new file mode 100644 index 0000000..718032e --- /dev/null +++ b/build/plugins/python/CMakeFiles/python.dir/cmake_clean.cmake @@ -0,0 +1,19 @@ +file(REMOVE_RECURSE + "../../lib/libpython.pdb" + "../../lib/libpython.so" + "CMakeFiles/python_autogen.dir/AutogenUsed.txt" + "CMakeFiles/python_autogen.dir/ParseCache.txt" + "python_autogen" + "CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o" + "CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o" + "CMakeFiles/python.dir/src/configwidget.cpp.o" + "CMakeFiles/python.dir/src/extension.cpp.o" + "CMakeFiles/python.dir/src/modulesmodel.cpp.o" + "CMakeFiles/python.dir/src/pythonmodulev1.cpp.o" + "python_autogen/EWIEGA46WW/qrc_python.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/python.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/python/CMakeFiles/python.dir/depend.make b/build/plugins/python/CMakeFiles/python.dir/depend.make new file mode 100644 index 0000000..f915aa6 --- /dev/null +++ b/build/plugins/python/CMakeFiles/python.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for python. +# This may be replaced when dependencies are built. diff --git a/build/plugins/python/CMakeFiles/python.dir/flags.make b/build/plugins/python/CMakeFiles/python.dir/flags.make new file mode 100644 index 0000000..8c6aebf --- /dev/null +++ b/build/plugins/python/CMakeFiles/python.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dpython_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/python3.8 -isystem /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include + diff --git a/build/plugins/python/CMakeFiles/python.dir/link.txt b/build/plugins/python/CMakeFiles/python.dir/link.txt new file mode 100644 index 0000000..4710c2d --- /dev/null +++ b/build/plugins/python/CMakeFiles/python.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libpython.so -o ../../lib/libpython.so CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o CMakeFiles/python.dir/src/configwidget.cpp.o CMakeFiles/python.dir/src/extension.cpp.o CMakeFiles/python.dir/src/modulesmodel.cpp.o CMakeFiles/python.dir/src/pythonmodulev1.cpp.o CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 -lpython3.8 diff --git a/build/plugins/python/CMakeFiles/python.dir/progress.make b/build/plugins/python/CMakeFiles/python.dir/progress.make new file mode 100644 index 0000000..531844b --- /dev/null +++ b/build/plugins/python/CMakeFiles/python.dir/progress.make @@ -0,0 +1,9 @@ +CMAKE_PROGRESS_1 = 57 +CMAKE_PROGRESS_2 = 58 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 59 +CMAKE_PROGRESS_5 = 60 +CMAKE_PROGRESS_6 = +CMAKE_PROGRESS_7 = 61 +CMAKE_PROGRESS_8 = 62 + diff --git a/build/plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Info.json b/build/plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Info.json new file mode 100644 index 0000000..011a525 --- /dev/null +++ b/build/plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/resources/text-x-python.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "python" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_python.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir/AutoRcc_python_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/python.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/python/CMakeFiles/python_autogen.dir/AutogenInfo.json b/build/plugins/python/CMakeFiles/python_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..e4d2fa0 --- /dev/null +++ b/build/plugins/python/CMakeFiles/python_autogen.dir/AutogenInfo.json @@ -0,0 +1,121 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/cast_specialization.h", + "MU", + "UVLADIE3JM/moc_cast_specialization.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.h", + "MU", + "UVLADIE3JM/moc_modulesmodel.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.h", + "MU", + "UVLADIE3JM/moc_pythonmodulev1.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "python_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/python3.8", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11/include", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/python_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/extension.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/modulesmodel.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/src/pythonmodulev1.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/python/CMakeFiles/python_autogen.dir/DependInfo.cmake b/build/plugins/python/CMakeFiles/python_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/python/CMakeFiles/python_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/python/CMakeFiles/python_autogen.dir/build.make b/build/plugins/python/CMakeFiles/python_autogen.dir/build.make new file mode 100644 index 0000000..2dbfd5f --- /dev/null +++ b/build/plugins/python/CMakeFiles/python_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for python_autogen. + +# Include the progress variables for this target. +include plugins/python/CMakeFiles/python_autogen.dir/progress.make + +plugins/python/CMakeFiles/python_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target python" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir/AutogenInfo.json Debug + +python_autogen: plugins/python/CMakeFiles/python_autogen +python_autogen: plugins/python/CMakeFiles/python_autogen.dir/build.make + +.PHONY : python_autogen + +# Rule to build all files generated by this target. +plugins/python/CMakeFiles/python_autogen.dir/build: python_autogen + +.PHONY : plugins/python/CMakeFiles/python_autogen.dir/build + +plugins/python/CMakeFiles/python_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python && $(CMAKE_COMMAND) -P CMakeFiles/python_autogen.dir/cmake_clean.cmake +.PHONY : plugins/python/CMakeFiles/python_autogen.dir/clean + +plugins/python/CMakeFiles/python_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/python_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/python/CMakeFiles/python_autogen.dir/depend + diff --git a/build/plugins/python/CMakeFiles/python_autogen.dir/cmake_clean.cmake b/build/plugins/python/CMakeFiles/python_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..4888a02 --- /dev/null +++ b/build/plugins/python/CMakeFiles/python_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/python_autogen" + "python_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/python_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/python/CMakeFiles/python_autogen.dir/progress.make b/build/plugins/python/CMakeFiles/python_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/plugins/python/CMakeFiles/python_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/plugins/python/Makefile b/build/plugins/python/Makefile new file mode 100644 index 0000000..75acd90 --- /dev/null +++ b/build/plugins/python/Makefile @@ -0,0 +1,396 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/python/CMakeFiles/python.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/CMakeFiles/python.dir/rule +.PHONY : plugins/python/CMakeFiles/python.dir/rule + +# Convenience name for target. +python: plugins/python/CMakeFiles/python.dir/rule + +.PHONY : python + +# fast build rule for target. +python/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/build +.PHONY : python/fast + +# Convenience name for target. +plugins/python/CMakeFiles/python_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/CMakeFiles/python_autogen.dir/rule +.PHONY : plugins/python/CMakeFiles/python_autogen.dir/rule + +# Convenience name for target. +python_autogen: plugins/python/CMakeFiles/python_autogen.dir/rule + +.PHONY : python_autogen + +# fast build rule for target. +python_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python_autogen.dir/build.make plugins/python/CMakeFiles/python_autogen.dir/build +.PHONY : python_autogen/fast + +python_autogen/EWIEGA46WW/qrc_python.o: python_autogen/EWIEGA46WW/qrc_python.cpp.o + +.PHONY : python_autogen/EWIEGA46WW/qrc_python.o + +# target to build an object file +python_autogen/EWIEGA46WW/qrc_python.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.o +.PHONY : python_autogen/EWIEGA46WW/qrc_python.cpp.o + +python_autogen/EWIEGA46WW/qrc_python.i: python_autogen/EWIEGA46WW/qrc_python.cpp.i + +.PHONY : python_autogen/EWIEGA46WW/qrc_python.i + +# target to preprocess a source file +python_autogen/EWIEGA46WW/qrc_python.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.i +.PHONY : python_autogen/EWIEGA46WW/qrc_python.cpp.i + +python_autogen/EWIEGA46WW/qrc_python.s: python_autogen/EWIEGA46WW/qrc_python.cpp.s + +.PHONY : python_autogen/EWIEGA46WW/qrc_python.s + +# target to generate assembly for a file +python_autogen/EWIEGA46WW/qrc_python.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/python_autogen/EWIEGA46WW/qrc_python.cpp.s +.PHONY : python_autogen/EWIEGA46WW/qrc_python.cpp.s + +python_autogen/mocs_compilation.o: python_autogen/mocs_compilation.cpp.o + +.PHONY : python_autogen/mocs_compilation.o + +# target to build an object file +python_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.o +.PHONY : python_autogen/mocs_compilation.cpp.o + +python_autogen/mocs_compilation.i: python_autogen/mocs_compilation.cpp.i + +.PHONY : python_autogen/mocs_compilation.i + +# target to preprocess a source file +python_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.i +.PHONY : python_autogen/mocs_compilation.cpp.i + +python_autogen/mocs_compilation.s: python_autogen/mocs_compilation.cpp.s + +.PHONY : python_autogen/mocs_compilation.s + +# target to generate assembly for a file +python_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/python_autogen/mocs_compilation.cpp.s +.PHONY : python_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +src/modulesmodel.o: src/modulesmodel.cpp.o + +.PHONY : src/modulesmodel.o + +# target to build an object file +src/modulesmodel.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.o +.PHONY : src/modulesmodel.cpp.o + +src/modulesmodel.i: src/modulesmodel.cpp.i + +.PHONY : src/modulesmodel.i + +# target to preprocess a source file +src/modulesmodel.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.i +.PHONY : src/modulesmodel.cpp.i + +src/modulesmodel.s: src/modulesmodel.cpp.s + +.PHONY : src/modulesmodel.s + +# target to generate assembly for a file +src/modulesmodel.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/modulesmodel.cpp.s +.PHONY : src/modulesmodel.cpp.s + +src/pythonmodulev1.o: src/pythonmodulev1.cpp.o + +.PHONY : src/pythonmodulev1.o + +# target to build an object file +src/pythonmodulev1.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.o +.PHONY : src/pythonmodulev1.cpp.o + +src/pythonmodulev1.i: src/pythonmodulev1.cpp.i + +.PHONY : src/pythonmodulev1.i + +# target to preprocess a source file +src/pythonmodulev1.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.i +.PHONY : src/pythonmodulev1.cpp.i + +src/pythonmodulev1.s: src/pythonmodulev1.cpp.s + +.PHONY : src/pythonmodulev1.s + +# target to generate assembly for a file +src/pythonmodulev1.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/python/CMakeFiles/python.dir/build.make plugins/python/CMakeFiles/python.dir/src/pythonmodulev1.cpp.s +.PHONY : src/pythonmodulev1.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... python" + @echo "... python_autogen" + @echo "... python_autogen/EWIEGA46WW/qrc_python.o" + @echo "... python_autogen/EWIEGA46WW/qrc_python.i" + @echo "... python_autogen/EWIEGA46WW/qrc_python.s" + @echo "... python_autogen/mocs_compilation.o" + @echo "... python_autogen/mocs_compilation.i" + @echo "... python_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... src/modulesmodel.o" + @echo "... src/modulesmodel.i" + @echo "... src/modulesmodel.s" + @echo "... src/pythonmodulev1.o" + @echo "... src/pythonmodulev1.i" + @echo "... src/pythonmodulev1.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/python/cmake_install.cmake b/build/plugins/python/cmake_install.cmake new file mode 100644 index 0000000..095a424 --- /dev/null +++ b/build/plugins/python/cmake_install.cmake @@ -0,0 +1,72 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libpython.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libpython.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libpython.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libpython.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libpython.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libpython.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libpython.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libpython.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/share/albert/org.albert.extension.python" TYPE DIRECTORY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/share/") +endif() + +if(NOT CMAKE_INSTALL_LOCAL_ONLY) + # Include the install script for each subdirectory. + include("/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/cmake_install.cmake") + +endif() + diff --git a/build/plugins/python/pybind11/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/python/pybind11/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/python/pybind11/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/python/pybind11/CMakeFiles/progress.marks b/build/plugins/python/pybind11/CMakeFiles/progress.marks new file mode 100644 index 0000000..573541a --- /dev/null +++ b/build/plugins/python/pybind11/CMakeFiles/progress.marks @@ -0,0 +1 @@ +0 diff --git a/build/plugins/python/pybind11/Makefile b/build/plugins/python/pybind11/Makefile new file mode 100644 index 0000000..ff36a3f --- /dev/null +++ b/build/plugins/python/pybind11/Makefile @@ -0,0 +1,184 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/python/pybind11/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/pybind11/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/pybind11/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/pybind11/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/python/pybind11/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/python/pybind11/cmake_install.cmake b/build/plugins/python/pybind11/cmake_install.cmake new file mode 100644 index 0000000..4246c6d --- /dev/null +++ b/build/plugins/python/pybind11/cmake_install.cmake @@ -0,0 +1,39 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/python/pybind11 + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + diff --git a/build/plugins/qmlboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/qmlboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/qmlboxmodel/CMakeFiles/progress.marks b/build/plugins/qmlboxmodel/CMakeFiles/progress.marks new file mode 100644 index 0000000..48082f7 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/progress.marks @@ -0,0 +1 @@ +12 diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/DependInfo.cmake b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/DependInfo.cmake new file mode 100644 index 0000000..0960397 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/DependInfo.cmake @@ -0,0 +1,50 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_NETWORK_LIB" + "QT_QML_LIB" + "QT_QUICK_LIB" + "QT_WIDGETS_LIB" + "qmlboxmodel_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/qmlboxmodel" + "../plugins/qmlboxmodel" + "plugins/qmlboxmodel/qmlboxmodel_autogen/include" + "../plugins/qmlboxmodel/src" + "../include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtQml" + "/usr/include/x86_64-linux-gnu/qt5/QtNetwork" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtQuick" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make new file mode 100644 index 0000000..b6463b5 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make @@ -0,0 +1,165 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend.make + +# Include the progress variables for this target. +include plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o: plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Building CXX object plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp > CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.i + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp -o CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.s + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o: ../plugins/qmlboxmodel/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.cpp + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.cpp > CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.i + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.cpp -o CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.s + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o: ../plugins/qmlboxmodel/src/frontendplugin.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.cpp + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.cpp > CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.i + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.cpp -o CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.s + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o: ../plugins/qmlboxmodel/src/mainwindow.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.cpp + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.cpp > CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.i + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.cpp -o CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.s + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o: ../plugins/qmlboxmodel/src/propertyeditor.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.cpp + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.cpp > CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.i + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.cpp -o CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.s + +# Object files for target qmlboxmodel +qmlboxmodel_OBJECTS = \ +"CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o" \ +"CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o" \ +"CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o" \ +"CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o" + +# External object files for target qmlboxmodel +qmlboxmodel_EXTERNAL_OBJECTS = + +lib/libqmlboxmodel.so: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o +lib/libqmlboxmodel.so: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o +lib/libqmlboxmodel.so: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o +lib/libqmlboxmodel.so: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o +lib/libqmlboxmodel.so: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o +lib/libqmlboxmodel.so: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make +lib/libqmlboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Quick.so.5.12.8 +lib/libqmlboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libqmlboxmodel.so: lib/libalbert.so +lib/libqmlboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Qml.so.5.12.8 +lib/libqmlboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Network.so.5.12.8 +lib/libqmlboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libqmlboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libqmlboxmodel.so: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Linking CXX shared library ../../lib/libqmlboxmodel.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/qmlboxmodel.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build: lib/libqmlboxmodel.so + +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && $(CMAKE_COMMAND) -P CMakeFiles/qmlboxmodel.dir/cmake_clean.cmake +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/clean + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend + diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/cmake_clean.cmake b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/cmake_clean.cmake new file mode 100644 index 0000000..24ae205 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/cmake_clean.cmake @@ -0,0 +1,17 @@ +file(REMOVE_RECURSE + "../../lib/libqmlboxmodel.pdb" + "../../lib/libqmlboxmodel.so" + "CMakeFiles/qmlboxmodel_autogen.dir/AutogenUsed.txt" + "CMakeFiles/qmlboxmodel_autogen.dir/ParseCache.txt" + "qmlboxmodel_autogen" + "CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o" + "CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o" + "CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o" + "CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o" + "CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/qmlboxmodel.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend.make b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend.make new file mode 100644 index 0000000..0e501f0 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for qmlboxmodel. +# This may be replaced when dependencies are built. diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make new file mode 100644 index 0000000..ac42940 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_QML_LIB -DQT_QUICK_LIB -DQT_WIDGETS_LIB -Dqmlboxmodel_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtQml -isystem /usr/include/x86_64-linux-gnu/qt5/QtNetwork -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtQuick -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets + diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/link.txt b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/link.txt new file mode 100644 index 0000000..6bf5a62 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libqmlboxmodel.so -o ../../lib/libqmlboxmodel.so CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Quick.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so -lXext /usr/lib/x86_64-linux-gnu/libQt5Qml.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Network.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/progress.make b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/progress.make new file mode 100644 index 0000000..c1e7765 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/progress.make @@ -0,0 +1,7 @@ +CMAKE_PROGRESS_1 = 63 +CMAKE_PROGRESS_2 = +CMAKE_PROGRESS_3 = 64 +CMAKE_PROGRESS_4 = 65 +CMAKE_PROGRESS_5 = +CMAKE_PROGRESS_6 = 66 + diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/AutogenInfo.json b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..d2f00c2 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/AutogenInfo.json @@ -0,0 +1,124 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/colordialog.hpp", + "MU", + "UVLADIE3JM/moc_colordialog.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.h", + "MU", + "UVLADIE3JM/moc_frontendplugin.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.h", + "MU", + "UVLADIE3JM/moc_mainwindow.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.h", + "MU", + "UVLADIE3JM/moc_propertyeditor.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_NETWORK_LIB", + "QT_QML_LIB", + "QT_QUICK_LIB", + "QT_WIDGETS_LIB", + "qmlboxmodel_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtQml", + "/usr/include/x86_64-linux-gnu/qt5/QtNetwork", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtQuick", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/qmlboxmodel_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/frontendplugin.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/mainwindow.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/src/propertyeditor.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/DependInfo.cmake b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make new file mode 100644 index 0000000..c54a620 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for qmlboxmodel_autogen. + +# Include the progress variables for this target. +include plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/progress.make + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target qmlboxmodel" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/AutogenInfo.json Debug + +qmlboxmodel_autogen: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen +qmlboxmodel_autogen: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make + +.PHONY : qmlboxmodel_autogen + +# Rule to build all files generated by this target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build: qmlboxmodel_autogen + +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel && $(CMAKE_COMMAND) -P CMakeFiles/qmlboxmodel_autogen.dir/cmake_clean.cmake +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/clean + +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/depend + diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/cmake_clean.cmake b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..2b781f5 --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/qmlboxmodel_autogen" + "qmlboxmodel_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/qmlboxmodel_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/progress.make b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/progress.make new file mode 100644 index 0000000..059bbec --- /dev/null +++ b/build/plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 67 + diff --git a/build/plugins/qmlboxmodel/Makefile b/build/plugins/qmlboxmodel/Makefile new file mode 100644 index 0000000..9fb1b0d --- /dev/null +++ b/build/plugins/qmlboxmodel/Makefile @@ -0,0 +1,366 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/qmlboxmodel/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/rule +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/rule + +# Convenience name for target. +qmlboxmodel: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/rule + +.PHONY : qmlboxmodel + +# fast build rule for target. +qmlboxmodel/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build +.PHONY : qmlboxmodel/fast + +# Convenience name for target. +plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/rule +.PHONY : plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/rule + +# Convenience name for target. +qmlboxmodel_autogen: plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/rule + +.PHONY : qmlboxmodel_autogen + +# fast build rule for target. +qmlboxmodel_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel_autogen.dir/build +.PHONY : qmlboxmodel_autogen/fast + +qmlboxmodel_autogen/mocs_compilation.o: qmlboxmodel_autogen/mocs_compilation.cpp.o + +.PHONY : qmlboxmodel_autogen/mocs_compilation.o + +# target to build an object file +qmlboxmodel_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.o +.PHONY : qmlboxmodel_autogen/mocs_compilation.cpp.o + +qmlboxmodel_autogen/mocs_compilation.i: qmlboxmodel_autogen/mocs_compilation.cpp.i + +.PHONY : qmlboxmodel_autogen/mocs_compilation.i + +# target to preprocess a source file +qmlboxmodel_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.i +.PHONY : qmlboxmodel_autogen/mocs_compilation.cpp.i + +qmlboxmodel_autogen/mocs_compilation.s: qmlboxmodel_autogen/mocs_compilation.cpp.s + +.PHONY : qmlboxmodel_autogen/mocs_compilation.s + +# target to generate assembly for a file +qmlboxmodel_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/qmlboxmodel_autogen/mocs_compilation.cpp.s +.PHONY : qmlboxmodel_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/frontendplugin.o: src/frontendplugin.cpp.o + +.PHONY : src/frontendplugin.o + +# target to build an object file +src/frontendplugin.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.o +.PHONY : src/frontendplugin.cpp.o + +src/frontendplugin.i: src/frontendplugin.cpp.i + +.PHONY : src/frontendplugin.i + +# target to preprocess a source file +src/frontendplugin.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.i +.PHONY : src/frontendplugin.cpp.i + +src/frontendplugin.s: src/frontendplugin.cpp.s + +.PHONY : src/frontendplugin.s + +# target to generate assembly for a file +src/frontendplugin.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/frontendplugin.cpp.s +.PHONY : src/frontendplugin.cpp.s + +src/mainwindow.o: src/mainwindow.cpp.o + +.PHONY : src/mainwindow.o + +# target to build an object file +src/mainwindow.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.o +.PHONY : src/mainwindow.cpp.o + +src/mainwindow.i: src/mainwindow.cpp.i + +.PHONY : src/mainwindow.i + +# target to preprocess a source file +src/mainwindow.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.i +.PHONY : src/mainwindow.cpp.i + +src/mainwindow.s: src/mainwindow.cpp.s + +.PHONY : src/mainwindow.s + +# target to generate assembly for a file +src/mainwindow.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/mainwindow.cpp.s +.PHONY : src/mainwindow.cpp.s + +src/propertyeditor.o: src/propertyeditor.cpp.o + +.PHONY : src/propertyeditor.o + +# target to build an object file +src/propertyeditor.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.o +.PHONY : src/propertyeditor.cpp.o + +src/propertyeditor.i: src/propertyeditor.cpp.i + +.PHONY : src/propertyeditor.i + +# target to preprocess a source file +src/propertyeditor.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.i +.PHONY : src/propertyeditor.cpp.i + +src/propertyeditor.s: src/propertyeditor.cpp.s + +.PHONY : src/propertyeditor.s + +# target to generate assembly for a file +src/propertyeditor.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/build.make plugins/qmlboxmodel/CMakeFiles/qmlboxmodel.dir/src/propertyeditor.cpp.s +.PHONY : src/propertyeditor.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... qmlboxmodel" + @echo "... qmlboxmodel_autogen" + @echo "... qmlboxmodel_autogen/mocs_compilation.o" + @echo "... qmlboxmodel_autogen/mocs_compilation.i" + @echo "... qmlboxmodel_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/frontendplugin.o" + @echo "... src/frontendplugin.i" + @echo "... src/frontendplugin.s" + @echo "... src/mainwindow.o" + @echo "... src/mainwindow.i" + @echo "... src/mainwindow.s" + @echo "... src/propertyeditor.o" + @echo "... src/propertyeditor.i" + @echo "... src/propertyeditor.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/qmlboxmodel/cmake_install.cmake b/build/plugins/qmlboxmodel/cmake_install.cmake new file mode 100644 index 0000000..83d198d --- /dev/null +++ b/build/plugins/qmlboxmodel/cmake_install.cmake @@ -0,0 +1,66 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libqmlboxmodel.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libqmlboxmodel.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libqmlboxmodel.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libqmlboxmodel.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libqmlboxmodel.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libqmlboxmodel.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libqmlboxmodel.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libqmlboxmodel.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/share/albert/org.albert.frontend.qmlboxmodel" TYPE DIRECTORY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/qmlboxmodel/share/") +endif() + diff --git a/build/plugins/snippets/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/snippets/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/snippets/CMakeFiles/progress.marks b/build/plugins/snippets/CMakeFiles/progress.marks new file mode 100644 index 0000000..48082f7 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/progress.marks @@ -0,0 +1 @@ +12 diff --git a/build/plugins/snippets/CMakeFiles/snippets.dir/DependInfo.cmake b/build/plugins/snippets/CMakeFiles/snippets.dir/DependInfo.cmake new file mode 100644 index 0000000..8567517 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets.dir/DependInfo.cmake @@ -0,0 +1,46 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_SQL_LIB" + "QT_WIDGETS_LIB" + "snippets_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/snippets" + "../plugins/snippets" + "plugins/snippets/snippets_autogen/include" + "../plugins/snippets/src" + "../include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtSql" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/snippets/CMakeFiles/snippets.dir/build.make b/build/plugins/snippets/CMakeFiles/snippets.dir/build.make new file mode 100644 index 0000000..c09224c --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets.dir/build.make @@ -0,0 +1,170 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/snippets/CMakeFiles/snippets.dir/depend.make + +# Include the progress variables for this target. +include plugins/snippets/CMakeFiles/snippets.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/snippets/CMakeFiles/snippets.dir/flags.make + +plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp: ../plugins/snippets/snippets.qrc +plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp: plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Info.json +plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp: ../plugins/snippets/resources/snippet.svg +plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for snippets.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Info.json Debug + +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o: plugins/snippets/CMakeFiles/snippets.dir/flags.make +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o: plugins/snippets/snippets_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/mocs_compilation.cpp + +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/mocs_compilation.cpp > CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.i + +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/mocs_compilation.cpp -o CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.s + +plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.o: plugins/snippets/CMakeFiles/snippets.dir/flags.make +plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.o: ../plugins/snippets/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/snippets.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.cpp + +plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/snippets.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.cpp > CMakeFiles/snippets.dir/src/configwidget.cpp.i + +plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/snippets.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.cpp -o CMakeFiles/snippets.dir/src/configwidget.cpp.s + +plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.o: plugins/snippets/CMakeFiles/snippets.dir/flags.make +plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.o: ../plugins/snippets/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/snippets.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.cpp + +plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/snippets.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.cpp > CMakeFiles/snippets.dir/src/extension.cpp.i + +plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/snippets.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.cpp -o CMakeFiles/snippets.dir/src/extension.cpp.s + +plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o: plugins/snippets/CMakeFiles/snippets.dir/flags.make +plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o: ../plugins/snippets/src/snippeteditordialog.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.cpp + +plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.cpp > CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.i + +plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.cpp -o CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.s + +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o: plugins/snippets/CMakeFiles/snippets.dir/flags.make +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o: plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp + +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp > CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.i + +plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp -o CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.s + +# Object files for target snippets +snippets_OBJECTS = \ +"CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/snippets.dir/src/configwidget.cpp.o" \ +"CMakeFiles/snippets.dir/src/extension.cpp.o" \ +"CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o" \ +"CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o" + +# External object files for target snippets +snippets_EXTERNAL_OBJECTS = + +lib/libsnippets.so: plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o +lib/libsnippets.so: plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.o +lib/libsnippets.so: plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.o +lib/libsnippets.so: plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o +lib/libsnippets.so: plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o +lib/libsnippets.so: plugins/snippets/CMakeFiles/snippets.dir/build.make +lib/libsnippets.so: /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 +lib/libsnippets.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libsnippets.so: lib/libalbert.so +lib/libsnippets.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libsnippets.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libsnippets.so: plugins/snippets/CMakeFiles/snippets.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Linking CXX shared library ../../lib/libsnippets.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/snippets.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/snippets/CMakeFiles/snippets.dir/build: lib/libsnippets.so + +.PHONY : plugins/snippets/CMakeFiles/snippets.dir/build + +plugins/snippets/CMakeFiles/snippets.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && $(CMAKE_COMMAND) -P CMakeFiles/snippets.dir/cmake_clean.cmake +.PHONY : plugins/snippets/CMakeFiles/snippets.dir/clean + +plugins/snippets/CMakeFiles/snippets.dir/depend: plugins/snippets/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/snippets/CMakeFiles/snippets.dir/depend + diff --git a/build/plugins/snippets/CMakeFiles/snippets.dir/cmake_clean.cmake b/build/plugins/snippets/CMakeFiles/snippets.dir/cmake_clean.cmake new file mode 100644 index 0000000..9774cfe --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets.dir/cmake_clean.cmake @@ -0,0 +1,18 @@ +file(REMOVE_RECURSE + "../../lib/libsnippets.pdb" + "../../lib/libsnippets.so" + "CMakeFiles/snippets_autogen.dir/AutogenUsed.txt" + "CMakeFiles/snippets_autogen.dir/ParseCache.txt" + "snippets_autogen" + "CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o" + "CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o" + "CMakeFiles/snippets.dir/src/configwidget.cpp.o" + "CMakeFiles/snippets.dir/src/extension.cpp.o" + "CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o" + "snippets_autogen/EWIEGA46WW/qrc_snippets.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/snippets.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/snippets/CMakeFiles/snippets.dir/depend.make b/build/plugins/snippets/CMakeFiles/snippets.dir/depend.make new file mode 100644 index 0000000..e3bfe63 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for snippets. +# This may be replaced when dependencies are built. diff --git a/build/plugins/snippets/CMakeFiles/snippets.dir/flags.make b/build/plugins/snippets/CMakeFiles/snippets.dir/flags.make new file mode 100644 index 0000000..634ae29 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SQL_LIB -DQT_WIDGETS_LIB -Dsnippets_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSql -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui + diff --git a/build/plugins/snippets/CMakeFiles/snippets.dir/link.txt b/build/plugins/snippets/CMakeFiles/snippets.dir/link.txt new file mode 100644 index 0000000..7c00c7c --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libsnippets.so -o ../../lib/libsnippets.so CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o CMakeFiles/snippets.dir/src/configwidget.cpp.o CMakeFiles/snippets.dir/src/extension.cpp.o CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Sql.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/snippets/CMakeFiles/snippets.dir/progress.make b/build/plugins/snippets/CMakeFiles/snippets.dir/progress.make new file mode 100644 index 0000000..b3690d8 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets.dir/progress.make @@ -0,0 +1,8 @@ +CMAKE_PROGRESS_1 = +CMAKE_PROGRESS_2 = 68 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 69 +CMAKE_PROGRESS_5 = 70 +CMAKE_PROGRESS_6 = +CMAKE_PROGRESS_7 = 71 + diff --git a/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Info.json b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Info.json new file mode 100644 index 0000000..4ef3e79 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/resources/snippet.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "snippets" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_snippets.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutoRcc_snippets_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/snippets.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutogenInfo.json b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..caa194e --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutogenInfo.json @@ -0,0 +1,106 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.h", + "MU", + "UVLADIE3JM/moc_snippeteditordialog.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_SQL_LIB", + "QT_WIDGETS_LIB", + "snippets_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtSql", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/snippets_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/extension.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets/src/snippeteditordialog.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/DependInfo.cmake b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make new file mode 100644 index 0000000..11a9bd2 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for snippets_autogen. + +# Include the progress variables for this target. +include plugins/snippets/CMakeFiles/snippets_autogen.dir/progress.make + +plugins/snippets/CMakeFiles/snippets_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target snippets" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/AutogenInfo.json Debug + +snippets_autogen: plugins/snippets/CMakeFiles/snippets_autogen +snippets_autogen: plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make + +.PHONY : snippets_autogen + +# Rule to build all files generated by this target. +plugins/snippets/CMakeFiles/snippets_autogen.dir/build: snippets_autogen + +.PHONY : plugins/snippets/CMakeFiles/snippets_autogen.dir/build + +plugins/snippets/CMakeFiles/snippets_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets && $(CMAKE_COMMAND) -P CMakeFiles/snippets_autogen.dir/cmake_clean.cmake +.PHONY : plugins/snippets/CMakeFiles/snippets_autogen.dir/clean + +plugins/snippets/CMakeFiles/snippets_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/snippets/CMakeFiles/snippets_autogen.dir/depend + diff --git a/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/cmake_clean.cmake b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..26f5c8e --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/snippets_autogen" + "snippets_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/snippets_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/progress.make b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/progress.make new file mode 100644 index 0000000..b1815f3 --- /dev/null +++ b/build/plugins/snippets/CMakeFiles/snippets_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 72 + diff --git a/build/plugins/snippets/Makefile b/build/plugins/snippets/Makefile new file mode 100644 index 0000000..a7b5ca4 --- /dev/null +++ b/build/plugins/snippets/Makefile @@ -0,0 +1,366 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/snippets/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/snippets/CMakeFiles/snippets.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/CMakeFiles/snippets.dir/rule +.PHONY : plugins/snippets/CMakeFiles/snippets.dir/rule + +# Convenience name for target. +snippets: plugins/snippets/CMakeFiles/snippets.dir/rule + +.PHONY : snippets + +# fast build rule for target. +snippets/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/build +.PHONY : snippets/fast + +# Convenience name for target. +plugins/snippets/CMakeFiles/snippets_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/snippets/CMakeFiles/snippets_autogen.dir/rule +.PHONY : plugins/snippets/CMakeFiles/snippets_autogen.dir/rule + +# Convenience name for target. +snippets_autogen: plugins/snippets/CMakeFiles/snippets_autogen.dir/rule + +.PHONY : snippets_autogen + +# fast build rule for target. +snippets_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets_autogen.dir/build.make plugins/snippets/CMakeFiles/snippets_autogen.dir/build +.PHONY : snippets_autogen/fast + +snippets_autogen/EWIEGA46WW/qrc_snippets.o: snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o + +.PHONY : snippets_autogen/EWIEGA46WW/qrc_snippets.o + +# target to build an object file +snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o +.PHONY : snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.o + +snippets_autogen/EWIEGA46WW/qrc_snippets.i: snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.i + +.PHONY : snippets_autogen/EWIEGA46WW/qrc_snippets.i + +# target to preprocess a source file +snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.i +.PHONY : snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.i + +snippets_autogen/EWIEGA46WW/qrc_snippets.s: snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.s + +.PHONY : snippets_autogen/EWIEGA46WW/qrc_snippets.s + +# target to generate assembly for a file +snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.s +.PHONY : snippets_autogen/EWIEGA46WW/qrc_snippets.cpp.s + +snippets_autogen/mocs_compilation.o: snippets_autogen/mocs_compilation.cpp.o + +.PHONY : snippets_autogen/mocs_compilation.o + +# target to build an object file +snippets_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.o +.PHONY : snippets_autogen/mocs_compilation.cpp.o + +snippets_autogen/mocs_compilation.i: snippets_autogen/mocs_compilation.cpp.i + +.PHONY : snippets_autogen/mocs_compilation.i + +# target to preprocess a source file +snippets_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.i +.PHONY : snippets_autogen/mocs_compilation.cpp.i + +snippets_autogen/mocs_compilation.s: snippets_autogen/mocs_compilation.cpp.s + +.PHONY : snippets_autogen/mocs_compilation.s + +# target to generate assembly for a file +snippets_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/snippets_autogen/mocs_compilation.cpp.s +.PHONY : snippets_autogen/mocs_compilation.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +src/snippeteditordialog.o: src/snippeteditordialog.cpp.o + +.PHONY : src/snippeteditordialog.o + +# target to build an object file +src/snippeteditordialog.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.o +.PHONY : src/snippeteditordialog.cpp.o + +src/snippeteditordialog.i: src/snippeteditordialog.cpp.i + +.PHONY : src/snippeteditordialog.i + +# target to preprocess a source file +src/snippeteditordialog.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.i +.PHONY : src/snippeteditordialog.cpp.i + +src/snippeteditordialog.s: src/snippeteditordialog.cpp.s + +.PHONY : src/snippeteditordialog.s + +# target to generate assembly for a file +src/snippeteditordialog.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/snippets/CMakeFiles/snippets.dir/build.make plugins/snippets/CMakeFiles/snippets.dir/src/snippeteditordialog.cpp.s +.PHONY : src/snippeteditordialog.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... snippets" + @echo "... snippets_autogen" + @echo "... snippets_autogen/EWIEGA46WW/qrc_snippets.o" + @echo "... snippets_autogen/EWIEGA46WW/qrc_snippets.i" + @echo "... snippets_autogen/EWIEGA46WW/qrc_snippets.s" + @echo "... snippets_autogen/mocs_compilation.o" + @echo "... snippets_autogen/mocs_compilation.i" + @echo "... snippets_autogen/mocs_compilation.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... src/snippeteditordialog.o" + @echo "... src/snippeteditordialog.i" + @echo "... src/snippeteditordialog.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/snippets/cmake_install.cmake b/build/plugins/snippets/cmake_install.cmake new file mode 100644 index 0000000..26a5c03 --- /dev/null +++ b/build/plugins/snippets/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/snippets + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsnippets.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsnippets.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsnippets.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libsnippets.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsnippets.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsnippets.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsnippets.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsnippets.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/ssh/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/ssh/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/ssh/CMakeFiles/progress.marks b/build/plugins/ssh/CMakeFiles/progress.marks new file mode 100644 index 0000000..60d3b2f --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/progress.marks @@ -0,0 +1 @@ +15 diff --git a/build/plugins/ssh/CMakeFiles/ssh.dir/DependInfo.cmake b/build/plugins/ssh/CMakeFiles/ssh.dir/DependInfo.cmake new file mode 100644 index 0000000..9187d0c --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh.dir/DependInfo.cmake @@ -0,0 +1,45 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "ssh_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/ssh" + "../plugins/ssh" + "plugins/ssh/ssh_autogen/include" + "../plugins/ssh/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/ssh/CMakeFiles/ssh.dir/build.make b/build/plugins/ssh/CMakeFiles/ssh.dir/build.make new file mode 100644 index 0000000..c66b8a3 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh.dir/build.make @@ -0,0 +1,155 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/ssh/CMakeFiles/ssh.dir/depend.make + +# Include the progress variables for this target. +include plugins/ssh/CMakeFiles/ssh.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/ssh/CMakeFiles/ssh.dir/flags.make + +plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp: ../plugins/ssh/ssh.qrc +plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp: plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Info.json +plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp: ../plugins/ssh/resources/ssh.svg +plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for ssh.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Info.json Debug + +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o: plugins/ssh/CMakeFiles/ssh.dir/flags.make +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o: plugins/ssh/ssh_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/mocs_compilation.cpp + +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/mocs_compilation.cpp > CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.i + +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/mocs_compilation.cpp -o CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.s + +plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.o: plugins/ssh/CMakeFiles/ssh.dir/flags.make +plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.o: ../plugins/ssh/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/ssh.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.cpp + +plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/ssh.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.cpp > CMakeFiles/ssh.dir/src/configwidget.cpp.i + +plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/ssh.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.cpp -o CMakeFiles/ssh.dir/src/configwidget.cpp.s + +plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.o: plugins/ssh/CMakeFiles/ssh.dir/flags.make +plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.o: ../plugins/ssh/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/ssh.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.cpp + +plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/ssh.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.cpp > CMakeFiles/ssh.dir/src/extension.cpp.i + +plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/ssh.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.cpp -o CMakeFiles/ssh.dir/src/extension.cpp.s + +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o: plugins/ssh/CMakeFiles/ssh.dir/flags.make +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o: plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp + +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp > CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.i + +plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp -o CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.s + +# Object files for target ssh +ssh_OBJECTS = \ +"CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/ssh.dir/src/configwidget.cpp.o" \ +"CMakeFiles/ssh.dir/src/extension.cpp.o" \ +"CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o" + +# External object files for target ssh +ssh_EXTERNAL_OBJECTS = + +lib/libssh.so: plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o +lib/libssh.so: plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.o +lib/libssh.so: plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.o +lib/libssh.so: plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o +lib/libssh.so: plugins/ssh/CMakeFiles/ssh.dir/build.make +lib/libssh.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libssh.so: lib/libalbert.so +lib/libssh.so: lib/libxdg.so +lib/libssh.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libssh.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libssh.so: plugins/ssh/CMakeFiles/ssh.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Linking CXX shared library ../../lib/libssh.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/ssh.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/ssh/CMakeFiles/ssh.dir/build: lib/libssh.so + +.PHONY : plugins/ssh/CMakeFiles/ssh.dir/build + +plugins/ssh/CMakeFiles/ssh.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && $(CMAKE_COMMAND) -P CMakeFiles/ssh.dir/cmake_clean.cmake +.PHONY : plugins/ssh/CMakeFiles/ssh.dir/clean + +plugins/ssh/CMakeFiles/ssh.dir/depend: plugins/ssh/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/ssh/CMakeFiles/ssh.dir/depend + diff --git a/build/plugins/ssh/CMakeFiles/ssh.dir/cmake_clean.cmake b/build/plugins/ssh/CMakeFiles/ssh.dir/cmake_clean.cmake new file mode 100644 index 0000000..2551c83 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh.dir/cmake_clean.cmake @@ -0,0 +1,17 @@ +file(REMOVE_RECURSE + "../../lib/libssh.pdb" + "../../lib/libssh.so" + "CMakeFiles/ssh_autogen.dir/AutogenUsed.txt" + "CMakeFiles/ssh_autogen.dir/ParseCache.txt" + "ssh_autogen" + "CMakeFiles/ssh.dir/src/configwidget.cpp.o" + "CMakeFiles/ssh.dir/src/extension.cpp.o" + "CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o" + "CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o" + "ssh_autogen/EWIEGA46WW/qrc_ssh.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/ssh.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/ssh/CMakeFiles/ssh.dir/depend.make b/build/plugins/ssh/CMakeFiles/ssh.dir/depend.make new file mode 100644 index 0000000..498cf66 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for ssh. +# This may be replaced when dependencies are built. diff --git a/build/plugins/ssh/CMakeFiles/ssh.dir/flags.make b/build/plugins/ssh/CMakeFiles/ssh.dir/flags.make new file mode 100644 index 0000000..b7aafb2 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dssh_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ + diff --git a/build/plugins/ssh/CMakeFiles/ssh.dir/link.txt b/build/plugins/ssh/CMakeFiles/ssh.dir/link.txt new file mode 100644 index 0000000..c5a83fa --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libssh.so -o ../../lib/libssh.so CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o CMakeFiles/ssh.dir/src/configwidget.cpp.o CMakeFiles/ssh.dir/src/extension.cpp.o CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/ssh/CMakeFiles/ssh.dir/progress.make b/build/plugins/ssh/CMakeFiles/ssh.dir/progress.make new file mode 100644 index 0000000..0c6bf46 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh.dir/progress.make @@ -0,0 +1,7 @@ +CMAKE_PROGRESS_1 = +CMAKE_PROGRESS_2 = 73 +CMAKE_PROGRESS_3 = 74 +CMAKE_PROGRESS_4 = +CMAKE_PROGRESS_5 = 75 +CMAKE_PROGRESS_6 = + diff --git a/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Info.json b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Info.json new file mode 100644 index 0000000..91fe3b0 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/resources/ssh.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "ssh" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_ssh.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutoRcc_ssh_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/ssh.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutogenInfo.json b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..89ecc79 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutogenInfo.json @@ -0,0 +1,96 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "ssh_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/ssh_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/DependInfo.cmake b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make new file mode 100644 index 0000000..f06a9c3 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for ssh_autogen. + +# Include the progress variables for this target. +include plugins/ssh/CMakeFiles/ssh_autogen.dir/progress.make + +plugins/ssh/CMakeFiles/ssh_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target ssh" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/AutogenInfo.json Debug + +ssh_autogen: plugins/ssh/CMakeFiles/ssh_autogen +ssh_autogen: plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make + +.PHONY : ssh_autogen + +# Rule to build all files generated by this target. +plugins/ssh/CMakeFiles/ssh_autogen.dir/build: ssh_autogen + +.PHONY : plugins/ssh/CMakeFiles/ssh_autogen.dir/build + +plugins/ssh/CMakeFiles/ssh_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh && $(CMAKE_COMMAND) -P CMakeFiles/ssh_autogen.dir/cmake_clean.cmake +.PHONY : plugins/ssh/CMakeFiles/ssh_autogen.dir/clean + +plugins/ssh/CMakeFiles/ssh_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/ssh/CMakeFiles/ssh_autogen.dir/depend + diff --git a/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/cmake_clean.cmake b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..c91b53d --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/ssh_autogen" + "ssh_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/ssh_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/progress.make b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/progress.make new file mode 100644 index 0000000..b595f06 --- /dev/null +++ b/build/plugins/ssh/CMakeFiles/ssh_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 76 + diff --git a/build/plugins/ssh/Makefile b/build/plugins/ssh/Makefile new file mode 100644 index 0000000..6f66d33 --- /dev/null +++ b/build/plugins/ssh/Makefile @@ -0,0 +1,336 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/ssh/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/ssh/CMakeFiles/ssh.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/CMakeFiles/ssh.dir/rule +.PHONY : plugins/ssh/CMakeFiles/ssh.dir/rule + +# Convenience name for target. +ssh: plugins/ssh/CMakeFiles/ssh.dir/rule + +.PHONY : ssh + +# fast build rule for target. +ssh/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/build +.PHONY : ssh/fast + +# Convenience name for target. +plugins/ssh/CMakeFiles/ssh_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/ssh/CMakeFiles/ssh_autogen.dir/rule +.PHONY : plugins/ssh/CMakeFiles/ssh_autogen.dir/rule + +# Convenience name for target. +ssh_autogen: plugins/ssh/CMakeFiles/ssh_autogen.dir/rule + +.PHONY : ssh_autogen + +# fast build rule for target. +ssh_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh_autogen.dir/build.make plugins/ssh/CMakeFiles/ssh_autogen.dir/build +.PHONY : ssh_autogen/fast + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +ssh_autogen/EWIEGA46WW/qrc_ssh.o: ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o + +.PHONY : ssh_autogen/EWIEGA46WW/qrc_ssh.o + +# target to build an object file +ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o +.PHONY : ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.o + +ssh_autogen/EWIEGA46WW/qrc_ssh.i: ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.i + +.PHONY : ssh_autogen/EWIEGA46WW/qrc_ssh.i + +# target to preprocess a source file +ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.i +.PHONY : ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.i + +ssh_autogen/EWIEGA46WW/qrc_ssh.s: ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.s + +.PHONY : ssh_autogen/EWIEGA46WW/qrc_ssh.s + +# target to generate assembly for a file +ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.s +.PHONY : ssh_autogen/EWIEGA46WW/qrc_ssh.cpp.s + +ssh_autogen/mocs_compilation.o: ssh_autogen/mocs_compilation.cpp.o + +.PHONY : ssh_autogen/mocs_compilation.o + +# target to build an object file +ssh_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.o +.PHONY : ssh_autogen/mocs_compilation.cpp.o + +ssh_autogen/mocs_compilation.i: ssh_autogen/mocs_compilation.cpp.i + +.PHONY : ssh_autogen/mocs_compilation.i + +# target to preprocess a source file +ssh_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.i +.PHONY : ssh_autogen/mocs_compilation.cpp.i + +ssh_autogen/mocs_compilation.s: ssh_autogen/mocs_compilation.cpp.s + +.PHONY : ssh_autogen/mocs_compilation.s + +# target to generate assembly for a file +ssh_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/ssh/CMakeFiles/ssh.dir/build.make plugins/ssh/CMakeFiles/ssh.dir/ssh_autogen/mocs_compilation.cpp.s +.PHONY : ssh_autogen/mocs_compilation.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... ssh" + @echo "... ssh_autogen" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... ssh_autogen/EWIEGA46WW/qrc_ssh.o" + @echo "... ssh_autogen/EWIEGA46WW/qrc_ssh.i" + @echo "... ssh_autogen/EWIEGA46WW/qrc_ssh.s" + @echo "... ssh_autogen/mocs_compilation.o" + @echo "... ssh_autogen/mocs_compilation.i" + @echo "... ssh_autogen/mocs_compilation.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/ssh/cmake_install.cmake b/build/plugins/ssh/cmake_install.cmake new file mode 100644 index 0000000..c9eb5a8 --- /dev/null +++ b/build/plugins/ssh/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/ssh + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libssh.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libssh.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libssh.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libssh.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libssh.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libssh.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libssh.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libssh.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/system/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/system/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/system/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/system/CMakeFiles/progress.marks b/build/plugins/system/CMakeFiles/progress.marks new file mode 100644 index 0000000..b6a7d89 --- /dev/null +++ b/build/plugins/system/CMakeFiles/progress.marks @@ -0,0 +1 @@ +16 diff --git a/build/plugins/system/CMakeFiles/system.dir/DependInfo.cmake b/build/plugins/system/CMakeFiles/system.dir/DependInfo.cmake new file mode 100644 index 0000000..14d2ab6 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system.dir/DependInfo.cmake @@ -0,0 +1,45 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "system_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/system" + "../plugins/system" + "plugins/system/system_autogen/include" + "../plugins/system/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/system/CMakeFiles/system.dir/build.make b/build/plugins/system/CMakeFiles/system.dir/build.make new file mode 100644 index 0000000..fc9ecb8 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system.dir/build.make @@ -0,0 +1,160 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/system/CMakeFiles/system.dir/depend.make + +# Include the progress variables for this target. +include plugins/system/CMakeFiles/system.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/system/CMakeFiles/system.dir/flags.make + +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: ../plugins/system/system.qrc +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Info.json +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: ../plugins/system/resources/reboot.svg +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: ../plugins/system/resources/lock.svg +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: ../plugins/system/resources/hibernate.svg +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: ../plugins/system/resources/logout.svg +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: ../plugins/system/resources/suspend.svg +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: ../plugins/system/resources/poweroff.svg +plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for system.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Info.json Debug + +plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o: plugins/system/CMakeFiles/system.dir/flags.make +plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o: plugins/system/system_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/mocs_compilation.cpp + +plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/mocs_compilation.cpp > CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.i + +plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/mocs_compilation.cpp -o CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.s + +plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.o: plugins/system/CMakeFiles/system.dir/flags.make +plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.o: ../plugins/system/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/system.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.cpp + +plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/system.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.cpp > CMakeFiles/system.dir/src/configwidget.cpp.i + +plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/system.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.cpp -o CMakeFiles/system.dir/src/configwidget.cpp.s + +plugins/system/CMakeFiles/system.dir/src/extension.cpp.o: plugins/system/CMakeFiles/system.dir/flags.make +plugins/system/CMakeFiles/system.dir/src/extension.cpp.o: ../plugins/system/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/system/CMakeFiles/system.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/system.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.cpp + +plugins/system/CMakeFiles/system.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/system.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.cpp > CMakeFiles/system.dir/src/extension.cpp.i + +plugins/system/CMakeFiles/system.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/system.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.cpp -o CMakeFiles/system.dir/src/extension.cpp.s + +plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o: plugins/system/CMakeFiles/system.dir/flags.make +plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o: plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp + +plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp > CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.i + +plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp -o CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.s + +# Object files for target system +system_OBJECTS = \ +"CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/system.dir/src/configwidget.cpp.o" \ +"CMakeFiles/system.dir/src/extension.cpp.o" \ +"CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o" + +# External object files for target system +system_EXTERNAL_OBJECTS = + +lib/libsystem.so: plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o +lib/libsystem.so: plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.o +lib/libsystem.so: plugins/system/CMakeFiles/system.dir/src/extension.cpp.o +lib/libsystem.so: plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o +lib/libsystem.so: plugins/system/CMakeFiles/system.dir/build.make +lib/libsystem.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libsystem.so: lib/libalbert.so +lib/libsystem.so: lib/libxdg.so +lib/libsystem.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libsystem.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libsystem.so: plugins/system/CMakeFiles/system.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Linking CXX shared library ../../lib/libsystem.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/system.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/system/CMakeFiles/system.dir/build: lib/libsystem.so + +.PHONY : plugins/system/CMakeFiles/system.dir/build + +plugins/system/CMakeFiles/system.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && $(CMAKE_COMMAND) -P CMakeFiles/system.dir/cmake_clean.cmake +.PHONY : plugins/system/CMakeFiles/system.dir/clean + +plugins/system/CMakeFiles/system.dir/depend: plugins/system/system_autogen/EWIEGA46WW/qrc_system.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/system/CMakeFiles/system.dir/depend + diff --git a/build/plugins/system/CMakeFiles/system.dir/cmake_clean.cmake b/build/plugins/system/CMakeFiles/system.dir/cmake_clean.cmake new file mode 100644 index 0000000..aa6ab95 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system.dir/cmake_clean.cmake @@ -0,0 +1,17 @@ +file(REMOVE_RECURSE + "../../lib/libsystem.pdb" + "../../lib/libsystem.so" + "CMakeFiles/system_autogen.dir/AutogenUsed.txt" + "CMakeFiles/system_autogen.dir/ParseCache.txt" + "system_autogen" + "CMakeFiles/system.dir/src/configwidget.cpp.o" + "CMakeFiles/system.dir/src/extension.cpp.o" + "CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o" + "CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o" + "system_autogen/EWIEGA46WW/qrc_system.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/system.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/system/CMakeFiles/system.dir/depend.make b/build/plugins/system/CMakeFiles/system.dir/depend.make new file mode 100644 index 0000000..1e95653 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for system. +# This may be replaced when dependencies are built. diff --git a/build/plugins/system/CMakeFiles/system.dir/flags.make b/build/plugins/system/CMakeFiles/system.dir/flags.make new file mode 100644 index 0000000..8b5c07a --- /dev/null +++ b/build/plugins/system/CMakeFiles/system.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dsystem_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ + diff --git a/build/plugins/system/CMakeFiles/system.dir/link.txt b/build/plugins/system/CMakeFiles/system.dir/link.txt new file mode 100644 index 0000000..6466152 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libsystem.so -o ../../lib/libsystem.so CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o CMakeFiles/system.dir/src/configwidget.cpp.o CMakeFiles/system.dir/src/extension.cpp.o CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/system/CMakeFiles/system.dir/progress.make b/build/plugins/system/CMakeFiles/system.dir/progress.make new file mode 100644 index 0000000..d1486b6 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system.dir/progress.make @@ -0,0 +1,7 @@ +CMAKE_PROGRESS_1 = 77 +CMAKE_PROGRESS_2 = +CMAKE_PROGRESS_3 = 78 +CMAKE_PROGRESS_4 = 79 +CMAKE_PROGRESS_5 = +CMAKE_PROGRESS_6 = 80 + diff --git a/build/plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Info.json b/build/plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Info.json new file mode 100644 index 0000000..9ed7c47 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Info.json @@ -0,0 +1,27 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/resources/reboot.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/resources/lock.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/resources/hibernate.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/resources/logout.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/resources/suspend.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/resources/poweroff.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "system" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_system.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir/AutoRcc_system_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/system.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/system/CMakeFiles/system_autogen.dir/AutogenInfo.json b/build/plugins/system/CMakeFiles/system_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..84344e4 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system_autogen.dir/AutogenInfo.json @@ -0,0 +1,96 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "system_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/system_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/system/CMakeFiles/system_autogen.dir/DependInfo.cmake b/build/plugins/system/CMakeFiles/system_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/system/CMakeFiles/system_autogen.dir/build.make b/build/plugins/system/CMakeFiles/system_autogen.dir/build.make new file mode 100644 index 0000000..2d13af4 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for system_autogen. + +# Include the progress variables for this target. +include plugins/system/CMakeFiles/system_autogen.dir/progress.make + +plugins/system/CMakeFiles/system_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target system" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir/AutogenInfo.json Debug + +system_autogen: plugins/system/CMakeFiles/system_autogen +system_autogen: plugins/system/CMakeFiles/system_autogen.dir/build.make + +.PHONY : system_autogen + +# Rule to build all files generated by this target. +plugins/system/CMakeFiles/system_autogen.dir/build: system_autogen + +.PHONY : plugins/system/CMakeFiles/system_autogen.dir/build + +plugins/system/CMakeFiles/system_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system && $(CMAKE_COMMAND) -P CMakeFiles/system_autogen.dir/cmake_clean.cmake +.PHONY : plugins/system/CMakeFiles/system_autogen.dir/clean + +plugins/system/CMakeFiles/system_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/system_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/system/CMakeFiles/system_autogen.dir/depend + diff --git a/build/plugins/system/CMakeFiles/system_autogen.dir/cmake_clean.cmake b/build/plugins/system/CMakeFiles/system_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..a755dd7 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/system_autogen" + "system_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/system_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/system/CMakeFiles/system_autogen.dir/progress.make b/build/plugins/system/CMakeFiles/system_autogen.dir/progress.make new file mode 100644 index 0000000..4e4c166 --- /dev/null +++ b/build/plugins/system/CMakeFiles/system_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 81 + diff --git a/build/plugins/system/Makefile b/build/plugins/system/Makefile new file mode 100644 index 0000000..a1209f6 --- /dev/null +++ b/build/plugins/system/Makefile @@ -0,0 +1,336 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/system/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/system/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/system/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/system/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/system/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/system/CMakeFiles/system.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/system/CMakeFiles/system.dir/rule +.PHONY : plugins/system/CMakeFiles/system.dir/rule + +# Convenience name for target. +system: plugins/system/CMakeFiles/system.dir/rule + +.PHONY : system + +# fast build rule for target. +system/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/build +.PHONY : system/fast + +# Convenience name for target. +plugins/system/CMakeFiles/system_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/system/CMakeFiles/system_autogen.dir/rule +.PHONY : plugins/system/CMakeFiles/system_autogen.dir/rule + +# Convenience name for target. +system_autogen: plugins/system/CMakeFiles/system_autogen.dir/rule + +.PHONY : system_autogen + +# fast build rule for target. +system_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system_autogen.dir/build.make plugins/system/CMakeFiles/system_autogen.dir/build +.PHONY : system_autogen/fast + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +system_autogen/EWIEGA46WW/qrc_system.o: system_autogen/EWIEGA46WW/qrc_system.cpp.o + +.PHONY : system_autogen/EWIEGA46WW/qrc_system.o + +# target to build an object file +system_autogen/EWIEGA46WW/qrc_system.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.o +.PHONY : system_autogen/EWIEGA46WW/qrc_system.cpp.o + +system_autogen/EWIEGA46WW/qrc_system.i: system_autogen/EWIEGA46WW/qrc_system.cpp.i + +.PHONY : system_autogen/EWIEGA46WW/qrc_system.i + +# target to preprocess a source file +system_autogen/EWIEGA46WW/qrc_system.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.i +.PHONY : system_autogen/EWIEGA46WW/qrc_system.cpp.i + +system_autogen/EWIEGA46WW/qrc_system.s: system_autogen/EWIEGA46WW/qrc_system.cpp.s + +.PHONY : system_autogen/EWIEGA46WW/qrc_system.s + +# target to generate assembly for a file +system_autogen/EWIEGA46WW/qrc_system.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/system_autogen/EWIEGA46WW/qrc_system.cpp.s +.PHONY : system_autogen/EWIEGA46WW/qrc_system.cpp.s + +system_autogen/mocs_compilation.o: system_autogen/mocs_compilation.cpp.o + +.PHONY : system_autogen/mocs_compilation.o + +# target to build an object file +system_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.o +.PHONY : system_autogen/mocs_compilation.cpp.o + +system_autogen/mocs_compilation.i: system_autogen/mocs_compilation.cpp.i + +.PHONY : system_autogen/mocs_compilation.i + +# target to preprocess a source file +system_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.i +.PHONY : system_autogen/mocs_compilation.cpp.i + +system_autogen/mocs_compilation.s: system_autogen/mocs_compilation.cpp.s + +.PHONY : system_autogen/mocs_compilation.s + +# target to generate assembly for a file +system_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/system/CMakeFiles/system.dir/build.make plugins/system/CMakeFiles/system.dir/system_autogen/mocs_compilation.cpp.s +.PHONY : system_autogen/mocs_compilation.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... install/strip" + @echo "... system" + @echo "... system_autogen" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... system_autogen/EWIEGA46WW/qrc_system.o" + @echo "... system_autogen/EWIEGA46WW/qrc_system.i" + @echo "... system_autogen/EWIEGA46WW/qrc_system.s" + @echo "... system_autogen/mocs_compilation.o" + @echo "... system_autogen/mocs_compilation.i" + @echo "... system_autogen/mocs_compilation.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/system/cmake_install.cmake b/build/plugins/system/cmake_install.cmake new file mode 100644 index 0000000..89287fa --- /dev/null +++ b/build/plugins/system/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/system + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsystem.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsystem.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsystem.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libsystem.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsystem.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsystem.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsystem.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libsystem.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/terminal/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/terminal/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/terminal/CMakeFiles/progress.marks b/build/plugins/terminal/CMakeFiles/progress.marks new file mode 100644 index 0000000..8351c19 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/progress.marks @@ -0,0 +1 @@ +14 diff --git a/build/plugins/terminal/CMakeFiles/terminal.dir/DependInfo.cmake b/build/plugins/terminal/CMakeFiles/terminal.dir/DependInfo.cmake new file mode 100644 index 0000000..80ced9b --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal.dir/DependInfo.cmake @@ -0,0 +1,46 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CONCURRENT_LIB" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "terminal_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/terminal" + "../plugins/terminal" + "plugins/terminal/terminal_autogen/include" + "../plugins/terminal/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/terminal/CMakeFiles/terminal.dir/build.make b/build/plugins/terminal/CMakeFiles/terminal.dir/build.make new file mode 100644 index 0000000..216faa8 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal.dir/build.make @@ -0,0 +1,141 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/terminal/CMakeFiles/terminal.dir/depend.make + +# Include the progress variables for this target. +include plugins/terminal/CMakeFiles/terminal.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/terminal/CMakeFiles/terminal.dir/flags.make + +plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp: ../plugins/terminal/terminal.qrc +plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp: plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Info.json +plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp: ../plugins/terminal/resources/terminal.svg +plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for terminal.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Info.json Debug + +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o: plugins/terminal/CMakeFiles/terminal.dir/flags.make +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o: plugins/terminal/terminal_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/mocs_compilation.cpp + +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/mocs_compilation.cpp > CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.i + +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/mocs_compilation.cpp -o CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.s + +plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.o: plugins/terminal/CMakeFiles/terminal.dir/flags.make +plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.o: ../plugins/terminal/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/terminal.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.cpp + +plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/terminal.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.cpp > CMakeFiles/terminal.dir/src/extension.cpp.i + +plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/terminal.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.cpp -o CMakeFiles/terminal.dir/src/extension.cpp.s + +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o: plugins/terminal/CMakeFiles/terminal.dir/flags.make +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o: plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp + +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp > CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.i + +plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp -o CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.s + +# Object files for target terminal +terminal_OBJECTS = \ +"CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/terminal.dir/src/extension.cpp.o" \ +"CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o" + +# External object files for target terminal +terminal_EXTERNAL_OBJECTS = + +lib/libterminal.so: plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o +lib/libterminal.so: plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.o +lib/libterminal.so: plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o +lib/libterminal.so: plugins/terminal/CMakeFiles/terminal.dir/build.make +lib/libterminal.so: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 +lib/libterminal.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libterminal.so: lib/libalbert.so +lib/libterminal.so: lib/libxdg.so +lib/libterminal.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libterminal.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libterminal.so: plugins/terminal/CMakeFiles/terminal.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Linking CXX shared library ../../lib/libterminal.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/terminal.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/terminal/CMakeFiles/terminal.dir/build: lib/libterminal.so + +.PHONY : plugins/terminal/CMakeFiles/terminal.dir/build + +plugins/terminal/CMakeFiles/terminal.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && $(CMAKE_COMMAND) -P CMakeFiles/terminal.dir/cmake_clean.cmake +.PHONY : plugins/terminal/CMakeFiles/terminal.dir/clean + +plugins/terminal/CMakeFiles/terminal.dir/depend: plugins/terminal/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/terminal/CMakeFiles/terminal.dir/depend + diff --git a/build/plugins/terminal/CMakeFiles/terminal.dir/cmake_clean.cmake b/build/plugins/terminal/CMakeFiles/terminal.dir/cmake_clean.cmake new file mode 100644 index 0000000..a6c7573 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal.dir/cmake_clean.cmake @@ -0,0 +1,16 @@ +file(REMOVE_RECURSE + "../../lib/libterminal.pdb" + "../../lib/libterminal.so" + "CMakeFiles/terminal_autogen.dir/AutogenUsed.txt" + "CMakeFiles/terminal_autogen.dir/ParseCache.txt" + "terminal_autogen" + "CMakeFiles/terminal.dir/src/extension.cpp.o" + "CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o" + "CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o" + "terminal_autogen/EWIEGA46WW/qrc_terminal.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/terminal.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/terminal/CMakeFiles/terminal.dir/depend.make b/build/plugins/terminal/CMakeFiles/terminal.dir/depend.make new file mode 100644 index 0000000..f446587 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for terminal. +# This may be replaced when dependencies are built. diff --git a/build/plugins/terminal/CMakeFiles/terminal.dir/flags.make b/build/plugins/terminal/CMakeFiles/terminal.dir/flags.make new file mode 100644 index 0000000..3c245c4 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CONCURRENT_LIB -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dterminal_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtConcurrent -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui + diff --git a/build/plugins/terminal/CMakeFiles/terminal.dir/link.txt b/build/plugins/terminal/CMakeFiles/terminal.dir/link.txt new file mode 100644 index 0000000..7cc48c5 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libterminal.so -o ../../lib/libterminal.so CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o CMakeFiles/terminal.dir/src/extension.cpp.o CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Concurrent.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/terminal/CMakeFiles/terminal.dir/progress.make b/build/plugins/terminal/CMakeFiles/terminal.dir/progress.make new file mode 100644 index 0000000..4e91e7b --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal.dir/progress.make @@ -0,0 +1,6 @@ +CMAKE_PROGRESS_1 = +CMAKE_PROGRESS_2 = 82 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 83 +CMAKE_PROGRESS_5 = 84 + diff --git a/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Info.json b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Info.json new file mode 100644 index 0000000..b75dad1 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Info.json @@ -0,0 +1,22 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/resources/terminal.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "terminal" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_terminal.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutoRcc_terminal_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/terminal.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutogenInfo.json b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..9dee01f --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutogenInfo.json @@ -0,0 +1,89 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CONCURRENT_LIB", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "terminal_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtConcurrent", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/terminal_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal/src/extension.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/DependInfo.cmake b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make new file mode 100644 index 0000000..bf83861 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for terminal_autogen. + +# Include the progress variables for this target. +include plugins/terminal/CMakeFiles/terminal_autogen.dir/progress.make + +plugins/terminal/CMakeFiles/terminal_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target terminal" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/AutogenInfo.json Debug + +terminal_autogen: plugins/terminal/CMakeFiles/terminal_autogen +terminal_autogen: plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make + +.PHONY : terminal_autogen + +# Rule to build all files generated by this target. +plugins/terminal/CMakeFiles/terminal_autogen.dir/build: terminal_autogen + +.PHONY : plugins/terminal/CMakeFiles/terminal_autogen.dir/build + +plugins/terminal/CMakeFiles/terminal_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal && $(CMAKE_COMMAND) -P CMakeFiles/terminal_autogen.dir/cmake_clean.cmake +.PHONY : plugins/terminal/CMakeFiles/terminal_autogen.dir/clean + +plugins/terminal/CMakeFiles/terminal_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/terminal/CMakeFiles/terminal_autogen.dir/depend + diff --git a/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/cmake_clean.cmake b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..d169dd7 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/terminal_autogen" + "terminal_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/terminal_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/progress.make b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/plugins/terminal/CMakeFiles/terminal_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/plugins/terminal/Makefile b/build/plugins/terminal/Makefile new file mode 100644 index 0000000..7a839c2 --- /dev/null +++ b/build/plugins/terminal/Makefile @@ -0,0 +1,306 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/terminal/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/terminal/CMakeFiles/terminal.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/CMakeFiles/terminal.dir/rule +.PHONY : plugins/terminal/CMakeFiles/terminal.dir/rule + +# Convenience name for target. +terminal: plugins/terminal/CMakeFiles/terminal.dir/rule + +.PHONY : terminal + +# fast build rule for target. +terminal/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/build +.PHONY : terminal/fast + +# Convenience name for target. +plugins/terminal/CMakeFiles/terminal_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/terminal/CMakeFiles/terminal_autogen.dir/rule +.PHONY : plugins/terminal/CMakeFiles/terminal_autogen.dir/rule + +# Convenience name for target. +terminal_autogen: plugins/terminal/CMakeFiles/terminal_autogen.dir/rule + +.PHONY : terminal_autogen + +# fast build rule for target. +terminal_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal_autogen.dir/build.make plugins/terminal/CMakeFiles/terminal_autogen.dir/build +.PHONY : terminal_autogen/fast + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +terminal_autogen/EWIEGA46WW/qrc_terminal.o: terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o + +.PHONY : terminal_autogen/EWIEGA46WW/qrc_terminal.o + +# target to build an object file +terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o +.PHONY : terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.o + +terminal_autogen/EWIEGA46WW/qrc_terminal.i: terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.i + +.PHONY : terminal_autogen/EWIEGA46WW/qrc_terminal.i + +# target to preprocess a source file +terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.i +.PHONY : terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.i + +terminal_autogen/EWIEGA46WW/qrc_terminal.s: terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.s + +.PHONY : terminal_autogen/EWIEGA46WW/qrc_terminal.s + +# target to generate assembly for a file +terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.s +.PHONY : terminal_autogen/EWIEGA46WW/qrc_terminal.cpp.s + +terminal_autogen/mocs_compilation.o: terminal_autogen/mocs_compilation.cpp.o + +.PHONY : terminal_autogen/mocs_compilation.o + +# target to build an object file +terminal_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.o +.PHONY : terminal_autogen/mocs_compilation.cpp.o + +terminal_autogen/mocs_compilation.i: terminal_autogen/mocs_compilation.cpp.i + +.PHONY : terminal_autogen/mocs_compilation.i + +# target to preprocess a source file +terminal_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.i +.PHONY : terminal_autogen/mocs_compilation.cpp.i + +terminal_autogen/mocs_compilation.s: terminal_autogen/mocs_compilation.cpp.s + +.PHONY : terminal_autogen/mocs_compilation.s + +# target to generate assembly for a file +terminal_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/terminal/CMakeFiles/terminal.dir/build.make plugins/terminal/CMakeFiles/terminal.dir/terminal_autogen/mocs_compilation.cpp.s +.PHONY : terminal_autogen/mocs_compilation.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... edit_cache" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... terminal" + @echo "... terminal_autogen" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... terminal_autogen/EWIEGA46WW/qrc_terminal.o" + @echo "... terminal_autogen/EWIEGA46WW/qrc_terminal.i" + @echo "... terminal_autogen/EWIEGA46WW/qrc_terminal.s" + @echo "... terminal_autogen/mocs_compilation.o" + @echo "... terminal_autogen/mocs_compilation.i" + @echo "... terminal_autogen/mocs_compilation.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/terminal/cmake_install.cmake b/build/plugins/terminal/cmake_install.cmake new file mode 100644 index 0000000..eb8e9bc --- /dev/null +++ b/build/plugins/terminal/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/terminal + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libterminal.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libterminal.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libterminal.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libterminal.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libterminal.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libterminal.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libterminal.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libterminal.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/websearch/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/websearch/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/websearch/CMakeFiles/progress.marks b/build/plugins/websearch/CMakeFiles/progress.marks new file mode 100644 index 0000000..98d9bcb --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/progress.marks @@ -0,0 +1 @@ +17 diff --git a/build/plugins/websearch/CMakeFiles/websearch.dir/DependInfo.cmake b/build/plugins/websearch/CMakeFiles/websearch.dir/DependInfo.cmake new file mode 100644 index 0000000..66c6987 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch.dir/DependInfo.cmake @@ -0,0 +1,47 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_WIDGETS_LIB" + "websearch_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/websearch" + "../plugins/websearch" + "plugins/websearch/websearch_autogen/include" + "../plugins/websearch/src" + "../include" + "../lib/xdg/include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/xdg/CMakeFiles/xdg.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/websearch/CMakeFiles/websearch.dir/build.make b/build/plugins/websearch/CMakeFiles/websearch.dir/build.make new file mode 100644 index 0000000..63f7d51 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch.dir/build.make @@ -0,0 +1,193 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/websearch/CMakeFiles/websearch.dir/depend.make + +# Include the progress variables for this target. +include plugins/websearch/CMakeFiles/websearch.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/websearch/CMakeFiles/websearch.dir/flags.make + +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/websearch.qrc +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Info.json +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/wikipedia.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/wolfram.png +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/duckduckgo.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/amazon.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/ebay.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/youtube.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/google.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/default.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: ../plugins/websearch/resources/octocat.svg +plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp: /usr/lib/qt5/bin/rcc + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic RCC for websearch.qrc" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /usr/bin/cmake -E cmake_autorcc /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Info.json Debug + +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o: plugins/websearch/CMakeFiles/websearch.dir/flags.make +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o: plugins/websearch/websearch_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/mocs_compilation.cpp + +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/mocs_compilation.cpp > CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.i + +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/mocs_compilation.cpp -o CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.s + +plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.o: plugins/websearch/CMakeFiles/websearch.dir/flags.make +plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.o: ../plugins/websearch/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/websearch.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.cpp + +plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/websearch.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.cpp > CMakeFiles/websearch.dir/src/configwidget.cpp.i + +plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/websearch.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.cpp -o CMakeFiles/websearch.dir/src/configwidget.cpp.s + +plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.o: plugins/websearch/CMakeFiles/websearch.dir/flags.make +plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.o: ../plugins/websearch/src/enginesmodel.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/websearch.dir/src/enginesmodel.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.cpp + +plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/websearch.dir/src/enginesmodel.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.cpp > CMakeFiles/websearch.dir/src/enginesmodel.cpp.i + +plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/websearch.dir/src/enginesmodel.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.cpp -o CMakeFiles/websearch.dir/src/enginesmodel.cpp.s + +plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.o: plugins/websearch/CMakeFiles/websearch.dir/flags.make +plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.o: ../plugins/websearch/src/extension.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/websearch.dir/src/extension.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.cpp + +plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/websearch.dir/src/extension.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.cpp > CMakeFiles/websearch.dir/src/extension.cpp.i + +plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/websearch.dir/src/extension.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.cpp -o CMakeFiles/websearch.dir/src/extension.cpp.s + +plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o: plugins/websearch/CMakeFiles/websearch.dir/flags.make +plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o: ../plugins/websearch/src/searchengineeditor.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.cpp + +plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/websearch.dir/src/searchengineeditor.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.cpp > CMakeFiles/websearch.dir/src/searchengineeditor.cpp.i + +plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/websearch.dir/src/searchengineeditor.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.cpp -o CMakeFiles/websearch.dir/src/searchengineeditor.cpp.s + +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o: plugins/websearch/CMakeFiles/websearch.dir/flags.make +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o: plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Building CXX object plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp + +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp > CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.i + +plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp -o CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.s + +# Object files for target websearch +websearch_OBJECTS = \ +"CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/websearch.dir/src/configwidget.cpp.o" \ +"CMakeFiles/websearch.dir/src/enginesmodel.cpp.o" \ +"CMakeFiles/websearch.dir/src/extension.cpp.o" \ +"CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o" \ +"CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o" + +# External object files for target websearch +websearch_EXTERNAL_OBJECTS = + +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.o +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.o +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.o +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/build.make +lib/libwebsearch.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libwebsearch.so: lib/libalbert.so +lib/libwebsearch.so: lib/libxdg.so +lib/libwebsearch.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libwebsearch.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libwebsearch.so: plugins/websearch/CMakeFiles/websearch.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_8) "Linking CXX shared library ../../lib/libwebsearch.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/websearch.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/websearch/CMakeFiles/websearch.dir/build: lib/libwebsearch.so + +.PHONY : plugins/websearch/CMakeFiles/websearch.dir/build + +plugins/websearch/CMakeFiles/websearch.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && $(CMAKE_COMMAND) -P CMakeFiles/websearch.dir/cmake_clean.cmake +.PHONY : plugins/websearch/CMakeFiles/websearch.dir/clean + +plugins/websearch/CMakeFiles/websearch.dir/depend: plugins/websearch/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/websearch/CMakeFiles/websearch.dir/depend + diff --git a/build/plugins/websearch/CMakeFiles/websearch.dir/cmake_clean.cmake b/build/plugins/websearch/CMakeFiles/websearch.dir/cmake_clean.cmake new file mode 100644 index 0000000..149f800 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch.dir/cmake_clean.cmake @@ -0,0 +1,19 @@ +file(REMOVE_RECURSE + "../../lib/libwebsearch.pdb" + "../../lib/libwebsearch.so" + "CMakeFiles/websearch_autogen.dir/AutogenUsed.txt" + "CMakeFiles/websearch_autogen.dir/ParseCache.txt" + "websearch_autogen" + "CMakeFiles/websearch.dir/src/configwidget.cpp.o" + "CMakeFiles/websearch.dir/src/enginesmodel.cpp.o" + "CMakeFiles/websearch.dir/src/extension.cpp.o" + "CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o" + "CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o" + "CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o" + "websearch_autogen/EWIEGA46WW/qrc_websearch.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/websearch.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/websearch/CMakeFiles/websearch.dir/depend.make b/build/plugins/websearch/CMakeFiles/websearch.dir/depend.make new file mode 100644 index 0000000..9bbfa3c --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for websearch. +# This may be replaced when dependencies are built. diff --git a/build/plugins/websearch/CMakeFiles/websearch.dir/flags.make b/build/plugins/websearch/CMakeFiles/websearch.dir/flags.make new file mode 100644 index 0000000..9072b5f --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_WIDGETS_LIB -Dwebsearch_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ + diff --git a/build/plugins/websearch/CMakeFiles/websearch.dir/link.txt b/build/plugins/websearch/CMakeFiles/websearch.dir/link.txt new file mode 100644 index 0000000..bb46e9d --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libwebsearch.so -o ../../lib/libwebsearch.so CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o CMakeFiles/websearch.dir/src/configwidget.cpp.o CMakeFiles/websearch.dir/src/enginesmodel.cpp.o CMakeFiles/websearch.dir/src/extension.cpp.o CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 ../../lib/libalbert.so ../../lib/libxdg.so /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/websearch/CMakeFiles/websearch.dir/progress.make b/build/plugins/websearch/CMakeFiles/websearch.dir/progress.make new file mode 100644 index 0000000..158ac0c --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch.dir/progress.make @@ -0,0 +1,9 @@ +CMAKE_PROGRESS_1 = 85 +CMAKE_PROGRESS_2 = 86 +CMAKE_PROGRESS_3 = +CMAKE_PROGRESS_4 = 87 +CMAKE_PROGRESS_5 = +CMAKE_PROGRESS_6 = 88 +CMAKE_PROGRESS_7 = 89 +CMAKE_PROGRESS_8 = + diff --git a/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Info.json b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Info.json new file mode 100644 index 0000000..da9285c --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Info.json @@ -0,0 +1,30 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include", + "INPUTS" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/wikipedia.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/wolfram.png", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/duckduckgo.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/amazon.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/ebay.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/youtube.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/google.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/default.svg", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/resources/octocat.svg" + ], + "LOCK_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Lock.lock", + "MULTI_CONFIG" : false, + "OPTIONS" : [ "-name", "websearch" ], + "OUTPUT_CHECKSUM" : "EWIEGA46WW", + "OUTPUT_NAME" : "qrc_websearch.cpp", + "RCC_EXECUTABLE" : "/usr/lib/qt5/bin/rcc", + "RCC_LIST_OPTIONS" : [ "--list" ], + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutoRcc_websearch_EWIEGA46WW_Used.txt", + "SOURCE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/websearch.qrc", + "VERBOSITY" : 0 +} diff --git a/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutogenInfo.json b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..c5f7622 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutogenInfo.json @@ -0,0 +1,119 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.h", + "MU", + "UVLADIE3JM/moc_enginesmodel.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.h", + "MU", + "UVLADIE3JM/moc_extension.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengine.h", + "MU", + "UVLADIE3JM/moc_searchengine.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.h", + "MU", + "UVLADIE3JM/moc_searchengineeditor.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_WIDGETS_LIB", + "websearch_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/lib/xdg/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/websearch_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/enginesmodel.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/extension.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch/src/searchengineeditor.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/DependInfo.cmake b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make new file mode 100644 index 0000000..ed99cc2 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for websearch_autogen. + +# Include the progress variables for this target. +include plugins/websearch/CMakeFiles/websearch_autogen.dir/progress.make + +plugins/websearch/CMakeFiles/websearch_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target websearch" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/AutogenInfo.json Debug + +websearch_autogen: plugins/websearch/CMakeFiles/websearch_autogen +websearch_autogen: plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make + +.PHONY : websearch_autogen + +# Rule to build all files generated by this target. +plugins/websearch/CMakeFiles/websearch_autogen.dir/build: websearch_autogen + +.PHONY : plugins/websearch/CMakeFiles/websearch_autogen.dir/build + +plugins/websearch/CMakeFiles/websearch_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch && $(CMAKE_COMMAND) -P CMakeFiles/websearch_autogen.dir/cmake_clean.cmake +.PHONY : plugins/websearch/CMakeFiles/websearch_autogen.dir/clean + +plugins/websearch/CMakeFiles/websearch_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/websearch/CMakeFiles/websearch_autogen.dir/depend + diff --git a/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/cmake_clean.cmake b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..58af5f1 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/websearch_autogen" + "websearch_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/websearch_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/progress.make b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/progress.make new file mode 100644 index 0000000..0394dc7 --- /dev/null +++ b/build/plugins/websearch/CMakeFiles/websearch_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = 90 + diff --git a/build/plugins/websearch/Makefile b/build/plugins/websearch/Makefile new file mode 100644 index 0000000..109e325 --- /dev/null +++ b/build/plugins/websearch/Makefile @@ -0,0 +1,396 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/websearch/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/websearch/CMakeFiles/websearch.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/CMakeFiles/websearch.dir/rule +.PHONY : plugins/websearch/CMakeFiles/websearch.dir/rule + +# Convenience name for target. +websearch: plugins/websearch/CMakeFiles/websearch.dir/rule + +.PHONY : websearch + +# fast build rule for target. +websearch/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/build +.PHONY : websearch/fast + +# Convenience name for target. +plugins/websearch/CMakeFiles/websearch_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/websearch/CMakeFiles/websearch_autogen.dir/rule +.PHONY : plugins/websearch/CMakeFiles/websearch_autogen.dir/rule + +# Convenience name for target. +websearch_autogen: plugins/websearch/CMakeFiles/websearch_autogen.dir/rule + +.PHONY : websearch_autogen + +# fast build rule for target. +websearch_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch_autogen.dir/build.make plugins/websearch/CMakeFiles/websearch_autogen.dir/build +.PHONY : websearch_autogen/fast + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/enginesmodel.o: src/enginesmodel.cpp.o + +.PHONY : src/enginesmodel.o + +# target to build an object file +src/enginesmodel.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.o +.PHONY : src/enginesmodel.cpp.o + +src/enginesmodel.i: src/enginesmodel.cpp.i + +.PHONY : src/enginesmodel.i + +# target to preprocess a source file +src/enginesmodel.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.i +.PHONY : src/enginesmodel.cpp.i + +src/enginesmodel.s: src/enginesmodel.cpp.s + +.PHONY : src/enginesmodel.s + +# target to generate assembly for a file +src/enginesmodel.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/enginesmodel.cpp.s +.PHONY : src/enginesmodel.cpp.s + +src/extension.o: src/extension.cpp.o + +.PHONY : src/extension.o + +# target to build an object file +src/extension.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.o +.PHONY : src/extension.cpp.o + +src/extension.i: src/extension.cpp.i + +.PHONY : src/extension.i + +# target to preprocess a source file +src/extension.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.i +.PHONY : src/extension.cpp.i + +src/extension.s: src/extension.cpp.s + +.PHONY : src/extension.s + +# target to generate assembly for a file +src/extension.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/extension.cpp.s +.PHONY : src/extension.cpp.s + +src/searchengineeditor.o: src/searchengineeditor.cpp.o + +.PHONY : src/searchengineeditor.o + +# target to build an object file +src/searchengineeditor.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.o +.PHONY : src/searchengineeditor.cpp.o + +src/searchengineeditor.i: src/searchengineeditor.cpp.i + +.PHONY : src/searchengineeditor.i + +# target to preprocess a source file +src/searchengineeditor.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.i +.PHONY : src/searchengineeditor.cpp.i + +src/searchengineeditor.s: src/searchengineeditor.cpp.s + +.PHONY : src/searchengineeditor.s + +# target to generate assembly for a file +src/searchengineeditor.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/src/searchengineeditor.cpp.s +.PHONY : src/searchengineeditor.cpp.s + +websearch_autogen/EWIEGA46WW/qrc_websearch.o: websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o + +.PHONY : websearch_autogen/EWIEGA46WW/qrc_websearch.o + +# target to build an object file +websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o +.PHONY : websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.o + +websearch_autogen/EWIEGA46WW/qrc_websearch.i: websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.i + +.PHONY : websearch_autogen/EWIEGA46WW/qrc_websearch.i + +# target to preprocess a source file +websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.i +.PHONY : websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.i + +websearch_autogen/EWIEGA46WW/qrc_websearch.s: websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.s + +.PHONY : websearch_autogen/EWIEGA46WW/qrc_websearch.s + +# target to generate assembly for a file +websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.s +.PHONY : websearch_autogen/EWIEGA46WW/qrc_websearch.cpp.s + +websearch_autogen/mocs_compilation.o: websearch_autogen/mocs_compilation.cpp.o + +.PHONY : websearch_autogen/mocs_compilation.o + +# target to build an object file +websearch_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.o +.PHONY : websearch_autogen/mocs_compilation.cpp.o + +websearch_autogen/mocs_compilation.i: websearch_autogen/mocs_compilation.cpp.i + +.PHONY : websearch_autogen/mocs_compilation.i + +# target to preprocess a source file +websearch_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.i +.PHONY : websearch_autogen/mocs_compilation.cpp.i + +websearch_autogen/mocs_compilation.s: websearch_autogen/mocs_compilation.cpp.s + +.PHONY : websearch_autogen/mocs_compilation.s + +# target to generate assembly for a file +websearch_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/websearch/CMakeFiles/websearch.dir/build.make plugins/websearch/CMakeFiles/websearch.dir/websearch_autogen/mocs_compilation.cpp.s +.PHONY : websearch_autogen/mocs_compilation.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... edit_cache" + @echo "... websearch" + @echo "... websearch_autogen" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/enginesmodel.o" + @echo "... src/enginesmodel.i" + @echo "... src/enginesmodel.s" + @echo "... src/extension.o" + @echo "... src/extension.i" + @echo "... src/extension.s" + @echo "... src/searchengineeditor.o" + @echo "... src/searchengineeditor.i" + @echo "... src/searchengineeditor.s" + @echo "... websearch_autogen/EWIEGA46WW/qrc_websearch.o" + @echo "... websearch_autogen/EWIEGA46WW/qrc_websearch.i" + @echo "... websearch_autogen/EWIEGA46WW/qrc_websearch.s" + @echo "... websearch_autogen/mocs_compilation.o" + @echo "... websearch_autogen/mocs_compilation.i" + @echo "... websearch_autogen/mocs_compilation.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/websearch/cmake_install.cmake b/build/plugins/websearch/cmake_install.cmake new file mode 100644 index 0000000..fb10fb8 --- /dev/null +++ b/build/plugins/websearch/cmake_install.cmake @@ -0,0 +1,62 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/websearch + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwebsearch.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwebsearch.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwebsearch.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libwebsearch.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwebsearch.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwebsearch.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwebsearch.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwebsearch.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + diff --git a/build/plugins/widgetboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake b/build/plugins/widgetboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake new file mode 100644 index 0000000..ff39ccc --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/CMakeDirectoryInformation.cmake @@ -0,0 +1,16 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Relative path conversion top directories. +set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/hamonikr/workspaces/tmp/albert-0.17.2") +set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/hamonikr/workspaces/tmp/albert-0.17.2/build") + +# Force unix paths in dependencies. +set(CMAKE_FORCE_UNIX_PATHS 1) + + +# The C and CXX include file regular expressions for this directory. +set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$") +set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$") +set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN}) +set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN}) diff --git a/build/plugins/widgetboxmodel/CMakeFiles/progress.marks b/build/plugins/widgetboxmodel/CMakeFiles/progress.marks new file mode 100644 index 0000000..b1bd38b --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/progress.marks @@ -0,0 +1 @@ +13 diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/DependInfo.cmake b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/DependInfo.cmake new file mode 100644 index 0000000..b6acc7a --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/DependInfo.cmake @@ -0,0 +1,51 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + "CXX" + ) +# The set of files for implicit dependencies of each language: +set(CMAKE_DEPENDS_CHECK_CXX + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o" + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp" "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o" + ) +set(CMAKE_CXX_COMPILER_ID "GNU") + +# Preprocessor definitions for this target. +set(CMAKE_TARGET_DEFINITIONS_CXX + "ALBERT_VERSION=\"0.17.2\"" + "QT_CORE_LIB" + "QT_GUI_LIB" + "QT_SVG_LIB" + "QT_WIDGETS_LIB" + "QT_X11EXTRAS_LIB" + "widgetboxmodel_EXPORTS" + ) + +# The include file search paths: +set(CMAKE_CXX_TARGET_INCLUDE_PATH + "plugins/widgetboxmodel" + "../plugins/widgetboxmodel" + "plugins/widgetboxmodel/widgetboxmodel_autogen/include" + "../plugins/widgetboxmodel/src" + "../include" + "/usr/include/x86_64-linux-gnu/qt5" + "/usr/include/x86_64-linux-gnu/qt5/QtSvg" + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets" + "/usr/include/x86_64-linux-gnu/qt5/QtGui" + "/usr/include/x86_64-linux-gnu/qt5/QtCore" + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++" + "/usr/include/x86_64-linux-gnu/qt5/QtX11Extras" + ) + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles/albert-lib.dir/DependInfo.cmake" + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make new file mode 100644 index 0000000..f4552c2 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make @@ -0,0 +1,209 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Include any dependencies generated for this target. +include plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend.make + +# Include the progress variables for this target. +include plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/progress.make + +# Include the compile flags for this target's objects. +include plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o: plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp > CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp -o CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.s + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o: ../plugins/widgetboxmodel/src/actionlist.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_2) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.cpp > CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.cpp -o CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.s + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o: ../plugins/widgetboxmodel/src/configwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_3) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.cpp > CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.cpp -o CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.s + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o: ../plugins/widgetboxmodel/src/frontendplugin.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_4) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.cpp > CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.cpp -o CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.s + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o: ../plugins/widgetboxmodel/src/frontendwidget.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_5) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.cpp > CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.cpp -o CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.s + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o: ../plugins/widgetboxmodel/src/resizinglist.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_6) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.cpp > CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.cpp -o CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.s + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o: ../plugins/widgetboxmodel/src/resultslist.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_7) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.cpp > CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.cpp -o CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.s + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o: ../plugins/widgetboxmodel/src/settingsbutton.cpp + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_8) "Building CXX object plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -o CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o -c /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.cpp + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.i: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Preprocessing CXX source to CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.i" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -E /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.cpp > CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.i + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.s: cmake_force + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green "Compiling CXX source to assembly CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.s" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /bin/x86_64-linux-gnu-g++-9 $(CXX_DEFINES) $(CXX_INCLUDES) $(CXX_FLAGS) -S /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.cpp -o CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.s + +# Object files for target widgetboxmodel +widgetboxmodel_OBJECTS = \ +"CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o" \ +"CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o" \ +"CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o" \ +"CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o" \ +"CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o" \ +"CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o" \ +"CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o" \ +"CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o" + +# External object files for target widgetboxmodel +widgetboxmodel_EXTERNAL_OBJECTS = + +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make +lib/libwidgetboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Svg.so.5.12.8 +lib/libwidgetboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 +lib/libwidgetboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5.12.8 +lib/libwidgetboxmodel.so: lib/libalbert.so +lib/libwidgetboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 +lib/libwidgetboxmodel.so: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 +lib/libwidgetboxmodel.so: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/link.txt + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --green --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_9) "Linking CXX shared library ../../lib/libwidgetboxmodel.so" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && $(CMAKE_COMMAND) -E cmake_link_script CMakeFiles/widgetboxmodel.dir/link.txt --verbose=$(VERBOSE) + +# Rule to build all files generated by this target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build: lib/libwidgetboxmodel.so + +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && $(CMAKE_COMMAND) -P CMakeFiles/widgetboxmodel.dir/cmake_clean.cmake +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/clean + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend + diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/cmake_clean.cmake b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/cmake_clean.cmake new file mode 100644 index 0000000..74200c8 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/cmake_clean.cmake @@ -0,0 +1,20 @@ +file(REMOVE_RECURSE + "../../lib/libwidgetboxmodel.pdb" + "../../lib/libwidgetboxmodel.so" + "CMakeFiles/widgetboxmodel_autogen.dir/AutogenUsed.txt" + "CMakeFiles/widgetboxmodel_autogen.dir/ParseCache.txt" + "widgetboxmodel_autogen" + "CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o" + "CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o" + "CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o" + "CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o" + "CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o" + "CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o" + "CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o" + "CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o" +) + +# Per-language clean rules from dependency scanning. +foreach(lang CXX) + include(CMakeFiles/widgetboxmodel.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend.make b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend.make new file mode 100644 index 0000000..2494f30 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/depend.make @@ -0,0 +1,2 @@ +# Empty dependencies file for widgetboxmodel. +# This may be replaced when dependencies are built. diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make new file mode 100644 index 0000000..d16b9a7 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/flags.make @@ -0,0 +1,10 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# compile CXX with /bin/x86_64-linux-gnu-g++-9 +CXX_FLAGS = -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -fPIC -std=c++14 + +CXX_DEFINES = -DALBERT_VERSION=\"0.17.2\" -DQT_CORE_LIB -DQT_GUI_LIB -DQT_SVG_LIB -DQT_WIDGETS_LIB -DQT_X11EXTRAS_LIB -Dwidgetboxmodel_EXPORTS + +CXX_INCLUDES = -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel -I/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include -I/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src -I/home/hamonikr/workspaces/tmp/albert-0.17.2/include -isystem /usr/include/x86_64-linux-gnu/qt5 -isystem /usr/include/x86_64-linux-gnu/qt5/QtSvg -isystem /usr/include/x86_64-linux-gnu/qt5/QtWidgets -isystem /usr/include/x86_64-linux-gnu/qt5/QtGui -isystem /usr/include/x86_64-linux-gnu/qt5/QtCore -isystem /usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++ -isystem /usr/include/x86_64-linux-gnu/qt5/QtX11Extras + diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/link.txt b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/link.txt new file mode 100644 index 0000000..945ed03 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/link.txt @@ -0,0 +1 @@ +/bin/x86_64-linux-gnu-g++-9 -fPIC -Wall -Wextra -pedantic -g -DQT_QML_DEBUG -shared -Wl,-soname,libwidgetboxmodel.so -o ../../lib/libwidgetboxmodel.so CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o -Wl,-rpath,/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib: /usr/lib/x86_64-linux-gnu/libQt5Svg.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5.12.8 ../../lib/libalbert.so -lXext /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.12.8 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.12.8 diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/progress.make b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/progress.make new file mode 100644 index 0000000..e069314 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/progress.make @@ -0,0 +1,10 @@ +CMAKE_PROGRESS_1 = 91 +CMAKE_PROGRESS_2 = +CMAKE_PROGRESS_3 = 92 +CMAKE_PROGRESS_4 = 93 +CMAKE_PROGRESS_5 = +CMAKE_PROGRESS_6 = 94 +CMAKE_PROGRESS_7 = +CMAKE_PROGRESS_8 = 95 +CMAKE_PROGRESS_9 = 96 + diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/AutogenInfo.json b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/AutogenInfo.json new file mode 100644 index 0000000..f2511d2 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/AutogenInfo.json @@ -0,0 +1,144 @@ +{ + "BUILD_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen", + "CMAKE_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build", + "CMAKE_CURRENT_BINARY_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "CMAKE_CURRENT_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel", + "CMAKE_EXECUTABLE" : "/usr/bin/cmake", + "CMAKE_SOURCE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2", + "HEADERS" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.h", + "MU", + "UVLADIE3JM/moc_actionlist.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.h", + "MU", + "UVLADIE3JM/moc_configwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.h", + "MU", + "UVLADIE3JM/moc_frontendplugin.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.h", + "MU", + "UVLADIE3JM/moc_frontendwidget.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.h", + "MU", + "UVLADIE3JM/moc_resizinglist.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.h", + "MU", + "UVLADIE3JM/moc_resultslist.cpp" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.h", + "MU", + "UVLADIE3JM/moc_settingsbutton.cpp" + ] + ], + "HEADER_EXTENSIONS" : [ "h", "hh", "h++", "hm", "hpp", "hxx", "in", "txx" ], + "INCLUDE_DIR" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/include", + "MOC_COMPILATION_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/mocs_compilation.cpp", + "MOC_DEFINITIONS" : + [ + "ALBERT_VERSION=\"0.17.2\"", + "QT_CORE_LIB", + "QT_GUI_LIB", + "QT_SVG_LIB", + "QT_WIDGETS_LIB", + "QT_X11EXTRAS_LIB", + "widgetboxmodel_EXPORTS" + ], + "MOC_DEPEND_FILTERS" : + [ + [ + "Q_PLUGIN_METADATA", + "[\n][ \t]*Q_PLUGIN_METADATA[ \t]*\\([^\\)]*FILE[ \t]*\"([^\"]+)\"" + ] + ], + "MOC_INCLUDES" : + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src", + "/home/hamonikr/workspaces/tmp/albert-0.17.2/include", + "/usr/include/x86_64-linux-gnu/qt5", + "/usr/include/x86_64-linux-gnu/qt5/QtSvg", + "/usr/include/x86_64-linux-gnu/qt5/QtWidgets", + "/usr/include/x86_64-linux-gnu/qt5/QtGui", + "/usr/include/x86_64-linux-gnu/qt5/QtCore", + "/usr/lib/x86_64-linux-gnu/qt5/mkspecs/linux-g++", + "/usr/include/x86_64-linux-gnu/qt5/QtX11Extras", + "/usr/include/c++/9", + "/usr/include/x86_64-linux-gnu/c++/9", + "/usr/include/c++/9/backward", + "/usr/lib/gcc/x86_64-linux-gnu/9/include", + "/usr/local/include", + "/usr/include/x86_64-linux-gnu", + "/usr/include" + ], + "MOC_MACRO_NAMES" : [ "Q_OBJECT", "Q_GADGET", "Q_NAMESPACE" ], + "MOC_OPTIONS" : [], + "MOC_PATH_PREFIX" : true, + "MOC_PREDEFS_CMD" : + [ + "/bin/x86_64-linux-gnu-g++-9", + "-dM", + "-E", + "-c", + "/usr/share/cmake-3.16/Modules/CMakeCXXCompilerABI.cpp" + ], + "MOC_PREDEFS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/widgetboxmodel_autogen/moc_predefs.h", + "MOC_RELAXED_MODE" : false, + "MOC_SKIP" : [], + "MULTI_CONFIG" : false, + "PARALLEL" : 6, + "PARSE_CACHE_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/ParseCache.txt", + "QT_MOC_EXECUTABLE" : "/usr/lib/qt5/bin/moc", + "QT_UIC_EXECUTABLE" : "/usr/lib/qt5/bin/uic", + "QT_VERSION_MAJOR" : 5, + "SETTINGS_FILE" : "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/AutogenUsed.txt", + "SOURCES" : + [ + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/actionlist.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/configwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendplugin.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/frontendwidget.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resizinglist.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/resultslist.cpp", + "MU" + ], + [ + "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/src/settingsbutton.cpp", + "MU" + ] + ], + "UIC_OPTIONS" : [], + "UIC_SEARCH_PATHS" : [], + "UIC_SKIP" : [], + "UIC_UI_FILES" : [], + "VERBOSITY" : 0 +} diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/DependInfo.cmake b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/DependInfo.cmake new file mode 100644 index 0000000..19fab21 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/DependInfo.cmake @@ -0,0 +1,11 @@ +# The set of languages for which implicit dependencies are needed: +set(CMAKE_DEPENDS_LANGUAGES + ) +# The set of files for implicit dependencies of each language: + +# Targets to which this target links. +set(CMAKE_TARGET_LINKED_INFO_FILES + ) + +# Fortran module output directory. +set(CMAKE_Fortran_TARGET_MODULE_DIR "") diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make new file mode 100644 index 0000000..e902b40 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make @@ -0,0 +1,77 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Delete rule output on recipe failure. +.DELETE_ON_ERROR: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +# Utility rule file for widgetboxmodel_autogen. + +# Include the progress variables for this target. +include plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/progress.make + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --blue --bold --progress-dir=/home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles --progress-num=$(CMAKE_PROGRESS_1) "Automatic MOC and UIC for target widgetboxmodel" + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && /usr/bin/cmake -E cmake_autogen /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/AutogenInfo.json Debug + +widgetboxmodel_autogen: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen +widgetboxmodel_autogen: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make + +.PHONY : widgetboxmodel_autogen + +# Rule to build all files generated by this target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build: widgetboxmodel_autogen + +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel && $(CMAKE_COMMAND) -P CMakeFiles/widgetboxmodel_autogen.dir/cmake_clean.cmake +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/clean + +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/hamonikr/workspaces/tmp/albert-0.17.2 /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/DependInfo.cmake --color=$(COLOR) +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/depend + diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/cmake_clean.cmake b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/cmake_clean.cmake new file mode 100644 index 0000000..963245d --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/cmake_clean.cmake @@ -0,0 +1,9 @@ +file(REMOVE_RECURSE + "CMakeFiles/widgetboxmodel_autogen" + "widgetboxmodel_autogen/mocs_compilation.cpp" +) + +# Per-language clean rules from dependency scanning. +foreach(lang ) + include(CMakeFiles/widgetboxmodel_autogen.dir/cmake_clean_${lang}.cmake OPTIONAL) +endforeach() diff --git a/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/progress.make b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/progress.make new file mode 100644 index 0000000..225de34 --- /dev/null +++ b/build/plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/progress.make @@ -0,0 +1,2 @@ +CMAKE_PROGRESS_1 = + diff --git a/build/plugins/widgetboxmodel/Makefile b/build/plugins/widgetboxmodel/Makefile new file mode 100644 index 0000000..5f1188e --- /dev/null +++ b/build/plugins/widgetboxmodel/Makefile @@ -0,0 +1,456 @@ +# CMAKE generated file: DO NOT EDIT! +# Generated by "Unix Makefiles" Generator, CMake Version 3.16 + +# Default target executed when no arguments are given to make. +default_target: all + +.PHONY : default_target + +# Allow only one "make -f Makefile2" at a time, but pass parallelism. +.NOTPARALLEL: + + +#============================================================================= +# Special targets provided by cmake. + +# Disable implicit rules so canonical targets will work. +.SUFFIXES: + + +# Remove some rules from gmake that .SUFFIXES does not remove. +SUFFIXES = + +.SUFFIXES: .hpux_make_needs_suffix_list + + +# Suppress display of executed commands. +$(VERBOSE).SILENT: + + +# A target that is always out of date. +cmake_force: + +.PHONY : cmake_force + +#============================================================================= +# Set environment variables for the build. + +# The shell in which to execute make rules. +SHELL = /bin/sh + +# The CMake executable. +CMAKE_COMMAND = /usr/bin/cmake + +# The command to remove a file. +RM = /usr/bin/cmake -E remove -f + +# Escaping for special characters. +EQUALS = = + +# The top-level source directory on which CMake was run. +CMAKE_SOURCE_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2 + +# The top-level build directory on which CMake was run. +CMAKE_BINARY_DIR = /home/hamonikr/workspaces/tmp/albert-0.17.2/build + +#============================================================================= +# Targets provided globally by CMake. + +# Special rule for the target install/strip +install/strip: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip + +# Special rule for the target install/strip +install/strip/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..." + /usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake +.PHONY : install/strip/fast + +# Special rule for the target install/local +install/local: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local + +# Special rule for the target install/local +install/local/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..." + /usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake +.PHONY : install/local/fast + +# Special rule for the target edit_cache +edit_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..." + /usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available. +.PHONY : edit_cache + +# Special rule for the target edit_cache +edit_cache/fast: edit_cache + +.PHONY : edit_cache/fast + +# Special rule for the target install +install: preinstall + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install + +# Special rule for the target install +install/fast: preinstall/fast + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..." + /usr/bin/cmake -P cmake_install.cmake +.PHONY : install/fast + +# Special rule for the target list_install_components +list_install_components: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\"" +.PHONY : list_install_components + +# Special rule for the target list_install_components +list_install_components/fast: list_install_components + +.PHONY : list_install_components/fast + +# Special rule for the target rebuild_cache +rebuild_cache: + @$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..." + /usr/bin/cmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) +.PHONY : rebuild_cache + +# Special rule for the target rebuild_cache +rebuild_cache/fast: rebuild_cache + +.PHONY : rebuild_cache/fast + +# The main all target +all: cmake_check_build_system + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles /home/hamonikr/workspaces/tmp/albert-0.17.2/build/plugins/widgetboxmodel/CMakeFiles/progress.marks + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/all + $(CMAKE_COMMAND) -E cmake_progress_start /home/hamonikr/workspaces/tmp/albert-0.17.2/build/CMakeFiles 0 +.PHONY : all + +# The main clean target +clean: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/clean +.PHONY : clean + +# The main clean target +clean/fast: clean + +.PHONY : clean/fast + +# Prepare targets for installation. +preinstall: all + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/preinstall +.PHONY : preinstall + +# Prepare targets for installation. +preinstall/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/preinstall +.PHONY : preinstall/fast + +# clear depends +depend: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1 +.PHONY : depend + +# Convenience name for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/rule +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/rule + +# Convenience name for target. +widgetboxmodel: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/rule + +.PHONY : widgetboxmodel + +# fast build rule for target. +widgetboxmodel/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build +.PHONY : widgetboxmodel/fast + +# Convenience name for target. +plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/rule: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f CMakeFiles/Makefile2 plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/rule +.PHONY : plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/rule + +# Convenience name for target. +widgetboxmodel_autogen: plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/rule + +.PHONY : widgetboxmodel_autogen + +# fast build rule for target. +widgetboxmodel_autogen/fast: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel_autogen.dir/build +.PHONY : widgetboxmodel_autogen/fast + +src/actionlist.o: src/actionlist.cpp.o + +.PHONY : src/actionlist.o + +# target to build an object file +src/actionlist.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.o +.PHONY : src/actionlist.cpp.o + +src/actionlist.i: src/actionlist.cpp.i + +.PHONY : src/actionlist.i + +# target to preprocess a source file +src/actionlist.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.i +.PHONY : src/actionlist.cpp.i + +src/actionlist.s: src/actionlist.cpp.s + +.PHONY : src/actionlist.s + +# target to generate assembly for a file +src/actionlist.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/actionlist.cpp.s +.PHONY : src/actionlist.cpp.s + +src/configwidget.o: src/configwidget.cpp.o + +.PHONY : src/configwidget.o + +# target to build an object file +src/configwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.o +.PHONY : src/configwidget.cpp.o + +src/configwidget.i: src/configwidget.cpp.i + +.PHONY : src/configwidget.i + +# target to preprocess a source file +src/configwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.i +.PHONY : src/configwidget.cpp.i + +src/configwidget.s: src/configwidget.cpp.s + +.PHONY : src/configwidget.s + +# target to generate assembly for a file +src/configwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/configwidget.cpp.s +.PHONY : src/configwidget.cpp.s + +src/frontendplugin.o: src/frontendplugin.cpp.o + +.PHONY : src/frontendplugin.o + +# target to build an object file +src/frontendplugin.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.o +.PHONY : src/frontendplugin.cpp.o + +src/frontendplugin.i: src/frontendplugin.cpp.i + +.PHONY : src/frontendplugin.i + +# target to preprocess a source file +src/frontendplugin.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.i +.PHONY : src/frontendplugin.cpp.i + +src/frontendplugin.s: src/frontendplugin.cpp.s + +.PHONY : src/frontendplugin.s + +# target to generate assembly for a file +src/frontendplugin.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendplugin.cpp.s +.PHONY : src/frontendplugin.cpp.s + +src/frontendwidget.o: src/frontendwidget.cpp.o + +.PHONY : src/frontendwidget.o + +# target to build an object file +src/frontendwidget.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.o +.PHONY : src/frontendwidget.cpp.o + +src/frontendwidget.i: src/frontendwidget.cpp.i + +.PHONY : src/frontendwidget.i + +# target to preprocess a source file +src/frontendwidget.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.i +.PHONY : src/frontendwidget.cpp.i + +src/frontendwidget.s: src/frontendwidget.cpp.s + +.PHONY : src/frontendwidget.s + +# target to generate assembly for a file +src/frontendwidget.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/frontendwidget.cpp.s +.PHONY : src/frontendwidget.cpp.s + +src/resizinglist.o: src/resizinglist.cpp.o + +.PHONY : src/resizinglist.o + +# target to build an object file +src/resizinglist.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.o +.PHONY : src/resizinglist.cpp.o + +src/resizinglist.i: src/resizinglist.cpp.i + +.PHONY : src/resizinglist.i + +# target to preprocess a source file +src/resizinglist.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.i +.PHONY : src/resizinglist.cpp.i + +src/resizinglist.s: src/resizinglist.cpp.s + +.PHONY : src/resizinglist.s + +# target to generate assembly for a file +src/resizinglist.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resizinglist.cpp.s +.PHONY : src/resizinglist.cpp.s + +src/resultslist.o: src/resultslist.cpp.o + +.PHONY : src/resultslist.o + +# target to build an object file +src/resultslist.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.o +.PHONY : src/resultslist.cpp.o + +src/resultslist.i: src/resultslist.cpp.i + +.PHONY : src/resultslist.i + +# target to preprocess a source file +src/resultslist.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.i +.PHONY : src/resultslist.cpp.i + +src/resultslist.s: src/resultslist.cpp.s + +.PHONY : src/resultslist.s + +# target to generate assembly for a file +src/resultslist.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/resultslist.cpp.s +.PHONY : src/resultslist.cpp.s + +src/settingsbutton.o: src/settingsbutton.cpp.o + +.PHONY : src/settingsbutton.o + +# target to build an object file +src/settingsbutton.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.o +.PHONY : src/settingsbutton.cpp.o + +src/settingsbutton.i: src/settingsbutton.cpp.i + +.PHONY : src/settingsbutton.i + +# target to preprocess a source file +src/settingsbutton.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.i +.PHONY : src/settingsbutton.cpp.i + +src/settingsbutton.s: src/settingsbutton.cpp.s + +.PHONY : src/settingsbutton.s + +# target to generate assembly for a file +src/settingsbutton.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/src/settingsbutton.cpp.s +.PHONY : src/settingsbutton.cpp.s + +widgetboxmodel_autogen/mocs_compilation.o: widgetboxmodel_autogen/mocs_compilation.cpp.o + +.PHONY : widgetboxmodel_autogen/mocs_compilation.o + +# target to build an object file +widgetboxmodel_autogen/mocs_compilation.cpp.o: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.o +.PHONY : widgetboxmodel_autogen/mocs_compilation.cpp.o + +widgetboxmodel_autogen/mocs_compilation.i: widgetboxmodel_autogen/mocs_compilation.cpp.i + +.PHONY : widgetboxmodel_autogen/mocs_compilation.i + +# target to preprocess a source file +widgetboxmodel_autogen/mocs_compilation.cpp.i: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.i +.PHONY : widgetboxmodel_autogen/mocs_compilation.cpp.i + +widgetboxmodel_autogen/mocs_compilation.s: widgetboxmodel_autogen/mocs_compilation.cpp.s + +.PHONY : widgetboxmodel_autogen/mocs_compilation.s + +# target to generate assembly for a file +widgetboxmodel_autogen/mocs_compilation.cpp.s: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(MAKE) -f plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/build.make plugins/widgetboxmodel/CMakeFiles/widgetboxmodel.dir/widgetboxmodel_autogen/mocs_compilation.cpp.s +.PHONY : widgetboxmodel_autogen/mocs_compilation.cpp.s + +# Help Target +help: + @echo "The following are some of the valid targets for this Makefile:" + @echo "... all (the default if no target is provided)" + @echo "... clean" + @echo "... depend" + @echo "... install/strip" + @echo "... install/local" + @echo "... edit_cache" + @echo "... install" + @echo "... list_install_components" + @echo "... rebuild_cache" + @echo "... widgetboxmodel" + @echo "... widgetboxmodel_autogen" + @echo "... src/actionlist.o" + @echo "... src/actionlist.i" + @echo "... src/actionlist.s" + @echo "... src/configwidget.o" + @echo "... src/configwidget.i" + @echo "... src/configwidget.s" + @echo "... src/frontendplugin.o" + @echo "... src/frontendplugin.i" + @echo "... src/frontendplugin.s" + @echo "... src/frontendwidget.o" + @echo "... src/frontendwidget.i" + @echo "... src/frontendwidget.s" + @echo "... src/resizinglist.o" + @echo "... src/resizinglist.i" + @echo "... src/resizinglist.s" + @echo "... src/resultslist.o" + @echo "... src/resultslist.i" + @echo "... src/resultslist.s" + @echo "... src/settingsbutton.o" + @echo "... src/settingsbutton.i" + @echo "... src/settingsbutton.s" + @echo "... widgetboxmodel_autogen/mocs_compilation.o" + @echo "... widgetboxmodel_autogen/mocs_compilation.i" + @echo "... widgetboxmodel_autogen/mocs_compilation.s" +.PHONY : help + + + +#============================================================================= +# Special targets to cleanup operation of make. + +# Special rule to run CMake to check the build system integrity. +# No rule that depends on this can have commands that come from listfiles +# because they might be regenerated. +cmake_check_build_system: + cd /home/hamonikr/workspaces/tmp/albert-0.17.2/build && $(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0 +.PHONY : cmake_check_build_system + diff --git a/build/plugins/widgetboxmodel/cmake_install.cmake b/build/plugins/widgetboxmodel/cmake_install.cmake new file mode 100644 index 0000000..db94f2b --- /dev/null +++ b/build/plugins/widgetboxmodel/cmake_install.cmake @@ -0,0 +1,66 @@ +# Install script for directory: /home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel + +# Set the install prefix +if(NOT DEFINED CMAKE_INSTALL_PREFIX) + set(CMAKE_INSTALL_PREFIX "/usr/local") +endif() +string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + +# Set the install configuration name. +if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME) + if(BUILD_TYPE) + string(REGEX REPLACE "^[^A-Za-z0-9_]+" "" + CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}") + else() + set(CMAKE_INSTALL_CONFIG_NAME "Debug") + endif() + message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"") +endif() + +# Set the component getting installed. +if(NOT CMAKE_INSTALL_COMPONENT) + if(COMPONENT) + message(STATUS "Install component: \"${COMPONENT}\"") + set(CMAKE_INSTALL_COMPONENT "${COMPONENT}") + else() + set(CMAKE_INSTALL_COMPONENT) + endif() +endif() + +# Install shared libraries without execute permission? +if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE) + set(CMAKE_INSTALL_SO_NO_EXE "1") +endif() + +# Is this installation the result of a crosscompile? +if(NOT DEFINED CMAKE_CROSSCOMPILING) + set(CMAKE_CROSSCOMPILING "FALSE") +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwidgetboxmodel.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwidgetboxmodel.so") + file(RPATH_CHECK + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwidgetboxmodel.so" + RPATH "$ORIGIN/../") + endif() + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/albert/plugins" TYPE SHARED_LIBRARY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib/libwidgetboxmodel.so") + if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwidgetboxmodel.so" AND + NOT IS_SYMLINK "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwidgetboxmodel.so") + file(RPATH_CHANGE + FILE "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwidgetboxmodel.so" + OLD_RPATH "/home/hamonikr/workspaces/tmp/albert-0.17.2/build/lib:" + NEW_RPATH "$ORIGIN/../") + if(CMAKE_INSTALL_DO_STRIP) + execute_process(COMMAND "/bin/strip" "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/albert/plugins/libwidgetboxmodel.so") + endif() + endif() +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) +endif() + +if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT) + file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/share/albert/org.albert.frontend.widgetboxmodel" TYPE DIRECTORY FILES "/home/hamonikr/workspaces/tmp/albert-0.17.2/plugins/widgetboxmodel/share/") +endif() + diff --git a/debian/changelog b/debian/changelog index 64c08a6..c253eae 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,3 +1,16 @@ +albert (0.17.2-0hamonikr1) stable; urgency=low + + * Release for HamoniKR Server 2.0 + - Update UPSTREAM src + + -- HamoniKR Wed, 03 Mar 2021 15:44:31 +0900 + +albert (0.17.2-0) stable; urgency=low + + * Albert Upstream Release + + -- Manuel Schneider Sun, 29 Oct 2017 00:00:00 +0000 + albert (0.16.1hamonikr2) stable; urgency=low * Update plugins/widgetboxmodel/share/themes/HamoniKR_Dark.qss @@ -23,4 +36,4 @@ albert (0.16.1-0) stable; urgency=low * Albert Upstream Release - -- Manuel Schneider Sun, 29 Oct 2017 00:00:00 +0000 + -- Manuel Schneider Sun, 29 Oct 2017 00:00:00 +0000 \ No newline at end of file diff --git a/debian/compat b/debian/compat index ec63514..f599e28 100644 --- a/debian/compat +++ b/debian/compat @@ -1 +1 @@ -9 +10 diff --git a/debian/control b/debian/control index bf636fa..27caa95 100644 --- a/debian/control +++ b/debian/control @@ -1,12 +1,10 @@ Source: albert +Maintainer: Manuel Schneider Section: utils Priority: optional -Maintainer: Manuel Schneider -Standards-Version: 4.0.0 -Homepage: https://albertlauncher.github.io/ -Vcs-Git: ghttps://github.com/albertlauncher/albert.git +Standards-Version: 4.1.0 Build-Depends: - debhelper (>=9), + debhelper (>=10), cmake (>=3.1.3), qtbase5-dev (>=5.5), libqt5x11extras5-dev (>=5.5), @@ -15,12 +13,17 @@ Build-Depends: libmuparser-dev (>=2), python3-dev (>=3.5), lsb-release - +Homepage: https://albertlauncher.github.io/ +Vcs-Browser: https://github.com/albertlauncher +Vcs-Git: https://github.com/albertlauncher/albert.git Package: albert Architecture: any -Depends: ${shlibs:Depends}, libqt5sql5-sqlite -Recommends: qml-module-qtgraphicaleffects, qml-module-qtquick-controls +Depends: + ${shlibs:Depends}, + libqt5sql5-sqlite, + qml-module-qtgraphicaleffects, + qml-module-qtquick-controls Description: A sophisticated, plugin-based, standalone keyboard launcher written in C++/Qt Albert is a unified and efficient access to your machine. Technically it is a keyboard launcher written in C++/Qt. The plugin based architecture makes it extremely flexible and powerful. Plugins can be used to create modular frontends or native extensions. Extensions can also be implemented using embedded Python modules or via a CGI approach in any language you want. The frontends shipped heavily focus on customizability. diff --git a/debian/postinst b/debian/postinst new file mode 100755 index 0000000..7466670 --- /dev/null +++ b/debian/postinst @@ -0,0 +1,11 @@ +#!/bin/bash + +# Get the Real Username +RUID=$(who | awk 'FNR == 1 {print $1}') +# Translate Real Username to Real User ID +RUSER_UID=$(id -u ${RUID}) + +if [[ ! -d "/home/$RUID/.config/albert" ]] +then + cp -r /etc/skel/.config/albert /home/$RUID/.config/ || true +fi \ No newline at end of file diff --git a/debian/rules b/debian/rules index 1e48c59..eab4609 100755 --- a/debian/rules +++ b/debian/rules @@ -1,19 +1,14 @@ #!/usr/bin/make -f CODENAME = $(shell lsb_release -cs) export DH_VERBOSE = 1 -#export DEB_BUILD_MAINT_OPTIONS = hardening=+all +export DEB_BUILD_MAINT_OPTIONS = hardening=+all #export DEB_CFLAGS_MAINT_APPEND = -Wall -pedantic #export DEB_LDFLAGS_MAINT_APPEND = -Wl,--as-needed +export QT_SELECT=5 %: dh $@ override_dh_auto_configure: -ifneq (, $(findstring ${CODENAME},"xenial" "yakkety" "zesty" "stretch")) - dh_auto_configure -- -DBUILD_WITH_QTCHARTS=OFF -else - dh_auto_configure -- -endif - -override_dh_usrlocal: \ No newline at end of file + dh_auto_configure -- -DCMAKE_BUILD_TYPE=Release -DBUILD_WITH_QTCHARTS=OFF -DBUILD_VIRTUALBOX=OFF diff --git a/debian/source/format b/debian/source/format new file mode 100644 index 0000000..89ae9db --- /dev/null +++ b/debian/source/format @@ -0,0 +1 @@ +3.0 (native) diff --git a/hamonikr/albert.desktop b/hamonikr/albert.desktop new file mode 100755 index 0000000..70e9cfb --- /dev/null +++ b/hamonikr/albert.desktop @@ -0,0 +1,13 @@ +#!/usr/bin/env xdg-open +[Desktop Entry] +Categories=Utility; +Comment=A desktop agnostic launcher +Comment[ko]=빠른 프로그램 실행도구 +Exec=albert +GenericName=Launcher +Icon=albert +Name=Albert +Name[ko]=런처 +StartupNotify=false +Type=Application +Version=1.0 diff --git a/hamonikr/etc/skel/.config/albert/albert.conf b/hamonikr/etc/skel/.config/albert/albert.conf new file mode 100644 index 0000000..4d1d804 --- /dev/null +++ b/hamonikr/etc/skel/.config/albert/albert.conf @@ -0,0 +1,21 @@ +[General] +hotkey=Alt+Space +showTray=true + +[org.albert.extension.applications] +enabled=true + +[org.albert.extension.websearch] +enabled=true + +[org.albert.frontend.widgetboxmodel] +alwaysOnTop=true +clearOnHide=false +displayIcons=true +displayScrollbar=false +displayShadow=true +hideOnClose=false +hideOnFocusLoss=true +itemCount=5 +showCentered=true +theme=HamoniKR_Dark diff --git a/hamonikr/etc/skel/.config/albert/core.db b/hamonikr/etc/skel/.config/albert/core.db new file mode 100644 index 0000000000000000000000000000000000000000..c1466583d2be55f938b85c7a166638c488a66595 GIT binary patch literal 32768 zcmeI4U1%It6vyw(-JRV{ckbCuvYC8AXKOVHl+e%?ECtgvnbyT5n{FnyMRDCElkK*f z-E_0*hf+1A;6p`x@WqPYgJ69S1hs0Z;1?9zDz?5<1w|A=(T9pcK?Lu|ek7O_e5!_3h}R$*Pj*&JD2uDj&~s{oFJP@-ubpm^sd~q~sRfZ~t>a&o zXiZ)%&)UrYCAWi_!gSs%Evsod)w zFMEY~{=BL8m^V4^WlB>AH|mrmR}9I_&E<1b@X)8D7;4Cceu(8HY9)q zkN^@u0!RP}AOR$R1dsp{KmthMP7>Ha6Iy-SzS91m-c6G$hb-Oy>n4qd>Jy3g|D9}$ z*#G|kU&2T52D}7k;4wG^55WlZ!)CAn*x&3Ic7t7F@33?1EIY#*9D@R6Aq@{g687+C1NZW$1KkjZHi$q7 zG$__UDL=?ijM@1WXUs-tT=<%y1v zjBBUk%IZlew^JF`M#(p-qmyg$M4O6lr3YkutG-prtt#H4T7!(Ybn=BfVFhJe3$0jv zyPxM1Y>{e=y2|RCWpIp2x0y~VtM8I>vo7asqGVC(O}Z!bCPV6tlzbrdMm;O_MxS(} zG^eb-Ps&jxM`&Kk5#5z?M9mJAyef6jPf8sWGDbB`F2kxNF~9Ups_ju7ot&2=%z&IA zOig9=VOeWfe1_J^kOsdrAu3HUAWfh_8bf)0WqeAcA$d*@`Fx>JNWA~&|MU+V5 IdxStrList; + } diff --git a/include/albert/item.h b/include/albert/item.h index 5ed8e07..04ec8a3 100644 --- a/include/albert/item.h +++ b/include/albert/item.h @@ -9,6 +9,7 @@ namespace Core { class Action; +typedef std::vector> ActionList; /** **************************************************************************** * @brief The item interface @@ -40,15 +41,15 @@ class EXPORT_CORE Item /** The declarative subtext for the item */ virtual QString subtext() const = 0; + /** The alternative actions of the item*/ + virtual ActionList actions() = 0; + /** The string to use for completion */ - virtual QString completion() const { return text(); } + virtual QString completion() const { return QString(); } // Null semantic /** Urgency level of the item, defautls to "Normal" */ virtual Urgency urgency() const { return Urgency::Normal; } - /** The alternative actions of the item*/ - virtual std::vector> actions() = 0; - }; } diff --git a/include/albert/query.h b/include/albert/query.h index c2edd62..0b05f09 100644 --- a/include/albert/query.h +++ b/include/albert/query.h @@ -42,6 +42,13 @@ class EXPORT_CORE Query final */ bool isTriggered() const; + /** + * @brief The sort hint of the query handler. + * Call this if you want the query manager to omit the final sorting of items. + * @note This is only effective for triggered batch handlers. + */ + void disableSort(); + /** * @brief The trigger of this query * Note that if the trigger is set, string() differs from rawString(). @@ -102,8 +109,9 @@ class EXPORT_CORE Query final QString trigger_; QString string_; QString rawString_; - bool isValid_ = true; std::map scores_; + bool sort_ = true; + bool isValid_ = true; friend class QueryExecution; }; diff --git a/include/albert/util/shutil.h b/include/albert/util/shutil.h deleted file mode 100644 index 506fbce..0000000 --- a/include/albert/util/shutil.h +++ /dev/null @@ -1,16 +0,0 @@ -// Copyright (C) 2014-2018 Manuel Schneider - -#pragma once -#include -#include -#include "../core_globals.h" - -namespace Core { -namespace ShUtil { - -EXPORT_CORE QString quote(QString input); -EXPORT_CORE QStringList split(const QString &input); - -} -} - diff --git a/include/albert/util/standardactions.h b/include/albert/util/standardactions.h index f384802..d50aac2 100644 --- a/include/albert/util/standardactions.h +++ b/include/albert/util/standardactions.h @@ -9,100 +9,109 @@ namespace Core { -//! @brief Base class for standard actions struct EXPORT_CORE StandardActionBase : public Action { -public: - StandardActionBase(const QString &text); + /** + * @brief Base class for standard actions implementing the text getter + * @param text The description of the action + */ + explicit StandardActionBase(const QString &text); QString text() const override; - private: QString text_; }; - -//! @brief A standard action holding a std::function struct EXPORT_CORE FuncAction : public StandardActionBase { -public: - FuncAction(const QString &text, std::function action); - void activate() override; - + /** + * @brief Runs a function + * @param text The description of the action + * @param action The fuction to execute + */ + explicit FuncAction(const QString &text, std::function action); + void activate() const override; private: std::function action_; }; +#define makeFuncAction std::make_shared - -// A standard action that copies text into the clipboard struct EXPORT_CORE ClipAction : public StandardActionBase { -public: - ClipAction(const QString &text, QString clipBoardText); - void activate() override; - + /** + * @brief Copies text into the clipboard + * @param text The description of the action + * @param clipBoardText The text to put in the clipboard + */ + explicit ClipAction(const QString &text, const QString &clipBoardText); + void activate() const override; private: QString clipBoardText_; }; +#define makeClipAction std::make_shared - - -// A standard action that opens an url using QDesktopServices struct EXPORT_CORE UrlAction : public StandardActionBase { -public: - UrlAction(const QString &text, QUrl url); - void activate() override; - + /** + * @brief Opens an URL using the system scheme/mime hanlders + * @param text The description of the action + * @param commandline The URL to open with the correspondig handler + */ + explicit UrlAction(const QString &text, const QUrl &url); + void activate() const override; private: - QUrl url_ ; + QUrl url_; }; +#define makeUrlAction std::make_shared - -// A standard action that starts a process struct EXPORT_CORE ProcAction : public StandardActionBase { -public: - ProcAction(const QString &text, const QStringList &commandline, const QString &workingDirectory = QString()); - void activate() override; - + /** + * @brief Starts a detached process + * @param text The description of the action + * @param commandline The program with arguments to execute + * @param workingDirectory The working directory + */ + explicit ProcAction(const QString &text, const QStringList &commandline, const QString &workingDirectory = QString()); + void activate() const override; protected: QStringList commandline_; QString workingDir_; }; +#define makeProcAction std::make_shared - -// A standard action that runs commands in a terminal -struct EXPORT_CORE TermAction : public ProcAction +struct EXPORT_CORE TermAction : public StandardActionBase { - enum class CloseBehavior { + enum CloseBehavior { CloseOnSuccess, CloseOnExit, DoNotClose }; -public: - /** - * @brief TermAction constructor + * @brief Runs a commandline in a detached user definded terminal * @param text The description of the action - * @param commandline The command to execute - * @param workingDirectory The working directory where to run the command - * @param shell Should the command be wrapped in a shell? - * @param behavior The close behavior when using the shell + * @param commandline The commandline to run + * @param workingDirectory The working directory */ - TermAction(const QString &text, const QStringList &commandline, const QString &workingDirectory = QString(), - bool shell = true, CloseBehavior behavior = CloseBehavior::CloseOnSuccess); - void activate() override; + explicit TermAction(const QString &text, const QStringList &commandline, const QString &workingDirectory = QString()); + /** + * @brief Executes a script wrapped in the user shell in a detached user definded terminal + * @param text The description of the action + * @param script The shell script to execute + * @param closeBehavior What happens when the script finished + * @param workingDirectory The working directory + */ + explicit TermAction(const QString &text, const QString &script, CloseBehavior closeBehavior = CloseOnSuccess, const QString &workingDirectory = QString()); + void activate() const override; private: - bool shell_; - CloseBehavior behavior_; + QStringList commandline_; + QString workingDir_; }; - - +#define makeTermAction std::make_shared } diff --git a/include/albert/util/standardindexitem.h b/include/albert/util/standardindexitem.h index ee7b701..19384a0 100644 --- a/include/albert/util/standardindexitem.h +++ b/include/albert/util/standardindexitem.h @@ -16,14 +16,16 @@ class EXPORT_CORE StandardIndexItem final : public IndexableItem { public: - StandardIndexItem(QString id = QString(), - QString iconPath = QString(), - QString text = QString(), - QString subtext = QString(), - QString completion = QString(), - Urgency urgency = Item::Urgency::Normal, - std::vector> actions = std::vector>(), - std::vector indexStrings = std::vector()); + explicit StandardIndexItem( + QString id = QString(), + QString iconPath = QString(), + QString text = QString(), + QString subtext = QString(), + std::vector indexStrings = std::vector(), + std::vector> actions = std::vector>(), + QString completion = QString(), + Urgency urgency = Item::Urgency::Normal + ); QString id() const override; void setId(QString id); @@ -37,18 +39,18 @@ class EXPORT_CORE StandardIndexItem final : public IndexableItem QString subtext() const override; void setSubtext(QString subtext); - QString completion() const override; - void setCompletion(QString completion); - - Item::Urgency urgency() const override; - void setUrgency(Item::Urgency urgency); + virtual std::vector indexStrings() const override; + void setIndexKeywords(std::vector indexStrings); std::vector> actions() override; void setActions(std::vector> actions); void addAction(std::shared_ptr action); - virtual std::vector indexStrings() const override; - void setIndexKeywords(std::vector indexStrings); + QString completion() const override; + void setCompletion(QString completion); + + Item::Urgency urgency() const override; + void setUrgency(Item::Urgency urgency); protected: @@ -57,11 +59,12 @@ class EXPORT_CORE StandardIndexItem final : public IndexableItem QString iconPath_; QString text_; QString subtext_; + std::vector indexStrings_; + std::vector> actions_; QString completion_; Item::Urgency urgency_; - std::vector> actions_; - std::vector indexStrings_; }; +#define makeStdIdxItem std::make_shared } diff --git a/include/albert/util/standarditem.h b/include/albert/util/standarditem.h index a488b98..02eb959 100644 --- a/include/albert/util/standarditem.h +++ b/include/albert/util/standarditem.h @@ -19,13 +19,15 @@ class EXPORT_CORE StandardItem : public Item { public: - StandardItem(QString id = QString(), - QString iconPath = QString(), - QString text = QString(), - QString subtext = QString(), - QString completion = QString(), - Urgency urgency = Item::Urgency::Normal, - std::vector> actions = std::vector>()); + explicit StandardItem( + QString id = QString(), + QString iconPath = QString(), + QString text = QString(), + QString subtext = QString(), + std::vector> actions = std::vector>(), + QString completion = QString(), + Urgency urgency = Item::Urgency::Normal + ); QString id() const override; void setId(QString id); @@ -39,28 +41,29 @@ class EXPORT_CORE StandardItem : public Item QString subtext() const override; void setSubtext(QString subtext); - QString completion() const override; - void setCompletion(QString completion); - - Item::Urgency urgency() const override; - void setUrgency(Item::Urgency urgency); - std::vector> actions() override; void setActions(std::vector> &&actions); void setActions(const std::vector> &actions); void addAction(std::shared_ptr &&action); void addAction(const std::shared_ptr &action); + QString completion() const override; + void setCompletion(QString completion); + + Item::Urgency urgency() const override; + void setUrgency(Item::Urgency urgency); + protected: QString id_; QString iconPath_; QString text_; QString subtext_; + std::vector> actions_; QString completion_; Item::Urgency urgency_; - std::vector> actions_; }; +#define makeStdItem std::make_shared } diff --git a/lib/globalshortcut/CMakeLists.txt b/lib/globalshortcut/CMakeLists.txt index 59eac09..21222f6 100644 --- a/lib/globalshortcut/CMakeLists.txt +++ b/lib/globalshortcut/CMakeLists.txt @@ -12,13 +12,18 @@ set(SRC set(LIB Qt5::Gui) -if(${CMAKE_SYSTEM_NAME} MATCHES "Linux") +if(${CMAKE_SYSTEM_NAME} MATCHES "Linux" OR ${CMAKE_SYSTEM_NAME} MATCHES "^(FreeBSD|DragonFly)$") find_package(Qt5 5.5.0 REQUIRED X11Extras) set(SRC ${SRC} src/hotkeymanager_x11.cpp) set(LIB ${LIB} Qt5::X11Extras X11) -elseif(${CMAKE_SYSTEM_NAME} MATCHES "Windows") - set(SRC ${SRC} src/hotkey/hotkeymanager_win.cpp) - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DUNICODE") + +#elseif(${CMAKE_SYSTEM_NAME} MATCHES "Windows") +# set(SRC ${SRC} src/hotkeymanager_win.cpp) +# set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DUNICODE") + +elseif(${CMAKE_SYSTEM_NAME} MATCHES "Darwin") + set(SRC ${SRC} src/hotkeymanager_mac.cpp) + endif() add_library(${PROJECT_NAME} STATIC ${SRC}) diff --git a/lib/globalshortcut/src/hotkeymanager.cpp b/lib/globalshortcut/src/hotkeymanager.cpp index 0245e67..4dd307f 100644 --- a/lib/globalshortcut/src/hotkeymanager.cpp +++ b/lib/globalshortcut/src/hotkeymanager.cpp @@ -1,7 +1,7 @@ // Copyright (C) 2014-2018 Manuel Schneider #include "globalshortcut/hotkeymanager.h" -#if defined __linux__ +#if defined __linux__ || defined __FreeBSD__ #include "hotkeymanager_x11.h" #elif defined __APPLE__ #elif defined _WIN32 diff --git a/lib/xdg/include/xdg/iconlookup.h b/lib/xdg/include/xdg/iconlookup.h index 914d7f0..6f8cab6 100644 --- a/lib/xdg/include/xdg/iconlookup.h +++ b/lib/xdg/include/xdg/iconlookup.h @@ -2,8 +2,7 @@ #pragma once #include -#include -#include +#include #include "xdg_globals.h" namespace XDG { @@ -15,31 +14,31 @@ class EXPORT_XDG IconLookup /** * @brief iconPath Does XDG icon lookup for the given icon name * @param iconName The icon name to lookup - * @param themeName The theme to use + * @param themeName The theme to use, use current theme if empty * @return If an icon was found the path to the icon, else an empty string */ - static QString iconPath(QString iconName, QString themeName = QIcon::themeName()); + static QString iconPath(QString iconName, QString themeName = QString()); /** * @brief iconPath Does XDG icon lookup for the given icon names, stops on success * @param iconNames A list of icon names to lookup - * @param themeName The theme to use + * @param themeName The theme to use, use current theme if empty * @return If one of the icons was found the path to the icon, else an empty string */ - static QString iconPath(std::initializer_list iconNames, QString themeName = QIcon::themeName()); + static QString iconPath(QStringList iconNames, QString themeName = QString()); private: IconLookup(); static IconLookup *instance(); - QString themeIconPath(QString iconName, QString themeName = QIcon::themeName()); + QString themeIconPath(QString iconName, QString themeName = QString()); QString doRecursiveIconLookup(const QString &iconName, const QString &theme, QStringList *checked); QString doIconLookup(const QString &iconName, const QString &themeFile); QString lookupThemeFile(const QString &themeName); QStringList iconDirs_; - QMap iconCache_; + std::map iconCache_; }; } diff --git a/lib/xdg/src/iconlookup.cpp b/lib/xdg/src/iconlookup.cpp index 7ce48b8..5dbf575 100644 --- a/lib/xdg/src/iconlookup.cpp +++ b/lib/xdg/src/iconlookup.cpp @@ -9,7 +9,7 @@ #include #include "themefileparser.h" #include "iconlookup.h" - +using namespace std; namespace { QStringList icon_extensions = {"png", "svg", "xpm"}; @@ -17,24 +17,21 @@ namespace { /** ***************************************************************************/ -QString XDG::IconLookup::iconPath(QString iconName, QString themeName){ - return instance()->themeIconPath(iconName, themeName); +QString XDG::IconLookup::iconPath(QStringList iconNames, QString themeName) { + QString result; + for ( const QString &iconName : iconNames ) + if ( !(result = instance()->themeIconPath(iconName, themeName)).isNull() ) + return result; + return QString(); } - /** ***************************************************************************/ -QString XDG::IconLookup::iconPath(std::initializer_list iconNames, QString themeName) { - for ( const QString &iconName : iconNames ) { - QString result = instance()->themeIconPath(iconName, themeName); - if ( !result.isEmpty() ) - return result; - } - return QString(); +QString XDG::IconLookup::iconPath(QString iconName, QString themeName){ + return instance()->themeIconPath(iconName, themeName); } - /** ***************************************************************************/ XDG::IconLookup::IconLookup() { @@ -48,11 +45,9 @@ XDG::IconLookup::IconLookup() if (QFile::exists(path)) iconDirs_.append(path); - for (const QString &basedir : QStandardPaths::standardLocations(QStandardPaths::GenericDataLocation)){ - path = QDir(basedir).filePath("icons"); - if (QFile::exists(path)) + for (const QString &basedir : QStandardPaths::standardLocations(QStandardPaths::GenericDataLocation)) + if (QFile::exists(path = QDir(basedir).filePath("icons"))) iconDirs_.append(path); - } path = "/usr/share/pixmaps"; if (QFile::exists(path)) @@ -77,6 +72,9 @@ XDG::IconLookup *XDG::IconLookup::instance() /** ***************************************************************************/ QString XDG::IconLookup::themeIconPath(QString iconName, QString themeName){ + if (themeName.isEmpty()) + themeName = QIcon::themeName(); + // if we have an absolute path, just return it if ( iconName[0]=='/' ){ if ( QFile::exists(iconName) ) @@ -91,40 +89,30 @@ QString XDG::IconLookup::themeIconPath(QString iconName, QString themeName){ iconName.chop(4); // Check cache - QString iconPath = iconCache_.value(iconName); - if (!iconPath.isNull()) - return iconPath; + try { + return iconCache_.at(iconName); + } catch (out_of_range) { } - // Lookup themefile QStringList checkedThemes; - iconPath = doRecursiveIconLookup(iconName, themeName, &checkedThemes); - if (!iconPath.isNull()){ - iconCache_.insert(iconName, iconPath); - return iconPath; - } + QString iconPath; + + // Lookup themefile + if (!(iconPath = doRecursiveIconLookup(iconName, themeName, &checkedThemes)).isNull()) + return iconCache_.emplace(iconName, iconPath).first->second; // Lookup in hicolor - if (!checkedThemes.contains("hicolor")){ - iconPath = doRecursiveIconLookup(iconName, "hicolor", &checkedThemes); - if (!iconPath.isNull()){ - iconCache_.insert(iconName, iconPath); - return iconPath; - } - } + if (!checkedThemes.contains("hicolor")) + if (!(iconPath = doRecursiveIconLookup(iconName, "hicolor", &checkedThemes)).isNull()) + return iconCache_.emplace(iconName, iconPath).first->second; // Now search unsorted - for (const QString &iconDir : iconDirs_){ - for (const QString &ext : icon_extensions){ - QString filename = QString("%1/%2.%3").arg(iconDir, iconName, ext); - if (QFile(filename).exists()){ - iconCache_.insert(iconName, filename); - return filename; - } - } - } + for (const QString &iconDir : iconDirs_) + for (const QString &ext : icon_extensions) + if (QFile(iconPath = QString("%1/%2.%3").arg(iconDir, iconName, ext)).exists()) + return iconCache_.emplace(iconName, iconPath).first->second; // Nothing found, save though to avoid repeated expensive lookups - return iconCache_.insert(iconName, QString("")).value(); + return iconCache_.emplace(iconName, QString()).first->second; } @@ -168,13 +156,13 @@ QString XDG::IconLookup::doIconLookup(const QString &iconName, const QString &th QString themeName = themeDir.dirName(); // Get the sizes of the dirs - std::vector> dirsAndSizes; + vector> dirsAndSizes; for (const QString &subdir : themeFileParser.directories()) - dirsAndSizes.push_back(std::make_pair(subdir, themeFileParser.size(subdir))); + dirsAndSizes.push_back(make_pair(subdir, themeFileParser.size(subdir))); // Sort them by size - std::sort(dirsAndSizes.begin(), dirsAndSizes.end(), - [](std::pair a, std::pair b) { + sort(dirsAndSizes.begin(), dirsAndSizes.end(), + [](pair a, pair b) { return a.second > b.second; }); diff --git a/metatool b/metatool new file mode 100755 index 0000000..af03036 --- /dev/null +++ b/metatool @@ -0,0 +1,158 @@ +#! /usr/bin/env python3 + +import re +import sys +import argparse +import datetime +import tempfile +from pathlib import Path +from subprocess import run + + +def create_changelog(args) -> str: + plugins_root = f"{args.root}/plugins" + modules_root = f"{args.root}/plugins/python/share/modules" + + latest = run(["git", "describe", "--tags", "--abbrev=0"], capture_output=True).stdout.decode().strip() + + albert_log = run(["git", "log", "--pretty=format:* %B", f"{latest}..dev"], capture_output=True).stdout.decode().strip() + + begin = run(["git", "ls-tree", latest, plugins_root], capture_output=True).stdout.decode().strip().split()[2] + plugin_log = run(["git", "-C", plugins_root, "log", "--pretty=format:* %B", f"{begin}..master"], capture_output=True).stdout.decode().strip() + + begin = run(["git", "-C", plugins_root, "ls-tree", begin, modules_root], capture_output=True).stdout.decode().strip().split()[2] + python_log = run(["git", "-C", modules_root, "log", "--pretty=format:* %B", f"{begin}..master"], capture_output=True).stdout.decode().strip() + + return f"[albert]\n{albert_log}\n\n[plugins]\n{plugin_log}\n\n[python]\n{python_log}" + + +def test_build(args): + files = list((Path(args.root) / ".docker").iterdir()) + for i, f in enumerate(files): + print(f"{i}: {f.name}") + + default = list(range(len(files))) + indices = input(f"Which to build? [{' '.join(str(i) for i in default)}] ") + indices = [int(s) for s in filter(None, indices.split())] + indices = indices if indices else default + for index in indices: + tag = files[index].name.replace("Dockerfile", "albert") + run(["docker", "build", "-t", tag, "-f", files[index], "."], cwd=args.root).check_returncode() + + +def release(args): + + root = Path(args.root) + + if args.version[0] == 'v': + args.version = args.version[1:] + + import re + if not re.match(r"^[0-9]+\.[0-9]+\.[0-9]+$", args.version): + print("Expected version number as parameter: major.minor.patch") + sys.exit(1) + + print("Don't forget to merge ready PRs.") + print("Don't forget to updated the 'python' submodule in the Python plugin.") + print("Don't forget to updated the 'plugins' submodule.") + + if "y".startswith(input("Shall I run a test build in docker? [Y/n] ").lower()): + test_build(args) + + v = input("Confirm the version number: ") + if args.version != (v[1:] if v[0] == 'v' else v): + print("Version mismatch.") + sys.exit(1) + + atomic_changelog = root/f"changelog_v{args.version}" + + with open(atomic_changelog, 'w') as file: + file.write(create_changelog(args)) + + print("Changelog created from git logs. Edit it to be meaningful to humans.") + input("Press Enter to continue...") + run(["vim", atomic_changelog]).check_returncode() + + with open(atomic_changelog, 'r') as file: + changelog = file.read().strip() + + if "y".startswith(input("Create news post? [Y/n] ").lower()): + if (root/"documentation").exists(): + run(["git", "pull"], cwd=root/"documentation").check_returncode() + else: + run(["git", "clone", "git://github.com/albertlauncher/documentation.git"], cwd=root).check_returncode() + + with open(f"documentation/src/_posts/{datetime.date.today().strftime('%Y-%m-%d')}-albert-v{args.version}-released.md", 'w') as file: + file.write(f"""--- +layout: page +title: "Albert v{args.version} released" +date: {datetime.datetime.now().strftime("%Y-%m-%d %H:%M%z")} +--- + +{changelog.strip()} + +Check the GitHub repositories for details. +https://github.com/albertlauncher/albert/commits/v{args.version} +""") + if "y".startswith(input("News post created. Build/Test/Publish it? [Y/n] ").lower()): + run("./build_check_deploy.sh", cwd=root/"documentation").check_returncode() + + if "y".startswith(input("Update the changelog? [Y/n] ").lower()): + with open(root/"CHANGELOG.md", 'r') as file: + old_changelog = file.read() + + with open(root/"CHANGELOG.md", 'w') as file: + file.write(f"v{args.version} ({datetime.date.today().strftime('%Y-%m-%d')})\n\n{changelog}\n\n{old_changelog}") + + print("Changelog updated.") + + run(["sed", "-i.bak", f"s/^project.*$/project(albert VERSION {args.version})/", root/"CMakeLists.txt"], cwd=root).check_returncode() + print("Project version updated.") + + if "yes".startswith(input("Stage, commit, tag, rebase master and push? [yes/NO]").lower()): + run(["git", "add", root/"CHANGELOG.md", root/"CMakeLists.txt"], cwd=root).check_returncode() + run(["git", "commit", "-m", f"v{args.version}"], cwd=root).check_returncode() + run(["git", "tag", f"v{args.version}"], cwd=root).check_returncode() + run(["git", "rebase", "dev", "master"], cwd=root).check_returncode() + run(["git", "push", "--tags", "--atomic", "origin", "dev", "master"], cwd=root).check_returncode() + + print("Clean up…") + run(["rm", atomic_changelog]) + run(["rm", "CMakeLists.txt.bak"]) + + + +def main(): + p = argparse.ArgumentParser() + sps = p.add_subparsers() + + sp = sps.add_parser('changelog', help='Create raw changelog.') + sp.set_defaults(func=lambda args: print(create_changelog(args))) + + sp = sps.add_parser('test', help='Test build using docker.') + sp.set_defaults(func=test_build) + + sp = sps.add_parser('release', help="Release a new version.") + sp.add_argument('version', type=str, help="The sematic version.") + sp.set_defaults(func=release) + + args = p.parse_args() + if not hasattr(args, "func"): + p.print_help() + sys.exit(1) + + sha = run(["git", "rev-list", "--parents", "HEAD"], capture_output=True).stdout.decode().strip().split("\n")[-1] + if sha != '4d409110b9771e688acbb995422541f03ef0d8a7': + print("Working dir is not the albert repository") + sys.exit(1) + + args.root = run(["git", "rev-parse", "--show-toplevel"], capture_output=True).stdout.decode().strip() + + try: + args.func(args) + except KeyboardInterrupt: + print("\nBye.") + + +if __name__ == "__main__": + main() diff --git a/plugins/externalextensions/CMakeLists.txt b/plugins/.archive/externalextensions/CMakeLists.txt similarity index 100% rename from plugins/externalextensions/CMakeLists.txt rename to plugins/.archive/externalextensions/CMakeLists.txt diff --git a/plugins/.archive/externalextensions/README.md b/plugins/.archive/externalextensions/README.md new file mode 100644 index 0000000..6987698 --- /dev/null +++ b/plugins/.archive/externalextensions/README.md @@ -0,0 +1,94 @@ +# External extensions + +***Note: This scripting extension is deprecated as of v0.14.0. Use the Python extension instead*** + +An external extensions is a regular CGI executable which handles queries for albert. +The type of query is defined by the environment variable `$ALBERT_OP`. +The standard output stream (stdout) is used to return JSON formatted data. + +To save state between executions add a dict of strings called 'variables' to the returned JSON dict. +The items of this dict will be set as environment variables in the next execution. + +## External extensions communication protocol (v3) + +The possible `$ALBERT_OP`s and the expected return values are as follows: + +### `METADATA` +Return the metadata of the extension. It should have the +following keys: + +|Key|Value| +|---|---| +|`iid`|(string, mandatory) The interface id `iid` (currently `org.albert.extension.external/v3.0` tells the application the type and version of the communication protocol . If the `iid` is incompatible this plugin will not show up in the plugins list. The remaining keys should be self-explanatory. Errors in this step are fatal: loading will not be continued.| +|`version`|(string, defaults to 'N/A')| +|`name`|(string, defaults to $id)| +|`trigger`|(string, defaults to 'empty')| +|`author`|(string, defaults to 'N/A')| +|`dependencies`|(array of strings, defaults to 'empty')| + +### `INITIALIZE` +The request to initialize the plugin. The plugin should load potential state from persistant storage, check if all requirements are met and set the exit code accordingly. (Everything but zero is an error). Errors in this step are fatal: loading will not be continued. + +### `FINALIZE` +The request to finalize the plugin. The plugin should save the state to persistent storage. + +### `QUERY` +The request to handle a query. The environment variable `ALBERT_QUERY` contains the _complete_ query as the user entered it into the input box, i.e. including potential triggers. + +**Note:** The process handling `QUERY` can be terminated at any time. Do _not_ change state in this code segment. + +Return the results by an array "items" containing JSON objects representing the results. A result object has to contain the following entries: `id`, `name`, `description`, `icon` and `actions`. + +|Key|Value| +|---|---| +|`id`| The plugin wide unique id of the result| +|`name`| The name of the result| +|`description`| The description of the result| +|`completion`| The completions string of the result| +|`icon`| The icon of the result (name or path)| +|`actions`| Array of objects representing the actions for the item.| + +The `id` of the item will be used to sort the items by usage. The `name`, `icon` and `description` will be displayed together as an item in the results list. `completion` is the string that will be used to replace the text in the input box when the user pressed Tab. If `icon` is an absolute path, the given file will be used. If the `icon` is not an absolute path, the algorithm described in the [Icon Theme Specification](https://freedesktop.org/wiki/Specifications/icon-theme-spec/) will be used to locate the icon. An object representing an action has to contain the following values: `name`, `command` and `arguments`. + +|Key|Value| +|---|---| +|`name`| The actions name| +|`command`| The program to be execute| +|`arguments`| An array of parameters for `command`| + +An example: +```json +{ + "items": [{ + "id":"extension.wide.unique.id", + "name":"An Item", + "description":"Nice description.", + "icon":"/path/to/icon", + "actions":[{ + "name":"Action name 1", + "command":"program", + "arguments":["-a", "-b"] + },{ + "name":"Action name 2", + "command":"program2", + "arguments":["-C", "-D"] + }] + }], + "variables": { + "some_var":"variable", + "some_other_var":"cool state" + } +} +``` + +## Deployment + +> Note that the exteral extensions have to be executable to be used by albert + +The extension check its data directories for a directory called `extensions`. The name of a data directory is the id of the extension. I the case of the external extension this is `org.albert.extension.externalextensions`. The data directories reside in the data directories of the application defined by [Qt](http://doc.qt.io/qt-5/qstandardpaths.html#StandardLocation-enum). Hence the external extensions would be looked up in the following directories (in this order): + +* ~/.local/share/albert/org.albert.extension.externalextensions/extensions +* /usr/local/share/albert/org.albert.extension.externalextensions/extensions +* /usr/share/albert/org.albert.extension.externalextensions/extensions + +Ids are guaranteed to be unique. This means that if several of those path contain a plugins with identical ids, only the first found plugin will be used. diff --git a/plugins/externalextensions/metadata.json b/plugins/.archive/externalextensions/metadata.json similarity index 100% rename from plugins/externalextensions/metadata.json rename to plugins/.archive/externalextensions/metadata.json diff --git a/plugins/externalextensions/src/configwidget.cpp b/plugins/.archive/externalextensions/src/configwidget.cpp similarity index 100% rename from plugins/externalextensions/src/configwidget.cpp rename to plugins/.archive/externalextensions/src/configwidget.cpp diff --git a/plugins/externalextensions/src/configwidget.h b/plugins/.archive/externalextensions/src/configwidget.h similarity index 100% rename from plugins/externalextensions/src/configwidget.h rename to plugins/.archive/externalextensions/src/configwidget.h diff --git a/plugins/externalextensions/src/configwidget.ui b/plugins/.archive/externalextensions/src/configwidget.ui similarity index 88% rename from plugins/externalextensions/src/configwidget.ui rename to plugins/.archive/externalextensions/src/configwidget.ui index 1c4cee5..8d50a70 100644 --- a/plugins/externalextensions/src/configwidget.ui +++ b/plugins/.archive/externalextensions/src/configwidget.ui @@ -9,7 +9,7 @@ <html> <head/> <body> -<p>External extensions allow the user to rapidly write custom extensions. External extensions are basically programs that follow a specific communication protocol. For the details see the <a href="https://albertlauncher.github.io/docs/extensions/external/">wiki</a>. The list below contains the extensions found on your system. +<p>External extensions allow the user to rapidly write custom extensions. External extensions are basically programs that follow a specific communication protocol. For the details check the docs. The list below contains the extensions found on your system. </p> </body> </html> diff --git a/plugins/externalextensions/src/extension.cpp b/plugins/.archive/externalextensions/src/extension.cpp similarity index 96% rename from plugins/externalextensions/src/extension.cpp rename to plugins/.archive/externalextensions/src/extension.cpp index 28eda45..563af97 100644 --- a/plugins/externalextensions/src/extension.cpp +++ b/plugins/.archive/externalextensions/src/extension.cpp @@ -1,6 +1,5 @@ // Copyright (C) 2014-2018 Manuel Schneider -#include #include #include #include @@ -12,6 +11,11 @@ #include "extension.h" #include "externalextension.h" #include "externalextensionmodel.h" +Q_LOGGING_CATEGORY(qlc, "applications") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() using namespace std; diff --git a/plugins/externalextensions/src/extension.h b/plugins/.archive/externalextensions/src/extension.h similarity index 91% rename from plugins/externalextensions/src/extension.h rename to plugins/.archive/externalextensions/src/extension.h index 8134773..089d443 100644 --- a/plugins/externalextensions/src/extension.h +++ b/plugins/.archive/externalextensions/src/extension.h @@ -1,10 +1,12 @@ // Copyright (C) 2014-2018 Manuel Schneider #pragma once +#include #include #include #include "albert/extension.h" #include "externalextension.h" +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace ExternalExtensions { diff --git a/plugins/externalextensions/src/externalextension.cpp b/plugins/.archive/externalextensions/src/externalextension.cpp similarity index 100% rename from plugins/externalextensions/src/externalextension.cpp rename to plugins/.archive/externalextensions/src/externalextension.cpp diff --git a/plugins/externalextensions/src/externalextension.h b/plugins/.archive/externalextensions/src/externalextension.h similarity index 100% rename from plugins/externalextensions/src/externalextension.h rename to plugins/.archive/externalextensions/src/externalextension.h diff --git a/plugins/externalextensions/src/externalextensionmodel.cpp b/plugins/.archive/externalextensions/src/externalextensionmodel.cpp similarity index 100% rename from plugins/externalextensions/src/externalextensionmodel.cpp rename to plugins/.archive/externalextensions/src/externalextensionmodel.cpp diff --git a/plugins/externalextensions/src/externalextensionmodel.h b/plugins/.archive/externalextensions/src/externalextensionmodel.h similarity index 100% rename from plugins/externalextensions/src/externalextensionmodel.h rename to plugins/.archive/externalextensions/src/externalextensionmodel.h diff --git a/plugins/CMakeLists.txt b/plugins/CMakeLists.txt index 4bdee96..2612682 100644 --- a/plugins/CMakeLists.txt +++ b/plugins/CMakeLists.txt @@ -33,12 +33,7 @@ endif() option(BUILD_CHROMEBOOKMARKS "Build the extension" ON) if (BUILD_CHROMEBOOKMARKS) - add_subdirectory(chromebookmarks) -endif() - -option(BUILD_EXTERNALEXTENSIONS "Build the extension" ON) -if (BUILD_EXTERNALEXTENSIONS) - add_subdirectory(externalextensions) + add_subdirectory(chromium) endif() option(BUILD_DEBUG "Build the extension" OFF) @@ -46,7 +41,7 @@ if (BUILD_DEBUG) add_subdirectory(debug) endif() -option(BUILD_FILES "Build the extension" ON) # Deprecated +option(BUILD_FILES "Build the extension" ON) if (BUILD_FILES) add_subdirectory(files) endif() diff --git a/plugins/README.md b/plugins/README.md new file mode 100644 index 0000000..4cf09fe --- /dev/null +++ b/plugins/README.md @@ -0,0 +1,62 @@ +# C++/Qt plugins + +A native albert extension is a [Qt Plugin](http://doc.qt.io/qt-5/plugins-howto.html#the-low-level-api-extending-qt-applications.) which is nothing else but a special shared library. A plugin has to have the correct interface id (IID) and of course to implement this interfaces to be loaded, e.g. `Core::Extension` or `Core::Frontend`. The best way to to get an overview is to read the [core library interface](https://github.com/albertlauncher/albert/tree/master/include/albert) classes. The headers comments and the other plugins especially the [template extension](https://github.com/albertlauncher/plugins/tree/master/templateExtension) should get you started. + +The internal API is still not final yet. If you want to write a plugin check the other extensions. There are some caveats and requirements you should know: + +- Qt Plugin needs a metadata file +- The metadata needs a unique id to be loaded +- The metadata file name must match the name in the `Q_PLUGIN_METADATA` macro +- The interface id defined in `Q_PLUGIN_METADATA` must match the current one defined in the interface headers for the plugin to be loaded. + +## Getting started + +The best way to get started is to copy the [template extension](https://github.com/albertlauncher/plugins/tree/master/templateExtension) and adjust the contents. + +To keep the code readable there are some conventions that are not strictly necessary, but the intention is to unify the filenames of the plugins.The main class of the extension is called `Extension` and if the extension returns a configuration widget the class shall be called `ConfigWidget`. The metadata file is called `metadata.json`. This would implicitly lead to naming conflicts, therefor all classes of an extensions live in a dedicated namespace having the name of the extension. In bullets: + +- Copy the template extension. +- Adjust the values contents in `metadata.json` and project name in `CmakeLists.txt`. +- Rename the namespace. Remember to define the namespace in the `*.ui` files, too. +- Make sure to have checked all core library headers . +- Implement your extension. + +Contact us if you need [help](/help/). + +## Extension plugins + +Implement the `Core::Extension` and `Core::QueryHandler` interface. Especially `Core::Extension` is not final yet. But this should not be a problem. Since changes would need you to just change a few lines of code. + +`Core::QueryHandler` has several functions that will be called on special events. Most important is the virtual function `handleQuery(Query)` this function will be called when the user types in his queries. + +The `Core::Query` object contains all necessary information and accepts objects of abstract type `Core::Item`. Subclass it or use `Core::StandardItem`. The items interface has a getter for actions of abstract type `Core::Action`. Again subclass it or use `Core::StandardAction`. Furter there is the `Core::IndexableItem` interface with its standard implementation `Core::StandardIndexItem`. These items are for the use with the utility class `Core::OfflineIndex` which does basic offline indexing and searching for you. + +To get a detailed description of the interfaces read the header files of the core library interface classes. + +## Frontend plugins + +Implement the `Core::Frontend` interface. Implementing a frontend is a cumbersome process with tons of caveats. I will rather not write a documentation on it. [Contact](/help/) us directly. + + +## The plugin metadata + +The plugin metadata is a mandatory file that is needed to compile the plugin. Its content is *JSON* formatted and its name has to be equal to the the one specified in the `Q_PLUGIN_METADATA` in the extensions main class. The convention is to call it `metadata.json`. Its fields give the application information about the plugin without having to load the plugin. + +Currently the plugin specification has the following keys: +- `id` is the unique identifier of the app. A plugin will not be loaded if its id has been registered already by an other plugin. +- `name` is the pretty printed name of the plugin. +- `version` is, well, the version of the plugin. +- `author` name of the developer of this plugin. +- `dependencies` is an array of dependencies of this plugin. These dependencies are mandatory for the plugin but optional for the application. The user is responsible to install them. + +A plugin specification could look like the following: + +```json +{ + "id" : "org.albert.extension.bookmarks", + "name" : "Bookmarks", + "version" : "1.1", + "author" : "Manuel Schneider", + "dependencies" : [] +} +``` diff --git a/plugins/applications/README.md b/plugins/applications/README.md new file mode 100644 index 0000000..8044ea0 --- /dev/null +++ b/plugins/applications/README.md @@ -0,0 +1,7 @@ +The applications extension makes desktop applications runnable by albert. The concept of desktop applications is described in the [freedesktop.org Desktop Entry Specification](https://specifications.freedesktop.org/desktop-entry-spec/latest/). + +Desktop entries are looked up in the _applications_ directory in the paths set in `$XDG_DATA_HOME` and `$XDG_DATA_DIRS` environment variables. If they are not set, they default to `~/.local/share` and `/usr/local/share:/usr/share`. + +Every application is represented by a desktop file which has an ID. The desktop file ID is built using the path of the desktop file relative to the applications directory and turning '/' into '-'. If multiple files have the same desktop file ID, the first one in the precedence order given by the paths above is used. The standard action of an application item is to start the application, the alternative actions are defined by the desktop actions in the desktop entry. + +The fuzzy option in the settings dialog allows error tolerant matching of the items. diff --git a/plugins/applications/metadata.json b/plugins/applications/metadata.json index 5f00dfb..89578d5 100644 --- a/plugins/applications/metadata.json +++ b/plugins/applications/metadata.json @@ -1,10 +1,10 @@ { "id" : "org.albert.extension.applications", "name" : "Applications", - "version" : "1.1", + "version" : "1.2", "platform" : "Linux", "group" : "Extensions", - "author" : "Manuel Schneider", - "dependencies" : ["gksu"], + "author" : "manuelschneid3r", + "dependencies" : [], "enabledbydefault": true } diff --git a/plugins/applications/src/configwidget.cpp b/plugins/applications/src/configwidget.cpp index b0819f4..6a697ae 100644 --- a/plugins/applications/src/configwidget.cpp +++ b/plugins/applications/src/configwidget.cpp @@ -6,8 +6,4 @@ /** ***************************************************************************/ Applications::ConfigWidget::ConfigWidget(QWidget *parent) : QWidget(parent) { ui.setupUi(this); - - // Show the app dirs in the label - QStringList standardPaths = QStandardPaths::standardLocations(QStandardPaths::ApplicationsLocation); - ui.label->setText(ui.label->text().replace("__XDG_DATA_DIRS__", standardPaths.join(", "))); } diff --git a/plugins/applications/src/extension.cpp b/plugins/applications/src/extension.cpp index 2dfe8d4..5a6b43a 100644 --- a/plugins/applications/src/extension.cpp +++ b/plugins/applications/src/extension.cpp @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2018 Manuel Schneider +// Copyright (C) 2014-2020 Manuel Schneider #include #include @@ -10,34 +10,29 @@ #include #include #include -#include -#include #include +#include +#include #include #include #include #include #include -#include "configwidget.h" -#include "extension.h" #include "albert/queryhandler.h" #include "albert/util/offlineindex.h" #include "albert/util/standardactions.h" #include "albert/util/standardindexitem.h" -#include "albert/util/shutil.h" +#include "configwidget.h" +#include "extension.h" #include "xdg/iconlookup.h" +Q_LOGGING_CATEGORY(qlc, "apps") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() using namespace Core; using namespace std; -Q_LOGGING_CATEGORY(qlc_applications, "applications") -#define DEBUG qCDebug(qlc_applications).noquote() -#define INFO qCInfo(qlc_applications).noquote() -#define WARNING qCWarning(qlc_applications).noquote() -#define CRITICAL qCCritical(qlc_applications).noquote() - -extern QString terminalCommand; - - namespace { const char* CFG_FUZZY = "fuzzy"; @@ -52,56 +47,48 @@ const char* CFG_USENONLOCALIZEDNAME = "use_non_localized_name"; const bool DEF_USENONLOCALIZEDNAME = false; /******************************************************************************/ -QStringList expandedFieldCodes(const QStringList & unexpandedFields, - const QString & icon, - const QString & name, - const QString & path) { +QString fieldCodesExpanded(const QString & exec, const QString & name, const QString & icon, const QString & de_path) { /* - * A number of special field codes have been defined which will be expanded - * by the file manager or program launcher when encountered in the command - * line. Field codes consist of the percentage character ("%") followed by - * an alpha character. Literal percentage characters must be escaped as %%. - * Deprecated field codes should be removed from the command line and - * ignored. Field codes are expanded only once, the string that is used to - * replace the field code should not be checked for field codes itself. + * https://specifications.freedesktop.org/desktop-entry-spec/1.5/ar01s07.html * - * http://standards.freedesktop.org/desktop-entry-spec/latest/ar01s06.html + * Code Description + * %% : '%' + * %f : A single file name (including the path), even if multiple files are selected. The system reading the desktop entry should recognize that the program in question cannot handle multiple file arguments, and it should should probably spawn and execute multiple copies of a program for each selected file if the program is not able to handle additional file arguments. If files are not on the local file system (i.e. are on HTTP or FTP locations), the files will be copied to the local file system and %f will be expanded to point at the temporary file. Used for programs that do not understand the URL syntax. + * %F : A list of files. Use for apps that can open several local files at once. Each file is passed as a separate argument to the executable program. + * %u : A single URL. Local files may either be passed as file: URLs or as file path. + * %U : A list of URLs. Each URL is passed as a separate argument to the executable program. Local files may either be passed as file: URLs or as file path. + * %i : The Icon key of the desktop entry expanded as two arguments, first --icon and then the value of the Icon key. Should not expand to any arguments if the Icon key is empty or missing. + * %c : The translated name of the application as listed in the appropriate Name key in the desktop entry. + * %k : The location of the desktop file as either a URI (if for example gotten from the vfolder system) or a local filename or empty if no location is known. + * Deprecated: %v %m %d %D %n %N */ - QStringList expandedFields; - - for (const QString & field : unexpandedFields){ - - if (field == "%i" && !icon.isEmpty()) { - expandedFields.push_back("--icon"); - expandedFields.push_back(icon); - } - - QString tmpstr; - QString::const_iterator it = field.begin(); - - while (it != field.end()) { - if (*it == '%'){ - ++it; - if (it == field.end()) - break; - else if (*it=='%') - tmpstr.push_back("%"); - else if (*it=='c') - tmpstr.push_back(name); - else if (*it=='k') - tmpstr.push_back(path); - // TODO Unhandled f F u U - } - else - tmpstr.push_back(*it); + QString commandLine; + for (auto it = exec.cbegin(); it != exec.end(); ++it) { + if (*it == '%'){ ++it; - } - if (!tmpstr.isEmpty()) - expandedFields.push_back(std::move(tmpstr)); + if (it == exec.end()) { + break; + } else if (*it=='%') { + commandLine.push_back("%"); + } else if (*it=='f') { // Unhandled atm + } else if (*it=='F') { // Unhandled atm + } else if (*it=='u') { // Unhandled atm + } else if (*it=='U') { // Unhandled atm + } else if (*it=='i' && !icon.isNull()) { + commandLine.push_back(QString("--icon %1").arg(icon)); + } else if (*it=='c') { + commandLine.push_back(name); + } else if (*it=='k') { + commandLine.push_back(de_path); + } else if (*it=='v' || *it=='m' || *it=='d' || *it=='D' || *it=='n' || *it=='N') { /*Skipping deprecated field codes*/ + } else { + qWarning() << "Ignoring invalid field code: " << *it; + } + } else + commandLine.push_back(*it); } - return expandedFields; + return commandLine; } - /******************************************************************************/ QString xdgStringEscape(const QString & unescaped) { /* @@ -163,8 +150,8 @@ class Applications::Private QPointer widget; QFileSystemWatcher watcher; - QString graphicalSudoPath; + QStringList indexedDirs; vector> index; OfflineIndex offlineIndex; @@ -194,7 +181,7 @@ void Applications::Private::startIndexing() { // Run finishIndexing when the indexing thread finished futureWatcher.disconnect(); QObject::connect(&futureWatcher, &QFutureWatcher>>::finished, - std::bind(&Private::finishIndexing, this)); + bind(&Private::finishIndexing, this)); // Run the indexer thread futureWatcher.setFuture(QtConcurrent::run(this, &Private::indexApplications)); @@ -248,7 +235,8 @@ vector> Applications::Private::indexApplications() QStringList xdg_current_desktop = QString(getenv("XDG_CURRENT_DESKTOP")).split(':',QString::SkipEmptyParts); QLocale loc; QStringList xdgAppDirs = QStandardPaths::standardLocations(QStandardPaths::ApplicationsLocation); - + xdgAppDirs.append(QStandardPaths::standardLocations(QStandardPaths::DesktopLocation)); + /* * Create a list of desktop files to index (unique ids) * To determine the ID of a desktop file, make its full path relative to @@ -274,7 +262,7 @@ vector> Applications::Private::indexApplications() const QString &id = id_path_pair.first; const QString &path = id_path_pair.second; - DEBUG << "Indexing desktop file:" << id; + DEBG << "Indexing desktop file:" << id; map> sectionMap; map>::iterator sectionIterator; @@ -364,11 +352,7 @@ vector> Applications::Private::indexApplications() continue; // Try to get the localized icon, skip if empty - icon = XDG::IconLookup::iconPath({xdgStringEscape(getLocalizedKey("Icon", entryMap, loc)), - "application-x-executable", - "exec"}); - if (icon.isNull()) - icon = ":application-x-executable"; + icon = xdgStringEscape(getLocalizedKey("Icon", entryMap, loc)); // Check if this is a terminal app term = (entryIterator = entryMap.find("Terminal")) != entryMap.end() @@ -399,34 +383,29 @@ vector> Applications::Private::indexApplications() // if ((valueIterator = entryMap.find("MimeType")) != entryMap.end()) // keywords = xdgStringEscape(valueIterator->second).split(';',QString::SkipEmptyParts); + /* * Build the item */ - // Unquote arguments and expand field codes - QStringList commandline = expandedFieldCodes(Core::ShUtil::split(exec), - icon, name, path); - // Malformed exec line. Constraint (1) - if (commandline.isEmpty()) - continue; + // Field code expandesd commandline + QString commandLine = fieldCodesExpanded(exec, name, icon, path); - // Finally we got everything, build the item - shared_ptr item = std::make_shared(); - item->setIconPath(icon); - item->setId(id); - item->setText(name); - item->setCompletion(name); + // Icon path + QString icon_path = XDG::IconLookup::iconPath({icon, "application-x-executable", "exec"}); + if (icon_path.isNull()) + icon_path = ":application-x-executable"; - // Set subtext/tootip + // Description + QString subtext; if (!comment.isEmpty()) - item->setSubtext(comment); + subtext = comment; else if(useGenericName && !genericName.isEmpty()) - item->setSubtext(genericName); + subtext = genericName; else if(useNonLocalizedName && !nonLocalizedName.isEmpty()) - item->setSubtext(nonLocalizedName); + subtext = nonLocalizedName; else - item->setSubtext(exec); - + subtext = commandLine; // Set index strings vector indexStrings; @@ -442,35 +421,29 @@ vector> Applications::Private::indexApplications() "dbus-send ", "/" }; - if (std::none_of(excludes.begin(), excludes.end(), [&exec](const QString &str){ return exec.startsWith(str); })) - indexStrings.emplace_back(commandline[0], UINT_MAX); // safe since (1) + if (none_of(excludes.begin(), excludes.end(), [&exec](const QString &str){ return exec.startsWith(str); })) + indexStrings.emplace_back(exec.section(QChar(QChar::Space), 0, 0, QString::SectionSkipEmpty), UINT_MAX); if (useKeywords) for (auto & kw : keywords) indexStrings.emplace_back(kw, UINT_MAX/2); if (useGenericName && !genericName.isEmpty()) - indexStrings.emplace_back(genericName, UINT_MAX/2 ); + indexStrings.emplace_back(genericName, UINT_MAX/2); if (useNonLocalizedName && !nonLocalizedName.isEmpty()) - indexStrings.emplace_back(nonLocalizedName, UINT_MAX/2 ); - - item->setIndexKeywords(std::move(indexStrings)); - - + indexStrings.emplace_back(nonLocalizedName, UINT_MAX/2); /* * Build actions */ - // Default and root action - if (term) { - item->addAction(make_shared("Run", commandline, workingDir, false)); - item->addAction(make_shared("Run as root", QStringList("sudo")+commandline, workingDir, false)); - } else { - item->addAction(make_shared("Run", commandline, workingDir)); - item->addAction(make_shared("Run as root", QStringList("gksudo")+commandline, workingDir)); - } + ActionList actionList; + + if (term) + actionList.emplace_back(makeTermAction("Run", commandLine, TermAction::CloseOnExit, workingDir)); + else + actionList.emplace_back(makeProcAction("Run", QStringList() << "sh" << "-c" << commandLine, workingDir)); // Desktop Actions for (const QString &actionIdentifier: actionIdentifiers){ @@ -490,21 +463,15 @@ vector> Applications::Private::indexApplications() continue; // Unquote arguments and expand field codes - QStringList commandline = expandedFieldCodes(Core::ShUtil::split(entryIterator->second), - icon, name, path); + commandLine = fieldCodesExpanded(entryIterator->second, icon, name, path); if (term) - item->addAction(make_shared(actionName, commandline, workingDir, false)); + actionList.emplace_back(makeTermAction(actionName, commandLine, TermAction::CloseOnExit, workingDir)); else - item->addAction(make_shared(actionName, commandline, workingDir)); + actionList.emplace_back(makeProcAction(actionName, QStringList() << "sh" << "-c" << commandLine, workingDir)); } - - /* - * Add item - */ - - desktopEntries.push_back(std::move(item)); + desktopEntries.emplace_back(makeStdIdxItem(id, icon_path, name, subtext, indexStrings, actionList)); } return desktopEntries; } @@ -523,7 +490,10 @@ Applications::Extension::Extension() qunsetenv("DESKTOP_AUTOSTART_ID"); - d->graphicalSudoPath = QStandardPaths::findExecutable("gksudo"); + d->indexedDirs = QStandardPaths::standardLocations(QStandardPaths::ApplicationsLocation); + if (QStandardPaths::standardLocations(QStandardPaths::DesktopLocation) + != QStandardPaths::standardLocations(QStandardPaths::HomeLocation)) // Missing desktops fall back to ~ + d->indexedDirs << QStandardPaths::standardLocations(QStandardPaths::DesktopLocation); // Load settings d->offlineIndex.setFuzzy(settings().value(CFG_FUZZY, DEF_FUZZY).toBool()); @@ -534,7 +504,7 @@ Applications::Extension::Extension() // If the filesystem changed, trigger the scan connect(&d->watcher, &QFileSystemWatcher::directoryChanged, - std::bind(&Private::startIndexing, d.get())); + bind(&Private::startIndexing, d.get())); // Trigger initial update updateIndex(); @@ -554,6 +524,9 @@ QWidget *Applications::Extension::widget(QWidget *parent) { if (d->widget.isNull()) { d->widget = new ConfigWidget(parent); + // Show the app dirs in the label + d->widget->ui.label->setText(d->widget->ui.label->text().replace("__XDG_DATA_DIRS__", d->indexedDirs.join(", "))); + // Fuzzy d->widget->ui.checkBox_fuzzy->setChecked(d->offlineIndex.fuzzy()); connect(d->widget->ui.checkBox_fuzzy, &QCheckBox::toggled, @@ -613,10 +586,10 @@ void Applications::Extension::handleQuery(Core::Query * query) const { vector,uint>> results; for (const shared_ptr &item : indexables) - results.emplace_back(std::static_pointer_cast(item), 1); + results.emplace_back(static_pointer_cast(item), 1); - query->addMatches(std::make_move_iterator(results.begin()), - std::make_move_iterator(results.end())); + query->addMatches(make_move_iterator(results.begin()), + make_move_iterator(results.end())); } diff --git a/plugins/applications/src/extension.h b/plugins/applications/src/extension.h index b4697e8..7aa741f 100644 --- a/plugins/applications/src/extension.h +++ b/plugins/applications/src/extension.h @@ -6,8 +6,7 @@ #include #include "albert/extension.h" #include "albert/queryhandler.h" - -Q_DECLARE_LOGGING_CATEGORY(qlc_applications) +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace Applications { @@ -23,7 +22,7 @@ class Extension final : public Core::Extension, public Core::QueryHandler Extension(); ~Extension() override; - QString name() const override { return "Applications"; } + QString name() const override { return "Apps"; } QWidget *widget(QWidget *parent = nullptr) override; void handleQuery(Core::Query * query) const override; diff --git a/plugins/calculator/README.md b/plugins/calculator/README.md new file mode 100644 index 0000000..bc9dba9 --- /dev/null +++ b/plugins/calculator/README.md @@ -0,0 +1,72 @@ +**Note**: This extension depends on [muparser](http://beltoforion.de/article.php?a=muparser). + +The calculator should be self-explanatory. The calculator item appears as soon as you type a valid math expression into the input box. Euler's number `_e` and π `_pi` are predefined. + +## Known limitations + +Muparser uses double precision floats which introduces the well known [precision problems](https://stackoverflow.com/questions/588004/is-floating-point-math-broken). + +## Built-in functions + +The following table gives an overview of the functions supported by the default implementation. It lists the function names, the number of arguments and a brief description. + +|Name|Argc.|Explanation| +|-|-|-| +|sin|1|sine function| +|cos|1|cosine function| +|tan|1|tangens function| +|asin|1|arcus sine function| +|acos|1|arcus cosine function| +|atan|1|arcus tangens function| +|sinh|1|hyperbolic sine function| +|cosh|1|hyperbolic cosine| +|tanh|1|hyperbolic tangens function| +|asinh|1|hyperbolic arcus sine function| +|acosh|1|hyperbolic arcus tangens function| +|atanh|1|hyperbolic arcur tangens function| +|log2|1|logarithm to the base 2| +|log10|1|logarithm to the base 10| +|log|1|logarithm to base e (2.71828...)| +|ln|1|logarithm to base e (2.71828...)| +|exp|1|e raised to the power of x| +|sqrt|1|square root of a value| +|sign|1|sign function -1 if x<0; 1 if x>0| +|rint|1|round to nearest integer| +|abs|1|absolute value| +|min|var.|min of all arguments| +|max|var.|max of all arguments| +|sum|var.|sum of all arguments| +|avg|var.|mean value of all arguments| + +## Built-in binary operators + +The following table lists the default binary operators supported by the parser. + +|Operator|Description|Priority| +|-|-|-| +|=|assignement|-1| +|&&|logical and|1| +|\|\||logical or|2| +|<=|less or equal|4| +|>=|greater or equal|4| +|!=|not equal|4| +|==|equal|4| +|>|greater than|4| +|<|less than|4| +|+|addition|5| +|-|subtraction|5| +|*|multiplication|6| +|/|division|6| +|^|raise x to the power of y|7| + +\*The assignment operator is special since it changes one of its arguments and can only by applied to variables. + +## Ternary Operators + +muParser has built in support for the if then else operator. It uses lazy evaluation in order to make sure only the necessary branch of the expression is evaluated. + +|Operator|Description|Remarks| +|-|-|-| +|?:|if then else operator|C++ style syntax| + +For more details check the [muparser documentation](http://beltoforion.de/article.php?a=muparser&hl=en&p=features&s=idDef1#idDef1). diff --git a/plugins/calculator/metadata.json b/plugins/calculator/metadata.json index adf4e29..ed4c6a8 100644 --- a/plugins/calculator/metadata.json +++ b/plugins/calculator/metadata.json @@ -1,10 +1,10 @@ { "id" : "org.albert.extension.calculator", "name" : "Calculator", - "version" : "1.0", + "version" : "1.1", "platform" : "All", "group" : "Extensions", - "author" : "Manuel Schneider", + "author" : "manuelschneid3r", "dependencies" : ["libmuparser"], "enabledbydefault": true } diff --git a/plugins/calculator/src/configwidget.ui b/plugins/calculator/src/configwidget.ui index dd072a2..0d2905e 100644 --- a/plugins/calculator/src/configwidget.ui +++ b/plugins/calculator/src/configwidget.ui @@ -6,7 +6,7 @@ - <html><head/><body><p>This is a simple calculator extension. It lets you evaluate basic math expressions. Check the <a href="https://albertlauncher.github.io/docs/extensions/calculator/"><span style=" text-decoration: underline; color:#0000ff;">docs</span></a> for built-in fuctions and operators.</p></body></html> + <html><head/><body><p>This is a simple calculator extension. It lets you evaluate basic math expressions.</p></body></html> true @@ -23,6 +23,13 @@ + + + + Parse hex expressions + + + diff --git a/plugins/calculator/src/extension.cpp b/plugins/calculator/src/extension.cpp index d7029fe..c42f775 100644 --- a/plugins/calculator/src/extension.cpp +++ b/plugins/calculator/src/extension.cpp @@ -1,42 +1,44 @@ // Copyright (C) 2014-2018 Manuel Schneider #include -#include #include #include #include +#include #include +#include "albert/query.h" +#include "albert/util/standardactions.h" +#include "albert/util/standarditem.h" #include "configwidget.h" #include "extension.h" #include "muParser.h" -#include "albert/query.h" -#include "albert/util/standarditem.h" -#include "albert/util/standardactions.h" +#include "muParserInt.h" #include "xdg/iconlookup.h" +Q_LOGGING_CATEGORY(qlc, "calculator") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() using namespace std; using namespace Core; - -Q_LOGGING_CATEGORY(qlc_calculator, "calculator") - - namespace { const QString CFG_SEPS = "group_separators"; const bool CFG_SEPS_DEF = false; +const QString CFG_HEXP = "hex_parsing"; +const bool CFG_HEXP_DEF = false; } - -class Calculator::Private +struct Calculator::Extension::Private { -public: QPointer widget; std::unique_ptr parser; + std::unique_ptr iparser; QLocale locale; QString iconPath; }; - /** ***************************************************************************/ Calculator::Extension::Extension() : Core::Extension("org.albert.extension.calculator"), @@ -55,15 +57,16 @@ Calculator::Extension::Extension() d->parser->SetDecSep(d->locale.decimalPoint().toLatin1()); d->parser->SetThousandsSep(d->locale.groupSeparator().toLatin1()); d->parser->SetArgSep(';'); -} + if (settings().value(CFG_SEPS, CFG_SEPS_DEF).toBool()) + setGroupSeparatorEnabled(true); - -/** ***************************************************************************/ -Calculator::Extension::~Extension() { - + if (settings().value(CFG_HEXP, CFG_HEXP_DEF).toBool()) + setIParserEnabled(true); } +/** ***************************************************************************/ +Calculator::Extension::~Extension() { } /** ***************************************************************************/ @@ -72,49 +75,70 @@ QWidget *Calculator::Extension::widget(QWidget *parent) { d->widget = new ConfigWidget(parent); d->widget->ui.checkBox_groupsep->setChecked(!(d->locale.numberOptions() & QLocale::OmitGroupSeparator)); - connect(d->widget->ui.checkBox_groupsep, &QCheckBox::toggled, [this](bool checked){ - settings().setValue(CFG_SEPS, checked); - d->locale.setNumberOptions( (checked) ? d->locale.numberOptions() & ~QLocale::OmitGroupSeparator - : d->locale.numberOptions() | QLocale::OmitGroupSeparator ); - }); + connect(d->widget->ui.checkBox_groupsep, &QCheckBox::toggled, + [this](bool checked){ setGroupSeparatorEnabled(checked); }); + + d->widget->ui.checkBox_hexparsing->setChecked(!(d->locale.numberOptions() & QLocale::OmitGroupSeparator)); + connect(d->widget->ui.checkBox_hexparsing, &QCheckBox::toggled, + [this](bool checked){ setIParserEnabled(checked); }); + } return d->widget; } - /** ***************************************************************************/ void Calculator::Extension::handleQuery(Core::Query * query) const { - try { - d->parser->SetExpr(query->string().toStdString()); - } catch (mu::Parser::exception_type &exception) { - qCWarning(qlc_calculator).noquote() << "Muparser SetExpr exception: " << exception.GetMsg().c_str(); + if (query->string().isEmpty()) return; - } - double result; // http://beltoforion.de/article.php?a=muparser&p=errorhandling + QString result; try { - result = d->parser->Eval(); - } catch (mu::Parser::exception_type &) { - // Expected exception in case of invalid input - // qDebug() << "Muparser Eval exception: " << exception.GetMsg().c_str(); + if(d->iparser && query->string().contains("0x")) { + d->iparser->SetExpr(query->string().toStdString()); + result = d->locale.toString(d->iparser->Eval(), 'G', 16); + } else { + d->parser->SetExpr(query->string().toStdString()); + result = d->locale.toString(d->parser->Eval(), 'G', 16); + } + } catch (mu::Parser::exception_type &exception) { + DEBG << "Muparser SetExpr exception: " << exception.GetMsg().c_str(); return; } - auto item = make_shared("muparser"); - item->setIconPath(d->iconPath); - d->locale.setNumberOptions(settings().value(CFG_SEPS, CFG_SEPS_DEF).toBool() - ? d->locale.numberOptions() & ~QLocale::OmitGroupSeparator - : d->locale.numberOptions() | QLocale::OmitGroupSeparator ); - item->setText(d->locale.toString(result, 'G', 16)); - item->setSubtext(QString("Result of '%1'").arg(query->string())); - item->setCompletion(item->text()); - d->locale.setNumberOptions(d->locale.numberOptions() | QLocale::OmitGroupSeparator); - item->addAction(make_shared("Copy result to clipboard", - d->locale.toString(result, 'G', 16))); - item->addAction(make_shared("Copy equation to clipboard", - QString("%1 = %2").arg(query->string(), item->text()))); - query->addMatch(move(item), UINT_MAX); + query->addMatch(makeStdItem("muparser", + d->iconPath, result, QString("Result of '%1'").arg(query->string()), + ActionList{ + makeClipAction("Copy result to clipboard", result), + makeClipAction("Copy equation to clipboard", QString("%1 = %2").arg(query->string(), result)) + }, + result + ), UINT_MAX); +} + + +/** ***************************************************************************/ +void Calculator::Extension::setGroupSeparatorEnabled(bool enabled){ + settings().setValue(CFG_SEPS, enabled); + if (enabled) + d->locale.setNumberOptions(d->locale.numberOptions() & ~QLocale::OmitGroupSeparator); + else + d->locale.setNumberOptions(d->locale.numberOptions() | QLocale::OmitGroupSeparator); +} + + +/** ***************************************************************************/ +void Calculator::Extension::setIParserEnabled(bool enabled){ + settings().setValue(CFG_HEXP, enabled); + + if (enabled){ + d->iparser.reset(new mu::ParserInt); + d->iparser->SetDecSep(d->locale.decimalPoint().toLatin1()); + d->iparser->SetThousandsSep(d->locale.groupSeparator().toLatin1()); + d->iparser->SetArgSep(';'); + } + else + d->iparser.reset(); } diff --git a/plugins/calculator/src/extension.h b/plugins/calculator/src/extension.h index 0d232de..8bb14fe 100644 --- a/plugins/calculator/src/extension.h +++ b/plugins/calculator/src/extension.h @@ -6,19 +6,17 @@ #include #include "albert/extension.h" #include "albert/queryhandler.h" - -Q_DECLARE_LOGGING_CATEGORY(qlc_calculator) +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace Calculator { -class Private; - class Extension final : public Core::Extension, public Core::QueryHandler { Q_OBJECT Q_PLUGIN_METADATA(IID ALBERT_EXTENSION_IID FILE "metadata.json") + struct Private; public: @@ -29,6 +27,9 @@ class Extension final : QWidget *widget(QWidget *parent = nullptr) override; void handleQuery(Core::Query * query) const override; + void setGroupSeparatorEnabled(bool enabled); + void setIParserEnabled(bool enabled); + private: std::unique_ptr d; diff --git a/plugins/chromebookmarks/metadata.json b/plugins/chromebookmarks/metadata.json deleted file mode 100644 index 06df0e5..0000000 --- a/plugins/chromebookmarks/metadata.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "id" : "org.albert.extension.chromebookmarks", - "name" : "Chrome bookmarks", - "version" : "1.0", - "platform" : "Linux", - "group" : "Extensions", - "author" : "Manuel Schneider", - "dependencies" : [], - "enabledbydefault": false -} diff --git a/plugins/chromebookmarks/src/configwidget.cpp b/plugins/chromebookmarks/src/configwidget.cpp deleted file mode 100644 index 1261a61..0000000 --- a/plugins/chromebookmarks/src/configwidget.cpp +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright (C) 2014-2018 Manuel Schneider - -#include -#include -#include "configwidget.h" - -/** ***************************************************************************/ -ChromeBookmarks::ConfigWidget::ConfigWidget(QWidget *parent) : QWidget(parent) { - ui.setupUi(this); - - connect(ui.pushButton_editPath, &QPushButton::clicked, - this, &ConfigWidget::onButton_EditPath); -} - -/** ***************************************************************************/ -ChromeBookmarks::ConfigWidget::~ConfigWidget() { - -} - -/** ***************************************************************************/ -void ChromeBookmarks::ConfigWidget::onButton_EditPath() { - QString path = QFileDialog::getOpenFileName(this, tr("Choose path")); - if(path.isEmpty()) return; - emit requestEditPath(path); -} diff --git a/plugins/chromebookmarks/src/configwidget.h b/plugins/chromebookmarks/src/configwidget.h deleted file mode 100644 index a090c3d..0000000 --- a/plugins/chromebookmarks/src/configwidget.h +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright (C) 2014-2018 Manuel Schneider - -#pragma once -#include -#include "ui_configwidget.h" - -namespace ChromeBookmarks { - -class ConfigWidget final : public QWidget -{ - Q_OBJECT -public: - explicit ConfigWidget(QWidget *parent = 0); - ~ConfigWidget(); - Ui::ConfigWidget ui; - -private: - void onButton_EditPath(); - -signals: - void requestEditPath(const QString&); -}; -} diff --git a/plugins/chromebookmarks/src/configwidget.ui b/plugins/chromebookmarks/src/configwidget.ui deleted file mode 100644 index ae506f2..0000000 --- a/plugins/chromebookmarks/src/configwidget.ui +++ /dev/null @@ -1,95 +0,0 @@ - - - ChromeBookmarks::ConfigWidget - - - - - - Path to bookmarkfile - - - - 0 - - - 0 - - - 0 - - - 0 - - - - - true - - - - - - - - - Fuzzy - - - - - - - Qt::Horizontal - - - - 40 - 20 - - - - - - - - - 50 - 0 - - - - Edit - - - - - - - - - - - - Qt::Vertical - - - - 20 - 40 - - - - - - - - - - - - - - - - diff --git a/plugins/chromebookmarks/src/extension.cpp b/plugins/chromebookmarks/src/extension.cpp deleted file mode 100644 index c7ea8a9..0000000 --- a/plugins/chromebookmarks/src/extension.cpp +++ /dev/null @@ -1,336 +0,0 @@ -// Copyright (C) 2014-2018 Manuel Schneider - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include "configwidget.h" -#include "extension.h" -#include "albert/util/standardactions.h" -#include "albert/util/standardindexitem.h" -#include "albert/util/offlineindex.h" -#include "xdg/iconlookup.h" -using namespace std; -using namespace Core; - -namespace { - -const char* EXT_ID = "org.albert.extension.chromebookmarks"; -const char* CFG_PATH = "bookmarkfile"; -const char* CFG_FUZZY = "fuzzy"; -const bool DEF_FUZZY = false; -const char *potentialExecutableNames[] = {"chromium", - "chromium-browser", - "chrome", - "chrome-browser", - "google-chrome", - "google-chrome-beta", - "google-chrome-stable", - "google-chrome-unstable"}; -const char *potentialConfigLocations[] = {"chromium", - "google-chrome"}; - -/** ***************************************************************************/ -vector> indexChromeBookmarks(QString executable, const QString &bookmarksPath) { - - // Build a new index - vector> bookmarks; - - QString icon = XDG::IconLookup::iconPath({"www", "web-browser", "emblem-web"}); - icon = icon.isEmpty() ? ":favicon" : icon; - - // Define a recursive bookmark indexing lambda - std::function rec_bmsearch = - [&rec_bmsearch, &bookmarks, &icon, &executable](const QJsonObject &json) { - QJsonValue type = json["type"]; - if (type == QJsonValue::Undefined) - return; - if (type.toString() == "folder"){ - QJsonArray jarr = json["children"].toArray(); - for (const QJsonValueRef i : jarr) - rec_bmsearch(i.toObject()); - } - if (type.toString() == "url") { - QString name = json["name"].toString(); - QString urlstr = json["url"].toString(); - - vector indexStrings; - QUrl url(urlstr); - QString host = url.host(); - indexStrings.emplace_back(name, UINT_MAX); - indexStrings.emplace_back(host.left(host.size()-url.topLevelDomain().size()), UINT_MAX/2); - - shared_ptr item = std::make_shared(QString("%1.%2").arg(EXT_ID, json["id"].toString())); - item->setText(name); - item->setCompletion(name); - item->setSubtext(urlstr); - item->setIconPath(icon); - item->setIndexKeywords(std::move(indexStrings)); - item->addAction(make_shared("Open URL", - QStringList() << executable << urlstr)); - item->addAction(make_shared("Open URL in new window", - QStringList() << executable << "--new-window" << urlstr)); - item->addAction(make_shared("Copy URL to clipboard", urlstr)); - - bookmarks.push_back(std::move(item)); - } - }; - - QFile f(bookmarksPath); - if (!f.open(QIODevice::ReadOnly)) { - qWarning() << qPrintable(QString("Could not open Chrome bookmarks file '%1'.").arg(bookmarksPath)); - return vector>(); - } - - QJsonObject json = QJsonDocument::fromJson(f.readAll()).object(); - QJsonObject roots = json.value("roots").toObject(); - for (const QJsonValue &i : roots) - if (i.isObject()) - rec_bmsearch(i.toObject()); - - f.close(); - - return bookmarks; -} - -} - - - -/** ***************************************************************************/ -/** ***************************************************************************/ -/** ***************************************************************************/ -/** ***************************************************************************/ -class ChromeBookmarks::Private -{ -public: - Private(Extension *q) : q(q) {} - - Extension *q; - - QPointer widget; - QFileSystemWatcher fileSystemWatcher; - QString bookmarksFile; - QString executable; - - vector> index; - Core::OfflineIndex offlineIndex; - QFutureWatcher>> futureWatcher; - - void finishIndexing(); - void startIndexing(); -}; - - -/** ***************************************************************************/ -void ChromeBookmarks::Private::startIndexing() { - - // Never run concurrent - if ( futureWatcher.future().isRunning() ) - return; - - // Run finishIndexing when the indexing thread finished - futureWatcher.disconnect(); - QObject::connect(&futureWatcher, &QFutureWatcher>>::finished, - std::bind(&Private::finishIndexing, this)); - - // Run the indexer thread - futureWatcher.setFuture(QtConcurrent::run(indexChromeBookmarks, executable, bookmarksFile)); - - // Notification - qInfo() << "Start indexing Chrome bookmarks."; - emit q->statusInfo("Indexing bookmarks ..."); - -} - - -/** ***************************************************************************/ -void ChromeBookmarks::Private::finishIndexing() { - - // Get the thread results - index = futureWatcher.future().result(); - - // Rebuild the offline index - offlineIndex.clear(); - for (const auto &item : index) - offlineIndex.add(item); - - /* - * Finally update the watches (maybe folders changed) - * Note that QFileSystemWatcher stops monitoring files once they have been - * renamed or removed from disk, and directories once they have been removed - * from disk. - * Chromium seems to mv the file (inode change). - */ - if ( fileSystemWatcher.files().empty() ) - if( !fileSystemWatcher.addPath(bookmarksFile)) - qWarning() << qPrintable(QString("%1 can not be watched. Changes in this path will not be noticed.").arg(bookmarksFile)); - - // Notification - qInfo() << qPrintable(QString("Indexed %1 Chrome bookmarks.").arg(index.size())); - emit q->statusInfo(QString("%1 bookmarks indexed.").arg(index.size())); -} - - -/** ***************************************************************************/ -/** ***************************************************************************/ -/** ***************************************************************************/ -/** ***************************************************************************/ -ChromeBookmarks::Extension::Extension() - : Core::Extension(EXT_ID), - Core::QueryHandler(Core::Plugin::id()), - d(new Private(this)) { - - - // Find executable - d->executable = QStandardPaths::findExecutable("chromium"); - for (auto &name : potentialExecutableNames) { - d->executable = QStandardPaths::findExecutable(name);; - if (!d->executable.isEmpty()) - break; - } - if (d->executable.isEmpty()) - throw "Chrome/ium executable not found."; - - // Load settings - d->offlineIndex.setFuzzy(settings().value(CFG_FUZZY, DEF_FUZZY).toBool()); - - // Load and set a valid path - QVariant v = settings().value(CFG_PATH); - if (v.isValid() && v.canConvert(QMetaType::QString) && QFileInfo(v.toString()).exists()) - setPath(v.toString()); - else - restorePath(); - - // If the path changed write it to the settings - connect(this, &Extension::pathChanged, [this](const QString& path){ - settings().setValue(CFG_PATH, path); - }); - - // Update index if bookmark file changed - connect(&d->fileSystemWatcher, &QFileSystemWatcher::fileChanged, - this, &Extension::updateIndex); - - // Update index if bookmark file's path changed - connect(this, &Extension::pathChanged, - this, &Extension::updateIndex); - - // Trigger an initial update - updateIndex(); - - registerQueryHandler(this); -} - - -/** ***************************************************************************/ -ChromeBookmarks::Extension::~Extension() {} - - -/** ***************************************************************************/ -QWidget *ChromeBookmarks::Extension::widget(QWidget *parent) { - if (d->widget.isNull()){ - d->widget = new ConfigWidget(parent); - - // Paths - d->widget->ui.lineEdit_path->setText(d->bookmarksFile); - connect(d->widget.data(), &ConfigWidget::requestEditPath, this, &Extension::setPath); - connect(this, &Extension::pathChanged, d->widget->ui.lineEdit_path, &QLineEdit::setText); - - // Fuzzy - d->widget->ui.checkBox_fuzzy->setChecked(fuzzy()); - connect(d->widget->ui.checkBox_fuzzy, &QCheckBox::toggled, this, &Extension::setFuzzy); - - // Status bar - ( d->futureWatcher.isRunning() ) - ? d->widget->ui.label_statusbar->setText("Indexing bookmarks ...") - : d->widget->ui.label_statusbar->setText(QString("%1 bookmarks indexed.").arg(d->index.size())); - connect(this, &Extension::statusInfo, d->widget->ui.label_statusbar, &QLabel::setText); - } - return d->widget; -} - - -/** ***************************************************************************/ -void ChromeBookmarks::Extension::handleQuery(Core::Query * query) const { - - const vector> &indexables = d->offlineIndex.search(query->string()); - - vector,uint>> results; - for (const shared_ptr &item : indexables) - results.emplace_back(std::static_pointer_cast(item), 0); - - query->addMatches(std::make_move_iterator(results.begin()), - std::make_move_iterator(results.end())); -} - - -/** ***************************************************************************/ -const QString &ChromeBookmarks::Extension::path() { - return d->bookmarksFile; -} - - -/** ***************************************************************************/ -void ChromeBookmarks::Extension::setPath(const QString &path) { - - QFileInfo fi(path); - if (!(fi.exists() && fi.isFile())) - return; - - d->bookmarksFile = path; - - emit pathChanged(path); -} - - -/** ***************************************************************************/ -void ChromeBookmarks::Extension::restorePath() { - // Find a bookmark file (Take first one) - for (const QString &browser : potentialConfigLocations){ - QString root = QDir(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)).filePath(browser); - QDirIterator it(root, {"Bookmarks"}, QDir::Files, QDirIterator::Subdirectories); - while (it.hasNext()) { - setPath(it.next()); - return; - } - } -} - - -/** ***************************************************************************/ -bool ChromeBookmarks::Extension::fuzzy() { - return d->offlineIndex.fuzzy(); -} - - -/** ***************************************************************************/ -void ChromeBookmarks::Extension::updateIndex() { - d->startIndexing(); -} - - -/** ***************************************************************************/ -void ChromeBookmarks::Extension::setFuzzy(bool b) { - settings().setValue(CFG_FUZZY, b); - d->offlineIndex.setFuzzy(b); -} - diff --git a/plugins/chromebookmarks/CMakeLists.txt b/plugins/chromium/CMakeLists.txt similarity index 95% rename from plugins/chromebookmarks/CMakeLists.txt rename to plugins/chromium/CMakeLists.txt index 5b86155..a7d2009 100644 --- a/plugins/chromebookmarks/CMakeLists.txt +++ b/plugins/chromium/CMakeLists.txt @@ -1,6 +1,6 @@ cmake_minimum_required(VERSION 3.1.3) -project(chromebookmarks) +project(chromium) file(GLOB_RECURSE SRC src/*) diff --git a/plugins/chromium/README.md b/plugins/chromium/README.md new file mode 100644 index 0000000..3318024 --- /dev/null +++ b/plugins/chromium/README.md @@ -0,0 +1,3 @@ +The chromium/chrome extension makes your chromium/chrome bookmarks accessible via albert. + +In the settings dialog you can set the path to your bookmarks file, if the default path is not correct. This may happen if you have multiple profiles in use. The fuzzy option allows error tolerant matching of the items. diff --git a/plugins/chromebookmarks/chromebookmarks.qrc b/plugins/chromium/chromium.qrc similarity index 100% rename from plugins/chromebookmarks/chromebookmarks.qrc rename to plugins/chromium/chromium.qrc diff --git a/plugins/chromium/metadata.json b/plugins/chromium/metadata.json new file mode 100644 index 0000000..059c94d --- /dev/null +++ b/plugins/chromium/metadata.json @@ -0,0 +1,10 @@ +{ + "id" : "org.albert.extension.chromium", + "name" : "Chromium", + "version" : "1.1", + "platform" : "All", + "group" : "Extensions", + "author" : "manuelschneid3r", + "dependencies" : [], + "enabledbydefault": false +} diff --git a/plugins/chromebookmarks/resources/favicon.png b/plugins/chromium/resources/favicon.png similarity index 100% rename from plugins/chromebookmarks/resources/favicon.png rename to plugins/chromium/resources/favicon.png diff --git a/plugins/terminal/src/configwidget.ui b/plugins/chromium/src/configwidget.ui similarity index 64% rename from plugins/terminal/src/configwidget.ui rename to plugins/chromium/src/configwidget.ui index b59efcd..60bba58 100644 --- a/plugins/terminal/src/configwidget.ui +++ b/plugins/chromium/src/configwidget.ui @@ -1,15 +1,12 @@ - Terminal::ConfigWidget - + Chromium::ConfigWidget + - + - The terminal extension allows you to run commands in a terminal or a shell directly. Theres not much more about it but convenience. Just invoke the extension using the trigger '>'. - - - true + Fuzzy @@ -26,6 +23,16 @@ + + + + + + + true + + + diff --git a/plugins/chromium/src/extension.cpp b/plugins/chromium/src/extension.cpp new file mode 100644 index 0000000..ae5f8a5 --- /dev/null +++ b/plugins/chromium/src/extension.cpp @@ -0,0 +1,270 @@ +// Copyright (C) 2014-2020 Manuel Schneider + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "ui_configwidget.h" +#include "extension.h" +#include "albert/util/standardactions.h" +#include "albert/util/standardindexitem.h" +#include "albert/util/offlineindex.h" +#include "xdg/iconlookup.h" +Q_LOGGING_CATEGORY(qlc, "chromium") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() +using namespace std; +using namespace Core; + +namespace { +const char* EXT_ID = "org.albert.extension.chromium"; +const char* CFG_FUZZY = "fuzzy"; +const bool DEF_FUZZY = false; +const char *CONFIG_LOCATIONS[] = { + "BraveSoftware", + "brave-browser", + "chromium", + "google-chrome" +}; +} + + +/** ***************************************************************************/ +/** ***************************************************************************/ + +class Chromium::Private +{ +public: + Private(Extension *q) : q(q) {} + + Extension *q; + + QPointer widget; + QFileSystemWatcher fileSystemWatcher; + QSet bookmarksFiles; + + vector> index; + Core::OfflineIndex offlineIndex; + QFutureWatcher>> futureWatcher; + + + void startIndexing() { + + // Never run concurrent + if ( futureWatcher.future().isRunning() ) + return; + + // Run finishIndexing when the indexing thread finished + futureWatcher.disconnect(); + QObject::connect(&futureWatcher, &QFutureWatcher>>::finished, + std::bind(&Private::finishIndexing, this)); + + // Run the indexer thread + futureWatcher.setFuture(QtConcurrent::run(getBookmarks, bookmarksFiles)); + + // Notification + INFO << "Start indexing Chrome bookmarks."; + emit q->statusInfo("Indexing bookmarks ..."); + + } + + + void finishIndexing() { + + // Get the thread results + index = futureWatcher.future().result(); + + // Rebuild the offline index + offlineIndex.clear(); + for (const auto &item : index) + offlineIndex.add(item); + + /* + * Finally update the watches (maybe folders changed) + * Note that QFileSystemWatcher stops monitoring files once they have been + * renamed or removed from disk, and directories once they have been removed + * from disk. + * Chromium seems to mv the file (inode change). + */ + for (auto filePath : bookmarksFiles) + if (!fileSystemWatcher.files().contains(filePath)) + if(!fileSystemWatcher.addPath(filePath)) + WARN << filePath << "can not be watched. Changes in this path will not be noticed."; + + // Notification + auto msg = QString("%1 bookmarks indexed from %2.").arg(index.size()) + .arg(QStringList::fromSet(bookmarksFiles).join(", ")); + INFO << msg; + emit q->statusInfo(msg); + } + + + static vector> getBookmarks(const QSet& bookmarksFiles){ + + vector> bookmarkItems; + + QString icon = XDG::IconLookup::iconPath({"www", "web-browser", "emblem-web"}); + icon = icon.isEmpty() ? ":favicon" : icon; + + // For each bookmarks file + for (auto filePath : bookmarksFiles) { + QFile f(filePath); + if (f.open(QIODevice::ReadOnly)) { + + // Read the bookmarks + QJsonObject json = QJsonDocument::fromJson(f.readAll()).object(); + QJsonObject roots = json.value("roots").toObject(); + set> bookmarks; + for (const QJsonValue &root : roots) + if (root.isObject()) + getBookmarksRecursionHelper(root.toObject(), bookmarks); + + // Create items and add to results + for (const auto& tuple : bookmarks){ + QString guid = get<0>(tuple); + QString title = get<1>(tuple); + QString url = get<2>(tuple); + + auto item = makeStdIdxItem( + QString("%1.%2").arg(EXT_ID, guid), icon, title, url, + IdxStrList{{title, UINT_MAX}, + {url, UINT_MAX/2}}, + ActionList{makeUrlAction("Open URL", url), + makeClipAction("Copy URL to clipboard", url)} + ); + bookmarkItems.emplace_back(item); + } + f.close(); + } else + WARN << "Could not open Chrome bookmarks file:" << filePath; + } + + return bookmarkItems; + } + + + static void getBookmarksRecursionHelper(const QJsonObject &json, set> &output){ + QJsonValue type = json["type"]; + if (type != QJsonValue::Undefined){ + + if (type.toString() == "folder") + for (const QJsonValueRef child : json["children"].toArray()) + getBookmarksRecursionHelper(child.toObject(), output); + + if (type.toString() == "url") + output.emplace(json["guid"].toString(), json["name"].toString(), json["url"].toString()); + } + } +}; + + +/** ***************************************************************************/ +/** ***************************************************************************/ + +Chromium::Extension::Extension() + : Core::Extension(EXT_ID), + Core::QueryHandler(Core::Plugin::id()), + d(new Private(this)) { + + // Load settings + d->offlineIndex.setFuzzy(settings().value(CFG_FUZZY, DEF_FUZZY).toBool()); + + // Update index when a "Bookmark" file changed + connect(&d->fileSystemWatcher, &QFileSystemWatcher::fileChanged, + this, [this](){ d->startIndexing(); }); + + // Find "Bookmarks" files, implicitly triggers an initial update + updatePaths(); + + registerQueryHandler(this); +} + + +/** ***************************************************************************/ +Chromium::Extension::~Extension() {} + + +/** ***************************************************************************/ +void Chromium::Extension::updatePaths() { + + QSet files; + + // Search for chromium based "Bookmarks" files + QDir configDir = QDir(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)); + for (const QString &configLocation : CONFIG_LOCATIONS){ + QString root = configDir.filePath(configLocation); + QDirIterator it(root, {"Bookmarks"}, QDir::Files, QDirIterator::Subdirectories); + while (it.hasNext()) + files.insert(it.next()); + } + + // If paths changed update bookmarks + if (d->bookmarksFiles != files){ + d->bookmarksFiles = files; + d->startIndexing(); + } +} + + +/** ***************************************************************************/ +QWidget *Chromium::Extension::widget(QWidget *parent) { + if (d->widget.isNull()){ + d->widget = new QWidget(parent); + + Ui::ConfigWidget ui; + ui.setupUi(d->widget); + + // Fuzzy + ui.checkBox_fuzzy->setChecked(fuzzy()); + connect(ui.checkBox_fuzzy, &QCheckBox::toggled, this, &Extension::setFuzzy); + + // Status bar + ( d->futureWatcher.isRunning() ) + ? ui.label_statusbar->setText("Indexing bookmarks ...") + : ui.label_statusbar->setText(QString("%1 bookmarks indexed from %2.").arg(d->index.size()). + arg(QStringList::fromSet(d->bookmarksFiles).join(", "))); + connect(this, &Extension::statusInfo, ui.label_statusbar, &QLabel::setText); + } + return d->widget.data(); +} + + +/** ***************************************************************************/ +bool Chromium::Extension::fuzzy() { + return d->offlineIndex.fuzzy(); +} + + +/** ***************************************************************************/ +void Chromium::Extension::setFuzzy(bool b) { + settings().setValue(CFG_FUZZY, b); + d->offlineIndex.setFuzzy(b); +} + + +/** ***************************************************************************/ +void Chromium::Extension::handleQuery(Core::Query * query) const { + + const vector> &indexables = d->offlineIndex.search(query->string()); + + vector,uint>> results; + for (const shared_ptr &item : indexables) + results.emplace_back(std::static_pointer_cast(item), 0); + + query->addMatches(std::make_move_iterator(results.begin()), + std::make_move_iterator(results.end())); +} + diff --git a/plugins/chromebookmarks/src/extension.h b/plugins/chromium/src/extension.h similarity index 50% rename from plugins/chromebookmarks/src/extension.h rename to plugins/chromium/src/extension.h index 302f4c8..9d4a628 100644 --- a/plugins/chromebookmarks/src/extension.h +++ b/plugins/chromium/src/extension.h @@ -1,18 +1,18 @@ // Copyright (C) 2014-2018 Manuel Schneider #pragma once +#include #include #include #include "albert/extension.h" #include "albert/queryhandler.h" +Q_DECLARE_LOGGING_CATEGORY(qlc) -namespace ChromeBookmarks { +namespace Chromium { class Private; -class Extension final : - public Core::Extension, - public Core::QueryHandler +class Extension final : public Core::Extension, public Core::QueryHandler { Q_OBJECT Q_PLUGIN_METADATA(IID ALBERT_EXTENSION_IID FILE "metadata.json") @@ -22,26 +22,21 @@ class Extension final : Extension(); ~Extension(); - QString name() const override { return "Chrome bookmarks"; } - QWidget *widget(QWidget *parent = nullptr) override; - void handleQuery(Core::Query * query) const override; + QString name() const override { return "Chromium"; } + QWidget *widget(QWidget *parent) override; + void handleQuery(Core::Query *query) const override; - const QString &path(); - void setPath(const QString &path); - void restorePath(); + void updatePaths(); bool fuzzy(); void setFuzzy(bool b = true); - void updateIndex(); - private: std::unique_ptr d; signals: - void pathChanged(const QString&); void statusInfo(const QString&); }; diff --git a/plugins/debug/CMakeLists.txt b/plugins/debug/CMakeLists.txt index fb68dca..30c4d26 100644 --- a/plugins/debug/CMakeLists.txt +++ b/plugins/debug/CMakeLists.txt @@ -16,4 +16,4 @@ target_link_libraries(${PROJECT_NAME} albert::lib ) -install(TARGETS ${PROJECT_NAME} LIBRARY DESTINATION lib/albert/plugins) +install(TARGETS ${PROJECT_NAME} LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}/albert/plugins) diff --git a/plugins/debug/src/extension.cpp b/plugins/debug/src/extension.cpp index 0ffc0c2..e4c645b 100644 --- a/plugins/debug/src/extension.cpp +++ b/plugins/debug/src/extension.cpp @@ -15,7 +15,6 @@ // along with this program. If not, see . #include -#include #include #include #include @@ -24,6 +23,11 @@ #include "extension.h" #include "albert/query.h" #include "albert/util/standarditem.h" +Q_LOGGING_CATEGORY(qlc, "debug") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() using Core::StandardItem; @@ -67,7 +71,7 @@ Debug::Extension::~Extension() { QWidget *Debug::Extension::widget(QWidget *parent) { if (d->widget.isNull()) d->widget = new ConfigWidget(this, parent); - return d->widget; + return d->widget.data(); } @@ -101,11 +105,10 @@ void Debug::Extension::handleQuery(Core::Query * query) const { if (!query->isValid()) return; - auto item = std::make_shared(QString::number(i)); - item->setText(QString("Das Item #%1").arg(i)); - item->setSubtext(QString("Toll, das Item #%1").arg(i)); - item->setIconPath(":debug"); - query->addMatch(std::move(item)); + query->addMatch(makeStdItem(QString::number(i), + ":debug", + QString("Item #%1").arg(i), + QString("Wow, Item #%1").arg(i))); } } diff --git a/plugins/debug/src/extension.h b/plugins/debug/src/extension.h index 5466737..a55f32e 100644 --- a/plugins/debug/src/extension.h +++ b/plugins/debug/src/extension.h @@ -1,10 +1,12 @@ // Copyright (C) 2014-2018 Manuel Schneider #pragma once +#include #include #include #include "albert/extension.h" #include "albert/queryhandler.h" +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace Debug { diff --git a/plugins/files/README.md b/plugins/files/README.md new file mode 100644 index 0000000..eee6b05 --- /dev/null +++ b/plugins/files/README.md @@ -0,0 +1,64 @@ +The files extension offers ways to access files through Albert. + +One way to access files is to use the offline index. The extension indexes files that can be accessed by their filename. In the settings you can set paths the extension recursively scans for files. + +Further the files extension provides a way to browse through the file system using paths. This is handy to access files that are _not_ indexed. Queries beginning with either `/` or `~` are interpreted as a path. In combination with the tab completion this is a nice way to browse the file system. + +The offline index can be configured in several ways. It is recommended that you configure the extension depending on your needs. Simply indexing all files on your system may be convenient, but on one hand the vast amounts of files you'll never use will clutter the output and on the other hand a large file index may introduce performance penalties, like long indexing and lookup times and high memory usage. + +Generally you have to define where the extension should look for files. But you may not want to index all of the files in the directory tree below the paths you specified. You have now two options to exclude files from indexing: File filters and MIME type filters. + +## File filters / Ignore files + +An ignore file is a simple text file with the name `.albertignore` which specifies which files should be ignored. Each line in an ignore file specifies a pattern which serves as an exclusive filter. Patterns read from an ignore file in the same directory as the path, or in any parent directory, with patterns in the higher level files (up to the toplevel path to be indexed) being overridden by those in lower level files down to the directory containing the file. These patterns match relative to the location of the ignore file. + +### Pattern format + +A blank line matches no files, so it can serve as a separator for readability. + +A line starting with `#` serves as a comment. + +The prefix `!` negates the pattern; any matching file excluded by a previous pattern will become included again. It is not possible to re-include a file if a parent directory of that file is excluded. Put a backslash (`\`) in front of the first `!` for patterns that begin with a literal `!`. + +A leading slash `/` marks a relative pattern. This pattern is anchored relative to the directory the ignore file resides in. Without the leading slash a pattern is an absolute pattern and is inherited to sub directories. For example the pattern `/bar` matches the file `bar` but not `foo/bar`, while the pattern `bar` does. + +An asterisk `*` in a pattern matches against all characters but the directory separator `/`. Two consecutive asterisks `**` in a pattern match against all characters. More consecutive asterisks collapse to `**`. + +#### Example + +``` +# Ignore eclipse dir +/workspace + +# Ignore git projects +/git/* + +# Include albert repos though +!/git/albert +!/git/aur-albert + +# However in the albert repo dont index source files +/git/albert/**.cpp + +# General ignores +node_modules +bower_components +``` + +## MIME filters + +You also have fine-grained control over the MIME types that should be indexed. The Advanced button in the settings opens a dialog that lets you set a list of patterns that are used to match against the MIME types of the indexed files. The check boxes besides the button are shortcuts that let you add or remove the most popular patterns. + +As against the file filters the MIME filters are inclusive, files are only indexed if their MIME type match against one of the patterns. Unlike the file filters which reside in a file the MIME filters have global scope. + +The patterns support common [wildcard matching](http://doc.qt.io/qt-5/qregexp.html#wildcard-matching). + +#### Example + +``` +application/* +inode/directory +audio/* +video/* +text/x-python +``` diff --git a/plugins/files/src/extension.cpp b/plugins/files/src/extension.cpp index 12998b8..8d0c74d 100644 --- a/plugins/files/src/extension.cpp +++ b/plugins/files/src/extension.cpp @@ -1,6 +1,5 @@ // Copyright (C) 2014-2018 Manuel Schneider -#include #include #include #include @@ -25,6 +24,11 @@ #include "albert/util/standarditem.h" #include "albert/util/standardactions.h" #include "xdg/iconlookup.h" +Q_LOGGING_CATEGORY(qlc, "applications") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() using namespace Core; using namespace std; @@ -52,7 +56,7 @@ class OfflineIndexBuilderVisitor : public Files::Visitor { : offlineIndex(offlineIndex) { } void visit(Files::IndexTreeNode *node) override { - for ( const shared_ptr &item : node->items() ) + for ( const auto &item : node->items() ) offlineIndex.add(item); } }; @@ -123,7 +127,7 @@ void Files::Private::startIndexing() { indexIntervalTimer.start(); // Run the indexer thread - qInfo() << "Start indexing files."; + INFO << "Start indexing files."; futureWatcher->setFuture(QtConcurrent::run(this, &Private::indexFiles)); // Notification @@ -147,7 +151,7 @@ void Files::Private::finishIndexing() { CounterVisitor counterVisitor; for (const auto & tree : indexTrees ) tree->accept(counterVisitor); - qInfo() << qPrintable(QString("Indexed %1 files in %2 directories.") + INFO << qPrintable(QString("Indexed %1 files in %2 directories.") .arg(counterVisitor.itemCount).arg(counterVisitor.dirCount)); emit q->statusInfo(QString("Indexed %1 files in %2 directories.") .arg(counterVisitor.itemCount).arg(counterVisitor.dirCount)); @@ -199,7 +203,7 @@ OfflineIndex* Files::Private::indexFiles() { } // Serialize data - qDebug() << "Serializing files…"; + DEBG << "Serializing files…"; emit q->statusInfo("Serializing index data…"); QFile file(q->cacheLocation().filePath("fileindex.json")); if (file.open(QIODevice::WriteOnly)) { @@ -211,11 +215,11 @@ OfflineIndex* Files::Private::indexFiles() { file.close(); } else - qWarning() << "Couldn't write to file:" << file.fileName(); + WARN << "Couldn't write to file:" << file.fileName(); // Build offline index - qDebug() << "Building inverted file index…"; + DEBG << "Building inverted file index…"; emit q->statusInfo("Building inverted index…"); Core::OfflineIndex *offline = new Core::OfflineIndex(indexSettings.fuzzy()); OfflineIndexBuilderVisitor visitor(*offline); @@ -255,7 +259,7 @@ Files::Extension::Extension() }); // Deserialize data - qDebug() << "Loading file index from cache."; + DEBG << "Loading file index from cache."; QFile file(cacheLocation().filePath("fileindex.json")); if ( file.exists() ) { if (file.open(QIODevice::ReadOnly)) { @@ -267,13 +271,13 @@ Files::Extension::Extension() file.close(); // Build offline index - qDebug() << "Building inverted file index."; + DEBG << "Building inverted file index."; OfflineIndexBuilderVisitor visitor(d->offlineIndex); for (auto& tree : d->indexTrees) tree->accept(visitor); } else - qWarning() << "Could not read from file: " << file.fileName(); + WARN << "Could not read from file: " << file.fileName(); } // Trigger an initial update @@ -324,7 +328,7 @@ void Files::Extension::handleQuery(Core::Query * query) const { QDir dir(pathInfo.filePath()); QString commonPrefix; QString queryFileName = queryFileInfo.fileName(); - vector> items; + vector,uint>> results; for (const QFileInfo& fileInfo : dir.entryInfoList(QDir::AllEntries|QDir::Hidden|QDir::NoDotAndDotDot, QDir::DirsFirst|QDir::Name|QDir::IgnoreCase) ) { @@ -347,18 +351,23 @@ void Files::Extension::handleQuery(Core::Query * query) const { if (icon.isEmpty()) icon = (mimetype.iconName() == "inode-directory") ? ":directory" : ":unknown"; - auto item = make_shared(fileInfo.filePath(), - icon, - fileName, - fileInfo.filePath()); - item->setActions(File::buildFileActions(fileInfo.filePath())); - items.push_back(move(item)); + results.emplace_back(makeStdItem( + fileInfo.filePath(), + icon, + fileName, + fileInfo.filePath(), + File::buildFileActions(fileInfo.filePath()), + fileInfo.filePath() + ), 0); } } - for (auto &item : items) { - item->setCompletion(dir.filePath(commonPrefix)); - query->addMatch(std::move(item)); - } + + if (!commonPrefix.isEmpty()) + for (auto &item : results) + item.first->setCompletion(dir.filePath(commonPrefix)); + + query->addMatches(make_move_iterator(results.begin()), + make_move_iterator(results.end())); } } else @@ -368,15 +377,13 @@ void Files::Extension::handleQuery(Core::Query * query) const { if ( QString("albert scan files").startsWith(query->string()) ) { - auto item = make_shared("files.action.index"); - item->setText("albert scan files"); - item->setSubtext("Update the file index"); - item->setIconPath(":app_icon"); - // Const cast is fine since the action will not be called here - item->addAction(make_shared("Update the file index", - [this](){ const_cast(this)->updateIndex();})); - - query->addMatch(move(item)); + query->addMatch(makeStdItem("files.action.index", + "app_icon", "albert scan files", "Update the file index", //Const cast is fine since the action will not be called here + ActionList { makeFuncAction( + "Update the file index", + [this](){ const_cast(this)->updateIndex();})} + ) + ); } // Search for matches @@ -417,17 +424,17 @@ void Files::Extension::setPaths(const QStringList &paths) { QString absPath = fileInfo.absoluteFilePath(); if (d->indexRootDirs.contains(absPath)) { - qWarning() << QString("Duplicate paths: %1.").arg(path); + WARN << QString("Duplicate paths: %1.").arg(path); continue; } if (!fileInfo.exists()) { - qWarning() << QString("Path does not exist: %1.").arg(path); + WARN << QString("Path does not exist: %1.").arg(path); continue; } if(!fileInfo.isDir()) { - qWarning() << QString("Path is not a directory: %1.").arg(path); + WARN << QString("Path is not a directory: %1.").arg(path); continue; } diff --git a/plugins/files/src/extension.h b/plugins/files/src/extension.h index 6b0866d..5f5a32c 100644 --- a/plugins/files/src/extension.h +++ b/plugins/files/src/extension.h @@ -1,10 +1,12 @@ // Copyright (C) 2014-2018 Manuel Schneider #pragma once +#include #include #include #include "albert/extension.h" #include "albert/queryhandler.h" +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace Files { @@ -16,7 +18,6 @@ class Extension final : { Q_OBJECT Q_PLUGIN_METADATA(IID ALBERT_EXTENSION_IID FILE "metadata.json") - Q_PROPERTY(QStringList paths READ paths WRITE setPaths NOTIFY pathsChanged) public: diff --git a/plugins/files/src/file.cpp b/plugins/files/src/file.cpp index a6b61ba..49b41f5 100644 --- a/plugins/files/src/file.cpp +++ b/plugins/files/src/file.cpp @@ -1,6 +1,5 @@ // Copyright (C) 2014-2018 Manuel Schneider -#include "file.h" #include #include #include @@ -9,11 +8,11 @@ #include #include #include -#include "xdg/iconlookup.h" #include "albert/util/standardactions.h" +#include "file.h" +#include "xdg/iconlookup.h" using namespace std; using namespace Core; -extern QString terminalCommand; /** ***************************************************************************/ @@ -38,7 +37,7 @@ QString Files::File::subtext() const { QString Files::File::completion() const { const QString &path = filePath(); QString result = ( QFileInfo(path).isDir() ) ? QString("%1/").arg(path) : path; -#ifdef __linux__ +#ifdef __unix__ if ( result.startsWith(QDir::homePath()) ) result.replace(QDir::homePath(), "~"); #endif @@ -67,27 +66,24 @@ std::vector > Files::File::buildFileActions(const QStrin { vector> actions; - actions.push_back(make_shared("Open with default application", - QUrl::fromLocalFile(filePath))); + actions.push_back(makeUrlAction("Open with default application", + QUrl::fromLocalFile(filePath))); QFileInfo fileInfo(filePath); + if ( fileInfo.isFile() && fileInfo.isExecutable() ) - actions.push_back(make_shared("Execute file", QStringList{filePath})); + actions.push_back(makeProcAction("Execute file", QStringList{filePath})); - actions.push_back(make_shared("Reveal in file browser", - QUrl::fromLocalFile(QFileInfo(filePath).path()))); + actions.push_back(makeUrlAction("Reveal in file browser", + QUrl::fromLocalFile(fileInfo.path()))); + // Let standard shell handle flow control (syntax differs in shells, e.g. fish) + actions.push_back(makeTermAction("Open terminal here", "", TermAction::DoNotClose, + fileInfo.isDir() ? fileInfo.filePath() : fileInfo.path())); - actions.push_back(make_shared("Open terminal at this path", [filePath](){ - QFileInfo fileInfo(filePath); - QStringList commandLine = terminalCommand.trimmed().split(' '); - if ( commandLine.size() == 0 ) - return; - QProcess::startDetached(commandLine[0], {}, fileInfo.isDir() ? fileInfo.filePath() : fileInfo.path()); - })); + actions.push_back(makeFuncAction("Copy file to clipboard", [filePath](){ - actions.push_back(make_shared("Copy file to clipboard", [filePath](){ // Get clipboard QClipboard *cb = QApplication::clipboard(); @@ -113,7 +109,7 @@ std::vector > Files::File::buildFileActions(const QStrin cb->setMimeData(newMimeData); })); - actions.push_back(make_shared("Copy path to clipboard", filePath)); + actions.push_back(makeClipAction("Copy path to clipboard", filePath)); return actions; diff --git a/plugins/files/src/mimetypedialog.ui b/plugins/files/src/mimetypedialog.ui index 19d9e1d..49ae3ef 100644 --- a/plugins/files/src/mimetypedialog.ui +++ b/plugins/files/src/mimetypedialog.ui @@ -30,7 +30,7 @@ <html><head/><body><p style=" color:#808080;"> -Choose the MIME types you want to be indexed by the files extension. The left box contains the known MIME types. Use it to find your desired MIME types. The right box contains the list of patterns that is used to filter the indexed files by matching their MIME type. The patterns support wildcard matching. Check the <a href="https://albertlauncher.github.io/docs/extensions/files/#mime-filters">docs</a> for more details and examples. +Choose the MIME types you want to be indexed by the files extension. The left box contains the known MIME types. Use it to find your desired MIME types. The right box contains the list of patterns that is used to filter the indexed files by matching their MIME type. The patterns support wildcard matching. Check the docs for more details and examples. </p></body></html> diff --git a/plugins/firefoxbookmarks/metadata.json b/plugins/firefoxbookmarks/metadata.json index e12540e..4d3f573 100644 --- a/plugins/firefoxbookmarks/metadata.json +++ b/plugins/firefoxbookmarks/metadata.json @@ -1,7 +1,7 @@ { "id" : "org.albert.extension.firefoxbookmarks", "name" : "Firefox bookmarks", - "version" : "1.0", + "version" : "2.0", "platform" : "All", "group" : "Extensions", "author" : "Martin Buergmann, Manuel Schneider", diff --git a/plugins/firefoxbookmarks/src/configwidget.ui b/plugins/firefoxbookmarks/src/configwidget.ui index d85c310..10fd845 100644 --- a/plugins/firefoxbookmarks/src/configwidget.ui +++ b/plugins/firefoxbookmarks/src/configwidget.ui @@ -11,6 +11,33 @@ + + + + <html><head/><body><p>This setting can be changed in the config file.</p></body></html> + + + Detected Firefox executable: + + + + + + + <html><head/><body><p>This setting can be changed in the config file.</p></body></html> + + + profiles.ini Path: + + + + + + + Qt::Horizontal + + + @@ -55,11 +82,34 @@ - - - - - + + + + + + 0 + 0 + + + + + + + + + + + + 0 + 0 + + + + Start Scan + + + + diff --git a/plugins/firefoxbookmarks/src/extension.cpp b/plugins/firefoxbookmarks/src/extension.cpp index ab799b5..30bd93d 100644 --- a/plugins/firefoxbookmarks/src/extension.cpp +++ b/plugins/firefoxbookmarks/src/extension.cpp @@ -1,12 +1,9 @@ -// Copyright (C) 2014-2018 Manuel Schneider - +// Copyright (C) 2014-2020 Manuel Schneider #include #include #include -#include #include -#include #include #include #include @@ -15,27 +12,38 @@ #include #include #include +#include #include #include #include #include #include #include +#include #include #include +#include #include #include -#include "extension.h" -#include "configwidget.h" +#include #include "albert/extension.h" #include "albert/util/offlineindex.h" -#include "albert/util/standardindexitem.h" #include "albert/util/standardactions.h" +#include "albert/util/standardindexitem.h" +#include "configwidget.h" +#include "extension.h" #include "xdg/iconlookup.h" +Q_LOGGING_CATEGORY(qlc, "firefox") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() using namespace std; using namespace Core; namespace { +const QString CFG_FIREFOX_HOME = "profilesIniPath"; +const QString CFG_FIREFOX_EXE = "firefoxPath"; const QString CFG_PROFILE = "profile"; const QString CFG_FUZZY = "fuzzy"; const bool DEF_FUZZY = false; @@ -92,7 +100,7 @@ void FirefoxBookmarks::Private::startIndexing() { futureWatcher.setFuture(QtConcurrent::run(this, &Private::indexFirefoxBookmarks)); // Notification - qInfo() << "Start indexing Firefox bookmarks."; + INFO << "Start indexing Firefox bookmarks."; emit q->statusInfo("Indexing bookmarks ..."); } @@ -100,8 +108,13 @@ void FirefoxBookmarks::Private::startIndexing() { /** ***************************************************************************/ void FirefoxBookmarks::Private::finishIndexing() { + auto result = futureWatcher.future().result(); + + if ( result.empty() ) + return; + // Get the thread results - index = futureWatcher.future().result(); + index = std::move(result); // Rebuild the offline index offlineIndex.clear(); @@ -109,7 +122,7 @@ void FirefoxBookmarks::Private::finishIndexing() { offlineIndex.add(item); // Notification - qInfo() << qPrintable(QString("Indexed %1 Firefox bookmarks.").arg(index.size())); + INFO << qPrintable(QString("Indexed %1 Firefox bookmarks.").arg(index.size())); emit q->statusInfo(QString("%1 bookmarks indexed.").arg(index.size())); } @@ -122,11 +135,51 @@ FirefoxBookmarks::Private::indexFirefoxBookmarks() const { vector> bookmarks; { + QTemporaryFile dbcopy; + dbcopy.setAutoRemove(true); + if (!dbcopy.open()) { + WARN << qPrintable(QString("Could not open temporary file: %1").arg(dbcopy.errorString())); + return vector>(); + } + + QFile places(dbPath); + if (!places.open(QIODevice::ReadOnly)) { + WARN << qPrintable(QString("Could not open places.sqlite file: %1").arg(dbcopy.errorString())); + return vector>(); + } + + bool sendfile_worked = false; + { + int source = places.handle(); + int destination = dbcopy.handle(); + if (sendfile(destination, source, nullptr, places.size()) != -1) { + sendfile_worked = true; + } else { + DEBG << "sendfile did not work, falling back to userland buffer"; + } + } + + if (!sendfile_worked) { + char buf[512]; + int read; + do { + read = places.read(buf, 512); + if (read == -1) { + WARN << qPrintable(QString("Could not copy places.sqlite file: read failed: %1").arg(places.errorString())); + return vector>(); + } + if (dbcopy.write(buf, read) == -1) { + WARN << qPrintable(QString("Could not copy places.sqlite file: write failed: %1").arg(dbcopy.errorString())); + return vector>(); + } + } while (read > 0); + } + QSqlDatabase database = QSqlDatabase::addDatabase("QSQLITE", q->Core::Plugin::id());; - database.setDatabaseName(dbPath); + database.setDatabaseName(dbcopy.fileName()); if (!database.open()) { - qWarning() << qPrintable(QString("Could not open Firefox database: %1").arg(database.databaseName())); + WARN << qPrintable(QString("Could not open Firefox database: %1").arg(database.databaseName())); return vector>(); } @@ -137,7 +190,7 @@ FirefoxBookmarks::Private::indexFirefoxBookmarks() const { "JOIN moz_bookmarks parents ON bookmarks.parent = parents.id AND parents.parent <> 4 " "JOIN moz_places places ON bookmarks.fk = places.id " "WHERE NOT hidden") ) { // Those with place:... will not work with xdg-open - qWarning() << qPrintable(QString("Querying Firefox bookmarks failed: %1").arg(result.lastError().text())); + WARN << qPrintable(QString("Querying Firefox bookmarks failed: %1").arg(result.lastError().text())); return vector>(); } @@ -150,31 +203,27 @@ FirefoxBookmarks::Private::indexFirefoxBookmarks() const { // Url will be used more often QString urlstr = result.value(2).toString(); - // Create item - shared_ptr item = make_shared(result.value(0).toString()); - item->setText(result.value(1).toString()); - item->setSubtext(urlstr); - item->setIconPath(icon); + // Add actions + ActionList actions; + actions.push_back(makeProcAction("Open URL in Firefox", + QStringList({firefoxExecutable, urlstr}))); + actions.push_back(makeProcAction("Open URL in new Firefox window", + QStringList({firefoxExecutable, "--new-window", urlstr}))); + actions.insert(openWithFirefox ? actions.end() : actions.begin(), + makeUrlAction("Open URL in your default browser", urlstr)); + actions.push_back(makeClipAction("Copy url to clipboard", urlstr)); - // Add severeal secondary index keywords - vector indexStrings; + // Create item QUrl url(urlstr); QString host = url.host(); - indexStrings.emplace_back(item->text(), UINT_MAX); - indexStrings.emplace_back(host.left(host.size()-url.topLevelDomain().size()), UINT_MAX/2); - indexStrings.emplace_back(result.value(2).toString(), UINT_MAX/4); // parent dirname - item->setIndexKeywords(move(indexStrings)); - - // Add actions - vector> actions; - actions.push_back(make_shared("Open URL in Firefox", - QStringList({firefoxExecutable, urlstr}))); - actions.push_back(make_shared("Open URL in new Firefox window", - QStringList({firefoxExecutable, "--new-window", urlstr}))); - actions.insert(openWithFirefox ? actions.end() : actions.begin(), - make_shared("Open URL in your default browser", urlstr)); - actions.push_back(make_shared("Copy url to clipboard", urlstr)); - item->setActions(move(actions)); + shared_ptr item = makeStdIdxItem(result.value(0).toString(), + icon, result.value(1).toString(), urlstr, + IdxStrList { + {result.value(1).toString(), UINT_MAX}, + {host.left(host.size()-url.topLevelDomain().size()), UINT_MAX/2}, + {result.value(2).toString(), UINT_MAX/4}, + }, + actions); bookmarks.push_back(move(item)); } @@ -211,20 +260,28 @@ FirefoxBookmarks::Extension::Extension() QSqlDatabase::removeDatabase(Core::Plugin::id()); // Find firefox executable - d->firefoxExecutable = QStandardPaths::findExecutable("firefox"); + d->firefoxExecutable = settings().value(CFG_FIREFOX_EXE, "").toString(); + if (d->firefoxExecutable.isEmpty()) { + d->firefoxExecutable = QStandardPaths::findExecutable("firefox"); + } if (d->firefoxExecutable.isEmpty()) throw "Firefox executable not found."; + settings().setValue(CFG_FIREFOX_EXE, d->firefoxExecutable); // Locate profiles ini - d->profilesIniPath = QStandardPaths::locate(QStandardPaths::HomeLocation, - ".mozilla/firefox/profiles.ini", - QStandardPaths::LocateFile); - if (d->profilesIniPath.isEmpty()) // Try a windowsy approach - d->profilesIniPath = QStandardPaths::locate(QStandardPaths::DataLocation, - "Mozilla/firefox/profiles.ini", + d->profilesIniPath = settings().value(CFG_FIREFOX_HOME, "").toString(); + if (d->profilesIniPath.isEmpty()) { + d->profilesIniPath = QStandardPaths::locate(QStandardPaths::HomeLocation, + ".mozilla/firefox/profiles.ini", QStandardPaths::LocateFile); + if (d->profilesIniPath.isEmpty()) // Try a windowsy approach + d->profilesIniPath = QStandardPaths::locate(QStandardPaths::DataLocation, + "Mozilla/firefox/profiles.ini", + QStandardPaths::LocateFile); + } if (d->profilesIniPath.isEmpty()) throw "Could not locate profiles.ini."; + settings().setValue(CFG_FIREFOX_HOME, d->profilesIniPath); // Load the settings d->currentProfileId = settings().value(CFG_PROFILE).toString(); @@ -233,21 +290,23 @@ FirefoxBookmarks::Extension::Extension() // If the id does not exist find a proper default QSettings profilesIni(d->profilesIniPath, QSettings::IniFormat); - if ( !profilesIni.contains(d->currentProfileId) ){ + QString pathkey = QString("%1/Path").arg(d->currentProfileId); + if ( !profilesIni.contains(pathkey) ){ d->currentProfileId = QString(); QStringList ids = profilesIni.childGroups(); if ( ids.isEmpty() ) - qWarning() << "No Firefox profiles found."; + WARN << "No Firefox profiles found."; else { // Use the last used profile if ( d->currentProfileId.isNull() ) { for (QString &id : ids) { profilesIni.beginGroup(id); - if ( profilesIni.contains("Default") - && profilesIni.value("Default").toBool() ) { + if ( profilesIni.contains("Path") + && profilesIni.contains("Default") + && profilesIni.value("Default").toInt() > 0 ) { d->currentProfileId = id; } profilesIni.endGroup(); @@ -259,8 +318,10 @@ FirefoxBookmarks::Extension::Extension() d->currentProfileId = "default"; } - // Use the first - d->currentProfileId = ids[0]; + if ( d->currentProfileId.isNull() ) { + // Use the first + d->currentProfileId = ids[0]; + } } } @@ -308,7 +369,7 @@ QWidget *FirefoxBookmarks::Extension::widget(QWidget *parent) { cmb->addItem( QString("%1 (%2)").arg(profilesIni.value("Name").toString(), profileId), profileId); else { cmb->addItem(profileId, profileId); - qWarning() << qPrintable(QString("Firefox profile '%1' does not contain a name.").arg(profileId)); + WARN << qPrintable(QString("Firefox profile '%1' does not contain a name.").arg(profileId)); } // If the profileId match set the current item of the checkbox @@ -318,8 +379,14 @@ QWidget *FirefoxBookmarks::Extension::widget(QWidget *parent) { profilesIni.endGroup(); } - connect(cmb, static_cast(&QComboBox::currentIndexChanged), - this, &Extension::setProfile); + connect(cmb, static_cast(&QComboBox::currentIndexChanged), + this, static_cast(&Extension::setProfile)); + + // profiles.ini Path Label + d->widget->ui.label_profiles->setText("profiles.ini Path: " + d->profilesIniPath); + + // discovered ff executable + d->widget->ui.label_exe->setText("Detected Firefox executable: " + d->firefoxExecutable); // Fuzzy QCheckBox *ckb = d->widget->ui.fuzzy; @@ -337,6 +404,10 @@ QWidget *FirefoxBookmarks::Extension::widget(QWidget *parent) { : d->widget->ui.label_statusbar->setText(QString("%1 bookmarks indexed.").arg(d->index.size())); connect(this, &Extension::statusInfo, d->widget->ui.label_statusbar, &QLabel::setText); + // Rescan button + QPushButton *btn = d->widget->ui.pushButton_update; + connect(btn, &QPushButton::clicked, bind(&Private::startIndexing, d.get())); + } return d->widget; } @@ -359,15 +430,24 @@ void FirefoxBookmarks::Extension::handleQuery(Core::Query *query) const { /** ***************************************************************************/ -void FirefoxBookmarks::Extension::setProfile(const QString& profile) { +void FirefoxBookmarks::Extension::setProfile(int index) { + + QComboBox *cmb = d->widget->ui.comboBox; + QVariant profileId = cmb->itemData(index); + setProfile(profileId.toString()); +} + + +/** ***************************************************************************/ +void FirefoxBookmarks::Extension::setProfile(const QString& profile) { d->currentProfileId = profile; QSettings profilesIni(d->profilesIniPath, QSettings::IniFormat); // Check if profile id is in profiles file if ( !profilesIni.childGroups().contains(d->currentProfileId) ){ - qWarning() << qPrintable(QString("Firefox user profile '%2' not found.").arg(d->currentProfileId)); + WARN << qPrintable(QString("Firefox user profile '%2' not found.").arg(d->currentProfileId)); return; } @@ -376,7 +456,7 @@ void FirefoxBookmarks::Extension::setProfile(const QString& profile) { // Check if the profile contains a path key if ( !profilesIni.contains("Path") ){ - qWarning() << qPrintable(QString("Firefox profile '%2' does not contain a path.").arg(d->currentProfileId)); + WARN << qPrintable(QString("Firefox profile '%2' does not contain a path.").arg(d->currentProfileId)); return; } diff --git a/plugins/firefoxbookmarks/src/extension.h b/plugins/firefoxbookmarks/src/extension.h index 12db4b2..da3cf8a 100644 --- a/plugins/firefoxbookmarks/src/extension.h +++ b/plugins/firefoxbookmarks/src/extension.h @@ -1,10 +1,12 @@ // Copyright (C) 2014-2018 Manuel Schneider #pragma once +#include #include #include "albert/extension.h" #include "albert/queryhandler.h" #include +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace FirefoxBookmarks { @@ -26,7 +28,8 @@ class Extension final : QWidget *widget(QWidget *parent = nullptr) override; void handleQuery(Core::Query * query) const override; - void setProfile(const QString &profile); + void setProfile(int); + void setProfile(const QString&); void changeFuzzyness(bool fuzzy); void changeOpenPolicy(bool withFirefox); diff --git a/plugins/hashgenerator/src/extension.cpp b/plugins/hashgenerator/src/extension.cpp index e55feb8..2d5aca4 100644 --- a/plugins/hashgenerator/src/extension.cpp +++ b/plugins/hashgenerator/src/extension.cpp @@ -9,6 +9,11 @@ #include "albert/util/standardactions.h" #include "albert/util/standarditem.h" #include "extension.h" +Q_LOGGING_CATEGORY(qlc, "hashgen") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() using namespace std; using namespace Core; @@ -91,14 +96,12 @@ void HashGenerator::Extension::handleQuery(Core::Query * query) const { hash.addData(string.toUtf8()); QByteArray hashString = hash.result().toHex(); - auto item = make_shared(algorithmNames[algorithm]); - item->setText(QString("%1 of '%2'").arg(algorithmNames[algorithm], string)); - item->setSubtext(hashString); - item->setIconPath(":hash"); - item->setCompletion(QString("%1 %2").arg(algorithmNames[algorithm].toLower(), string)); - item->addAction(make_shared("Copy hash value to clipboard", - QString(hashString))); - return item; + return makeStdItem(algorithmNames[algorithm], + ":hash", + QString("%1 of '%2'").arg(algorithmNames[algorithm], string), + hashString, + ActionList { makeClipAction("Copy hash value to clipboard", QString(hashString)) }, + QString("%1 %2").arg(algorithmNames[algorithm].toLower(), string)); }; if ( query->trigger() == "hash " ) { diff --git a/plugins/hashgenerator/src/extension.h b/plugins/hashgenerator/src/extension.h index 7b6f78a..23b5e75 100644 --- a/plugins/hashgenerator/src/extension.h +++ b/plugins/hashgenerator/src/extension.h @@ -1,10 +1,12 @@ // Copyright (C) 2014-2018 Manuel Schneider #pragma once +#include #include #include #include "albert/extension.h" #include "albert/queryhandler.h" +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace HashGenerator { diff --git a/plugins/mpris/README.md b/plugins/mpris/README.md new file mode 100644 index 0000000..0cb6096 --- /dev/null +++ b/plugins/mpris/README.md @@ -0,0 +1,18 @@ +**Note**: This extension depends on the [Qt D-Bus](http://doc.qt.io/qt-5/qtdbus-index.html) module. + +This extension is for linux only. It lets you control running MPRIS-capable media players like Rhythmbox or VLC. +MPRIS (Media Player Remote Interfacing Specification) is a protocol that enables media players to be controlled via DBus. +Currently this extension supports the following commands: +- Play +- Pause +- Next +- Previous +- Stop + +Just enter the action you want to perform (like "play" to start playback) and there will be an entry for every player that is running and the action is applicable. +I.e. when you have only one player running and it's already playing, the Play-entry will not occure. +Or; when you have two players running and one is playing, "next" will yield two entries. One for each player. + +If the media player supports the Raise method it can also be brought to front with albert. +This may or may not work as well depending on the implementation of the Raise method within the media player. +**But** there is no seperate entry to raise the player, this is an alternative action attached to all MPRIS-entries. diff --git a/plugins/mpris/src/extension.cpp b/plugins/mpris/src/extension.cpp index 5171e22..04e930f 100644 --- a/plugins/mpris/src/extension.cpp +++ b/plugins/mpris/src/extension.cpp @@ -1,19 +1,22 @@ // Copyright (C) 2016-2017 Martin Buergmann -#include "extension.h" #include #include #include -#include #include #include #include #include "albert/query.h" -#include "xdg/iconlookup.h" #include "command.h" #include "configwidget.h" +#include "extension.h" #include "player.h" - +#include "xdg/iconlookup.h" +Q_LOGGING_CATEGORY(qlc, "mpris") +#define DEBG qCDebug(qlc,).noquote() +#define INFO qCInfo(qlc,).noquote() +#define WARN qCWarning(qlc,).noquote() +#define CRIT qCCritical(qlc,).noquote() #define themeOr(name, fallbk) XDG::IconLookup::iconPath(name).isEmpty() ? fallbk : XDG::IconLookup::iconPath(name) namespace { diff --git a/plugins/mpris/src/extension.h b/plugins/mpris/src/extension.h index 2697864..96ebbe9 100644 --- a/plugins/mpris/src/extension.h +++ b/plugins/mpris/src/extension.h @@ -1,10 +1,12 @@ // Copyright (C) 2016-2017 Martin Buergmann #pragma once +#include #include #include #include "albert/extension.h" #include "albert/queryhandler.h" +Q_DECLARE_LOGGING_CATEGORY(qlc) namespace MPRIS { diff --git a/plugins/mpris/src/item.cpp b/plugins/mpris/src/item.cpp index a81d93a..ac8ee5e 100644 --- a/plugins/mpris/src/item.cpp +++ b/plugins/mpris/src/item.cpp @@ -16,9 +16,9 @@ MPRIS::Item::Item(Player &p, const QString &title, const QString &subtext, const subtext_ = subtext.arg(p.name()); else subtext_ = subtext; - actions_.push_back(std::make_shared(subtext_, [this](){ QDBusConnection::sessionBus().send(message_); })); + actions_.push_back(makeFuncAction(subtext_, [this](){ QDBusConnection::sessionBus().send(message_); })); if (p.canRaise()) { - actions_.push_back(std::make_shared("Raise Window", [&p](){ + actions_.push_back(makeFuncAction("Raise Window", [&p](){ QString busid = p.busId(); QDBusMessage raise = QDBusMessage::createMethodCall(busid, "/org/mpris/MediaPlayer2", "org.mpris.MediaPlayer2", "Raise"); if (!QDBusConnection::sessionBus().send(raise)) { diff --git a/plugins/python/README.md b/plugins/python/README.md new file mode 100644 index 0000000..624d9d0 --- /dev/null +++ b/plugins/python/README.md @@ -0,0 +1,204 @@ +# Python + +The Python extension makes the application extendable by embedding Python modules. Since the name of the native extension providing this functionality is *Python extension* and a Python module in this context is called *Python extension* too, this article refers to the Python extensions by using the term *Python modules*. + +In the settings of the Python extension you can find a list of installed Python extensions. This list with checkboxes works similar to the list of native extensions. Check the box of a Python module to automatically load it when the Python extension gets initialized. The icon represents the loading status. Dash means unloaded, the green checkmark stands for a successfully loaded module and a red cross indicates an error while loading the extension. In this case you can hover over the item to check its tooltip. There you find any error messages. You can also run Albert from terminal to check for error output. + +## Known issues + +The Python interpreter shuts down when the Python extension is unloaded. After this, enabling the extension will restart the interpreter. Some modules cannot be re-initialized safely and may cause segfaults after the interpreter has been restarted (numpy!). The issue is that Python itself cannot completely unload extension modules and there are several caveats with regard to interpreter restarting. In short, not all memory may be freed, either due to Python reference cycles or user-created global data. All the details can be found in the CPython documentation. + +## Development + +How the Python extension interacts with Python modules is defined in the versioned interface specifications. Devs interested in writing extensions should check the interface specification below. Note that interfaces may brake any time as long as albert is still in alpha stage (v0.*). + +## Deployment + +The extension checks its data directories for a directory called `modules`. The name of a data directory is the id of the extension. In the case of the Python extension this is `org.albert.extension.python`. The data directories reside in the data directories of the application defined by [Qt](http://doc.qt.io/qt-5/qstandardpaths.html#StandardLocation-enum). Hence on linux the modules would be looked up in the following directories (in this order): + +``` +~/.local/share/albert/org.albert.extension.python/modules +/usr/local/share/albert/org.albert.extension.python/modules +/usr/share/albert/org.albert.extension.python/modules +``` + +Ids are guaranteed to be unique. This means that if several of those paths contain a plugins with identical ids, the first plugin found will be used. + +## Getting started (on Linux) + +This example should get you started developing a Python module to extend the functionality of Albert. For more extension examples, see the [albert Python extensions repository](https://github.com/albertlauncher/python). + +1. Duplicate the folder `~/.local/share/albert/org.albert.extension.python/modules/api-test` +1. Rename the module but stay consistent with the conventions. +1. Open Albert settings and navigate to Extensions > Python +1. If your module is not listed, reload the Python extension or restart Albert +1. Enable your module (Check the checkbox) next to your extension +1. Create your extension. The Python extension reloads modules on file changes. + +Before you code check the Pull Requests. Maybe somebody had your idea already. Finally dont hesitate to share your extension! + +## The Python interface specification (v0.4) + +To work as an albert extension Python modules have to have a particular interface described below. The Python extension also defines an embedded module `albert` which allows the Python modules to interact with the core. The interface specification and the built-in albert module are versioned together and form the versioned Python interface. The Python interface is _not_ final. They are prototypes and intended to be improved on user feedback. + +### The Python module interface specification + +This is the metadata albert reads from your module **before** loading it: + +Variable | Description +--- | --- +`__doc__` | **Optional** _[string]_. The docstring of the module is used as description of the extension. This string will be displayed to the user. +`__title__` | _**MANDATORY** [string]_. This variable should hold the pretty name of the extension. This string will be displayed to the user. +`__version__` | _**MANDATORY** [string]_. The versioning scheme should be `[iid_major].[iid_minor].[verion]`. The interface id (`iid_*`) should match the pyton interface version. `version` is the extensions version.

**Note** that within each `iid_maj` the API is backwards compatible, but as long as albert is in alpha stage `iid_major` will be `0` and API may brake any time. +`__triggers__` | **Optional** _[string, list of strings]_. If this extension should be run exclusively, this variable has to hold the trigger that causes the extension to be executed. +`__authors__` | **Optional** _[string, list of strings]_. This variable should hold the name of the author of the extension. +`__exec_deps__`| **Optional** _[string, list of strings]_. This string should contain any dependencies the extension needs to be used. The name of the dependency has to match the name of the executable in $PATH. +`__py_deps__` | **Optional** _[string, list of strings]_. This string should contain any dependencies the extension needs to be used. The name of the dependency has to match the name of the package in the PyPI. + +These are the functions an albert extension must/may have: + +Function | Description +--- | --- +`handleQuery(Query)` | ***MANDATORY***. This is the crucial part of a Python module. When the user types a query, this function is called with a query object representing the current query execution. This function should return a list of Item objects. See the Item class section below. +`initialize()` | **Optional**. This function is called when the extension is loaded. Although you could technically run your initialization code in global scope, it is recommended to initialize your extension in this function. If your extension fails to initialize you can raise exceptions here, which are displayed to the user. +`finalize()` | **Optional**. This function is called when the extension is unloaded. + +### The built-in `albert` module + +The built-in albert module exposes several functions and classes for use with Albert. + +#### Functions + +Function | Description +--- | --- +`debug(obj)`
`info(obj)`
`warning(obj)`
`critical(obj)`|Log a message to stdout. Note that `debug` is effectively a NOP in release builds. Puts the passed object into `str()` for convenience. The messages are logged using the QLoggingCategory of the python extension and therefore are subject to filter rules. +`iconLookup(iconName:str)`|Perform xdg icon lookup and return a path. Empty if nothing found. +`iconLookup(iconName:list)`|Same as above. With multiple candidate names. +`cacheLocation()`|Returns the writable cache location of the app. (E.g. $HOME/.cache/albert/ on Linux) +`configLocation()`|Returns the writable config location of the app. (E.g. $HOME/.config/albert/ on Linux) +`dataLocation()`|Returns the writable data location of the app. (E.g. $HOME/.local/share/albert/ on Linux) + +#### The `Query` class + +The query class represents a query execution. It holds the necessary information to handle a Query. It is passed to the handleQuery function. It holds the following read-only properties. + +Attribute | Description +--- | --- +`string`|This is the actual query string without the trigger. If the query is not triggered this string equals rawstring. +`rawString`|This is the full query string including the trigger. If the query is not triggered this string equals string. +`trigger`|This is the trigger that has been used to start this extension. +`isTriggered`|Indicates that this query has been triggered. +`isValid`|This flag indicates if the query is valid. A query is valid untill the query manager cancels it. You should regularly check this flag and abort the query handling if the flag is `False` to release threads in the threadpool for the next query. +`disableSort()`|Indicates that this query has been triggered. + +#### The `Item` class + +The base class for all items is `ItemBase`. This is a wrapper for the internal Item interface. You should not need this unless you need the `Urgency` enum. The `Urgency` enum is defined in the `ItemBase` namespace and has the following enum members: `Alert`, `Notification` and `Normal`. The `Item` class represents a result item. Objects of this class are intended to be returned by the handleQuery function. The signature of the constructor is as follows: + +```python +Item(id="", + icon=":python_module", + text="", + subtext="", + actions=[], + completion=None:str, + urgency=Urgency.Normal) +``` + +Note that the default icon path is `:python_module` which is an embedded resource icon depicting a Python script and the urgency defaults to normal. + +Attribute | Description +--- | --- +`id`|The identifier string of the item. It is used for ranking algorithms and should not be empty. +`icon`|The path of the icon displayed in the item. +`text`|The primary text of the item. +`actions`|The actions of the item. See [action classes](#action-classes). +`subtext`|The secondary text of the item. This text should have informative character. +`completion`|The completion string of the item. This string will be used to replace the input line when the user hits the Tab key on an item. Note that the semantics may vary depending on the context. +`urgency`|The urgency of the item. Note that the Urgency enum is defined in the ItemBase class. See the Urgency enum. +`addAction(Action)`|Add an action to the item. + +#### Action classes + +The base class for all actions is `ActionBase`. This is a wrapper for the internal Action interface. You should not need it ( If you think you do I‘d be interested why. Please contact me in this case.). There is also a set of standard actions subclassing `ActionBase` which should cover virtually every usecases. + +##### ClipAction +```python +class albert.ClipAction(text="", clipboardText="") +``` +This class copies the given text to the clipboard on activation. + +##### UrlAction +```python +class albert.UrlAction(text="", url="") +``` +This class opens the given URL with the systems default URL handler for the scheme of the URL on activation. + +##### ProcAction +```python +class albert.ProcAction(text="", commandline=[], cwd=None:str) +``` +This class executes the given commandline as a detached process on activation. Optionally the working directory of the process can be set. + +##### TermAction +```python +class albert.TermAction(text="", commandline=[], cwd=None:str) +``` +This class executes the given commandline in the terminal set in the preferences. Optionally the working directory of the process can be set. + +```python +class albert.TermAction(text="", script="", behavior=CloseBehavior.CloseOnSuccess, cwd=None:str) +``` +Convenience wrapper for shell scripts. Executes the script in the user shell in the terminal. + +`TermAction` contains the enum `CloseBehavior`, which can be used to specify the desired behavior on command termination. The values should be self-explanatory. +```python +class CloseBehavior(Enum): + CloseOnSuccess = 0 + CloseOnExit = 1 + DoNotClose = 2 +``` + +##### FuncAction +```python +class albert.FuncAction(text="", callable:callable=lambda:pass) +``` +This class is a general purpose action. On activation the callable is executed. + +#### Some examples +```python +ClipAction(text='This action description', + clipboardText='This goes to the cb') + +UrlAction(text='This simply opens google', + url='https://www.google.com/') + +ProcAction(text='This action runs sth.', + commandline=['jupyter', 'notebook'], + cwd='notebooks/nb1') + +TermAction(text='This action runs a command in the terminal.', + commandline=['jupyter', 'notebook'], + cwd='~/notebooks/nb1') + +TermAction(text='This action runs a script in the user shell in the terminal.', + script="echo Shell hun | tr 'h' 'f' | cat - ", + behavior=TermAction.CloseBehavior.DoNotClose + cwd='~') + +def do_sth(): + albert.info("Hello on stdout!") + +FuncAction(text="Prints Hello on stdout!", callable=do_sth) + +# An item example +Item(id='google', + text='Google the query', + subtext='Handy shortcut to google the query', + actions=[ + UrlAction(text='This simply opens a google search', + url='https://www.google.com/search?q=%s' % query.string) + ClipAction(text='Nifty for dudes assuming you are Google', + clipboardText='Dude, https://www.google.com/search?q=%s') + ]) +``` diff --git a/plugins/python/metadata.json b/plugins/python/metadata.json index b3511dc..7eba3bd 100644 --- a/plugins/python/metadata.json +++ b/plugins/python/metadata.json @@ -1,9 +1,9 @@ { "id" : "org.albert.extension.python", "name" : "Python", - "version" : "1.2", + "version" : "1.3", "platform" : "All", "group" : "Extensions", - "author" : "Manuel Schneider", - "dependencies" : ["python"] + "author" : "Manuel Schneider @manuelschneid3r", + "dependencies" : ["python3"] } diff --git a/plugins/python/pybind11/.appveyor.yml b/plugins/python/pybind11/.appveyor.yml index 4b8f3f8..149a8a3 100644 --- a/plugins/python/pybind11/.appveyor.yml +++ b/plugins/python/pybind11/.appveyor.yml @@ -1,67 +1,37 @@ version: 1.0.{build} image: -- Visual Studio 2017 - Visual Studio 2015 test: off +skip_branch_with_pr: true build: parallel: true platform: -- x64 - x86 environment: matrix: - PYTHON: 36 - CPP: 14 CONFIG: Debug - PYTHON: 27 - CPP: 14 CONFIG: Debug - - CONDA: 36 - CPP: latest - CONFIG: Release -matrix: - exclude: - - image: Visual Studio 2015 - platform: x86 - - image: Visual Studio 2015 - CPP: latest - - image: Visual Studio 2017 - CPP: latest - platform: x86 install: - ps: | - if ($env:PLATFORM -eq "x64") { $env:CMAKE_ARCH = "x64" } - if ($env:APPVEYOR_JOB_NAME -like "*Visual Studio 2017*") { - $env:CMAKE_GENERATOR = "Visual Studio 15 2017" - $env:CMAKE_INCLUDE_PATH = "C:\Libraries\boost_1_64_0" - $env:CXXFLAGS = "-permissive-" - } else { - $env:CMAKE_GENERATOR = "Visual Studio 14 2015" - } - if ($env:PYTHON) { - if ($env:PLATFORM -eq "x64") { $env:PYTHON = "$env:PYTHON-x64" } - $env:PATH = "C:\Python$env:PYTHON\;C:\Python$env:PYTHON\Scripts\;$env:PATH" - python -m pip install --upgrade pip wheel - python -m pip install pytest numpy --no-warn-script-location - } elseif ($env:CONDA) { - if ($env:CONDA -eq "27") { $env:CONDA = "" } - if ($env:PLATFORM -eq "x64") { $env:CONDA = "$env:CONDA-x64" } - $env:PATH = "C:\Miniconda$env:CONDA\;C:\Miniconda$env:CONDA\Scripts\;$env:PATH" - $env:PYTHONHOME = "C:\Miniconda$env:CONDA" - conda install -y -q pytest numpy scipy - } + $env:CMAKE_GENERATOR = "Visual Studio 14 2015" + if ($env:PLATFORM -eq "x64") { $env:PYTHON = "$env:PYTHON-x64" } + $env:PATH = "C:\Python$env:PYTHON\;C:\Python$env:PYTHON\Scripts\;$env:PATH" + python -W ignore -m pip install --upgrade pip wheel + python -W ignore -m pip install pytest numpy --no-warn-script-location - ps: | - Start-FileDownload 'http://bitbucket.org/eigen/eigen/get/3.3.3.zip' - 7z x 3.3.3.zip -y > $null - $env:CMAKE_INCLUDE_PATH = "eigen-eigen-67e894c6cd8f;$env:CMAKE_INCLUDE_PATH" + Start-FileDownload 'https://gitlab.com/libeigen/eigen/-/archive/3.3.7/eigen-3.3.7.zip' + 7z x eigen-3.3.7.zip -y > $null + $env:CMAKE_INCLUDE_PATH = "eigen-3.3.7;$env:CMAKE_INCLUDE_PATH" build_script: - cmake -G "%CMAKE_GENERATOR%" -A "%CMAKE_ARCH%" - -DPYBIND11_CPP_STANDARD=/std:c++%CPP% + -DCMAKE_CXX_STANDARD=14 -DPYBIND11_WERROR=ON -DDOWNLOAD_CATCH=ON -DCMAKE_SUPPRESS_REGENERATION=1 + . - set MSBuildLogger="C:\Program Files\AppVeyor\BuildAgent\Appveyor.MSBuildLogger.dll" - cmake --build . --config %CONFIG% --target pytest -- /m /v:m /logger:%MSBuildLogger% - cmake --build . --config %CONFIG% --target cpptest -- /m /v:m /logger:%MSBuildLogger% -- if "%CPP%"=="latest" (cmake --build . --config %CONFIG% --target test_cmake_build -- /m /v:m /logger:%MSBuildLogger%) on_failure: if exist "tests\test_cmake_build" type tests\test_cmake_build\*.log* diff --git a/plugins/python/pybind11/.clang-tidy b/plugins/python/pybind11/.clang-tidy new file mode 100644 index 0000000..e29d929 --- /dev/null +++ b/plugins/python/pybind11/.clang-tidy @@ -0,0 +1,13 @@ +FormatStyle: file + +Checks: ' +llvm-namespace-comment, +modernize-use-override, +readability-container-size-empty, +modernize-use-using, +modernize-use-equals-default, +modernize-use-auto, +modernize-use-emplace, +' + +HeaderFilterRegex: 'pybind11/.*h' diff --git a/plugins/python/pybind11/.cmake-format.yaml b/plugins/python/pybind11/.cmake-format.yaml new file mode 100644 index 0000000..a2a69f3 --- /dev/null +++ b/plugins/python/pybind11/.cmake-format.yaml @@ -0,0 +1,73 @@ +parse: + additional_commands: + pybind11_add_module: + flags: + - THIN_LTO + - MODULE + - SHARED + - NO_EXTRAS + - EXCLUDE_FROM_ALL + - SYSTEM + +format: + line_width: 99 + tab_size: 2 + + # If an argument group contains more than this many sub-groups + # (parg or kwarg groups) then force it to a vertical layout. + max_subgroups_hwrap: 2 + + # If a positional argument group contains more than this many + # arguments, then force it to a vertical layout. + max_pargs_hwrap: 6 + + # If a cmdline positional group consumes more than this many + # lines without nesting, then invalidate the layout (and nest) + max_rows_cmdline: 2 + separate_ctrl_name_with_space: false + separate_fn_name_with_space: false + dangle_parens: false + + # If the trailing parenthesis must be 'dangled' on its on + # 'line, then align it to this reference: `prefix`: the start' + # 'of the statement, `prefix-indent`: the start of the' + # 'statement, plus one indentation level, `child`: align to' + # the column of the arguments + dangle_align: prefix + # If the statement spelling length (including space and + # parenthesis) is smaller than this amount, then force reject + # nested layouts. + min_prefix_chars: 4 + + # If the statement spelling length (including space and + # parenthesis) is larger than the tab width by more than this + # amount, then force reject un-nested layouts. + max_prefix_chars: 10 + + # If a candidate layout is wrapped horizontally but it exceeds + # this many lines, then reject the layout. + max_lines_hwrap: 2 + + line_ending: unix + + # Format command names consistently as 'lower' or 'upper' case + command_case: canonical + + # Format keywords consistently as 'lower' or 'upper' case + # unchanged is valid too + keyword_case: 'upper' + + # A list of command names which should always be wrapped + always_wrap: [] + + # If true, the argument lists which are known to be sortable + # will be sorted lexicographically + enable_sort: true + + # If true, the parsers may infer whether or not an argument + # list is sortable (without annotation). + autosort: false + +# Causes a few issues - can be solved later, possibly. +markup: + enable_markup: false diff --git a/plugins/python/pybind11/.github/CONTRIBUTING.md b/plugins/python/pybind11/.github/CONTRIBUTING.md new file mode 100644 index 0000000..4ced21b --- /dev/null +++ b/plugins/python/pybind11/.github/CONTRIBUTING.md @@ -0,0 +1,319 @@ +Thank you for your interest in this project! Please refer to the following +sections on how to contribute code and bug reports. + +### Reporting bugs + +Before submitting a question or bug report, please take a moment of your time +and ensure that your issue isn't already discussed in the project documentation +provided at [pybind11.readthedocs.org][] or in the [issue tracker][]. You can +also check [gitter][] to see if it came up before. + +Assuming that you have identified a previously unknown problem or an important +question, it's essential that you submit a self-contained and minimal piece of +code that reproduces the problem. In other words: no external dependencies, +isolate the function(s) that cause breakage, submit matched and complete C++ +and Python snippets that can be easily compiled and run in isolation; or +ideally make a small PR with a failing test case that can be used as a starting +point. + +## Pull requests + +Contributions are submitted, reviewed, and accepted using GitHub pull requests. +Please refer to [this article][using pull requests] for details and adhere to +the following rules to make the process as smooth as possible: + +* Make a new branch for every feature you're working on. +* Make small and clean pull requests that are easy to review but make sure they + do add value by themselves. +* Add tests for any new functionality and run the test suite (`cmake --build + build --target pytest`) to ensure that no existing features break. +* Please run [`pre-commit`][pre-commit] to check your code matches the + project style. (Note that `gawk` is required.) Use `pre-commit run + --all-files` before committing (or use installed-mode, check pre-commit docs) + to verify your code passes before pushing to save time. +* This project has a strong focus on providing general solutions using a + minimal amount of code, thus small pull requests are greatly preferred. + +### Licensing of contributions + +pybind11 is provided under a BSD-style license that can be found in the +``LICENSE`` file. By using, distributing, or contributing to this project, you +agree to the terms and conditions of this license. + +You are under no obligation whatsoever to provide any bug fixes, patches, or +upgrades to the features, functionality or performance of the source code +("Enhancements") to anyone; however, if you choose to make your Enhancements +available either publicly, or directly to the author of this software, without +imposing a separate written license agreement for such Enhancements, then you +hereby grant the following license: a non-exclusive, royalty-free perpetual +license to install, use, modify, prepare derivative works, incorporate into +other computer software, distribute, and sublicense such enhancements or +derivative works thereof, in binary and source code form. + + +## Development of pybind11 + +To setup an ideal development environment, run the following commands on a +system with CMake 3.14+: + +```bash +python3 -m venv venv +source venv/bin/activate +pip install -r tests/requirements.txt +cmake -S . -B build -DDOWNLOAD_CATCH=ON -DDOWNLOAD_EIGEN=ON +cmake --build build -j4 +``` + +Tips: + +* You can use `virtualenv` (from PyPI) instead of `venv` (which is Python 3 + only). +* You can select any name for your environment folder; if it contains "env" it + will be ignored by git. +* If you don’t have CMake 3.14+, just add “cmake” to the pip install command. +* You can use `-DPYBIND11_FINDPYTHON=ON` to use FindPython on CMake 3.12+ +* In classic mode, you may need to set `-DPYTHON_EXECUTABLE=/path/to/python`. + FindPython uses `-DPython_ROOT_DIR=/path/to` or + `-DPython_EXECUTABLE=/path/to/python`. + +### Configuration options + +In CMake, configuration options are given with “-D”. Options are stored in the +build directory, in the `CMakeCache.txt` file, so they are remembered for each +build directory. Two selections are special - the generator, given with `-G`, +and the compiler, which is selected based on environment variables `CXX` and +similar, or `-DCMAKE_CXX_COMPILER=`. Unlike the others, these cannot be changed +after the initial run. + +The valid options are: + +* `-DCMAKE_BUILD_TYPE`: Release, Debug, MinSizeRel, RelWithDebInfo +* `-DPYBIND11_FINDPYTHON=ON`: Use CMake 3.12+’s FindPython instead of the + classic, deprecated, custom FindPythonLibs +* `-DPYBIND11_NOPYTHON=ON`: Disable all Python searching (disables tests) +* `-DBUILD_TESTING=ON`: Enable the tests +* `-DDOWNLOAD_CATCH=ON`: Download catch to build the C++ tests +* `-DOWNLOAD_EIGEN=ON`: Download Eigen for the NumPy tests +* `-DPYBIND11_INSTALL=ON/OFF`: Enable the install target (on by default for the + master project) +* `-DUSE_PYTHON_INSTALL_DIR=ON`: Try to install into the python dir + + +

A few standard CMake tricks: (click to expand)

+ +* Use `cmake --build build -v` to see the commands used to build the files. +* Use `cmake build -LH` to list the CMake options with help. +* Use `ccmake` if available to see a curses (terminal) gui, or `cmake-gui` for + a completely graphical interface (not present in the PyPI package). +* Use `cmake --build build -j12` to build with 12 cores (for example). +* Use `-G` and the name of a generator to use something different. `cmake + --help` lists the generators available. + - On Unix, setting `CMAKE_GENERATER=Ninja` in your environment will give + you automatic mulithreading on all your CMake projects! +* Open the `CMakeLists.txt` with QtCreator to generate for that IDE. +* You can use `-DCMAKE_EXPORT_COMPILE_COMMANDS=ON` to generate the `.json` file + that some tools expect. + +

+ + +To run the tests, you can "build" the check target: + +```bash +cmake --build build --target check +``` + +`--target` can be spelled `-t` in CMake 3.15+. You can also run individual +tests with these targets: + +* `pytest`: Python tests only +* `cpptest`: C++ tests only +* `test_cmake_build`: Install / subdirectory tests + +If you want to build just a subset of tests, use +`-DPYBIND11_TEST_OVERRIDE="test_callbacks.cpp;test_pickling.cpp"`. If this is +empty, all tests will be built. + +### Formatting + +All formatting is handled by pre-commit. + +Install with brew (macOS) or pip (any OS): + +```bash +# Any OS +python3 -m pip install pre-commit + +# OR macOS with homebrew: +brew install pre-commit +``` + +Then, you can run it on the items you've added to your staging area, or all +files: + +```bash +pre-commit run +# OR +pre-commit run --all-files +``` + +And, if you want to always use it, you can install it as a git hook (hence the +name, pre-commit): + +```bash +pre-commit install +``` + +### Clang-Tidy + +To run Clang tidy, the following recipe should work. Files will be modified in +place, so you can use git to monitor the changes. + +```bash +docker run --rm -v $PWD:/pybind11 -it silkeh/clang:10 +apt-get update && apt-get install python3-dev python3-pytest +cmake -S pybind11/ -B build -DCMAKE_CXX_CLANG_TIDY="$(which clang-tidy);-fix" +cmake --build build +``` + +### Include what you use + +To run include what you use, install (`brew install include-what-you-use` on +macOS), then run: + +```bash +cmake -S . -B build-iwyu -DCMAKE_CXX_INCLUDE_WHAT_YOU_USE=$(which include-what-you-use) +cmake --build build +``` + +The report is sent to stderr; you can pip it into a file if you wish. + +### Build recipes + +This builds with the Intel compiler (assuming it is in your path, along with a +recent CMake and Python 3): + +```bash +python3 -m venv venv +. venv/bin/activate +pip install pytest +cmake -S . -B build-intel -DCMAKE_CXX_COMPILER=$(which icpc) -DDOWNLOAD_CATCH=ON -DDOWNLOAD_EIGEN=ON -DPYBIND11_WERROR=ON +``` + +This will test the PGI compilers: + +```bash +docker run --rm -it -v $PWD:/pybind11 nvcr.io/hpc/pgi-compilers:ce +apt-get update && apt-get install -y python3-dev python3-pip python3-pytest +wget -qO- "https://cmake.org/files/v3.18/cmake-3.18.2-Linux-x86_64.tar.gz" | tar --strip-components=1 -xz -C /usr/local +cmake -S pybind11/ -B build +cmake --build build +``` + +### Explanation of the SDist/wheel building design + +> These details below are _only_ for packaging the Python sources from git. The +> SDists and wheels created do not have any extra requirements at all and are +> completely normal. + +The main objective of the packaging system is to create SDists (Python's source +distribution packages) and wheels (Python's binary distribution packages) that +include everything that is needed to work with pybind11, and which can be +installed without any additional dependencies. This is more complex than it +appears: in order to support CMake as a first class language even when using +the PyPI package, they must include the _generated_ CMake files (so as not to +require CMake when installing the `pybind11` package itself). They should also +provide the option to install to the "standard" location +(`/include/pybind11` and `/share/cmake/pybind11`) so they are +easy to find with CMake, but this can cause problems if you are not an +environment or using ``pyproject.toml`` requirements. This was solved by having +two packages; the "nice" pybind11 package that stores the includes and CMake +files inside the package, that you get access to via functions in the package, +and a `pybind11-global` package that can be included via `pybind11[global]` if +you want the more invasive but discoverable file locations. + +If you want to install or package the GitHub source, it is best to have Pip 10 +or newer on Windows, macOS, or Linux (manylinux1 compatible, includes most +distributions). You can then build the SDists, or run any procedure that makes +SDists internally, like making wheels or installing. + + +```bash +# Editable development install example +python3 -m pip install -e . +``` + +Since Pip itself does not have an `sdist` command (it does have `wheel` and +`install`), you may want to use the upcoming `build` package: + +```bash +python3 -m pip install build + +# Normal package +python3 -m build -s . + +# Global extra +PYBIND11_GLOBAL_SDIST=1 python3 -m build -s . +``` + +If you want to use the classic "direct" usage of `python setup.py`, you will +need CMake 3.15+ and either `make` or `ninja` preinstalled (possibly via `pip +install cmake ninja`), since directly running Python on `setup.py` cannot pick +up and install `pyproject.toml` requirements. As long as you have those two +things, though, everything works the way you would expect: + +```bash +# Normal package +python3 setup.py sdist + +# Global extra +PYBIND11_GLOBAL_SDIST=1 python3 setup.py sdist +``` + +A detailed explanation of the build procedure design for developers wanting to +work on or maintain the packaging system is as follows: + +#### 1. Building from the source directory + +When you invoke any `setup.py` command from the source directory, including +`pip wheel .` and `pip install .`, you will activate a full source build. This +is made of the following steps: + +1. If the tool is PEP 518 compliant, like Pip 10+, it will create a temporary + virtual environment and install the build requirements (mostly CMake) into + it. (if you are not on Windows, macOS, or a manylinux compliant system, you + can disable this with `--no-build-isolation` as long as you have CMake 3.15+ + installed) +2. The environment variable `PYBIND11_GLOBAL_SDIST` is checked - if it is set + and truthy, this will be make the accessory `pybind11-global` package, + instead of the normal `pybind11` package. This package is used for + installing the files directly to your environment root directory, using + `pybind11[global]`. +2. `setup.py` reads the version from `pybind11/_version.py` and verifies it + matches `includes/pybind11/detail/common.h`. +3. CMake is run with `-DCMAKE_INSTALL_PREIFX=pybind11`. Since the CMake install + procedure uses only relative paths and is identical on all platforms, these + files are valid as long as they stay in the correct relative position to the + includes. `pybind11/share/cmake/pybind11` has the CMake files, and + `pybind11/include` has the includes. The build directory is discarded. +4. Simpler files are placed in the SDist: `tools/setup_*.py.in`, + `tools/pyproject.toml` (`main` or `global`) +5. The package is created by running the setup function in the + `tools/setup_*.py`. `setup_main.py` fills in Python packages, and + `setup_global.py` fills in only the data/header slots. +6. A context manager cleans up the temporary CMake install directory (even if + an error is thrown). + +### 2. Building from SDist + +Since the SDist has the rendered template files in `tools` along with the +includes and CMake files in the correct locations, the builds are completely +trivial and simple. No extra requirements are required. You can even use Pip 9 +if you really want to. + + +[pre-commit]: https://pre-commit.com +[pybind11.readthedocs.org]: http://pybind11.readthedocs.org/en/latest +[issue tracker]: https://github.com/pybind/pybind11/issues +[gitter]: https://gitter.im/pybind/Lobby +[using pull requests]: https://help.github.com/articles/using-pull-requests diff --git a/plugins/python/pybind11/.github/ISSUE_TEMPLATE/bug-report.md b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/bug-report.md new file mode 100644 index 0000000..ae36ea6 --- /dev/null +++ b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/bug-report.md @@ -0,0 +1,28 @@ +--- +name: Bug Report +about: File an issue about a bug +title: "[BUG] " +--- + + +Make sure you've completed the following steps before submitting your issue -- thank you! + +1. Make sure you've read the [documentation][]. Your issue may be addressed there. +2. Search the [issue tracker][] to verify that this hasn't already been reported. +1 or comment there if it has. +3. Consider asking first in the [Gitter chat room][]. +4. Include a self-contained and minimal piece of code that reproduces the problem. If that's not possible, try to make the description as clear as possible. + a. If possible, make a PR with a new, failing test to give us a starting point to work on! + +[documentation]: https://pybind11.readthedocs.io +[issue tracker]: https://github.com/pybind/pybind11/issues +[Gitter chat room]: https://gitter.im/pybind/Lobby + +*After reading, remove this checklist and the template text in parentheses below.* + +## Issue description + +(Provide a short description, state the expected behavior and what actually happens.) + +## Reproducible example code + +(The code should be minimal, have no external dependencies, isolate the function(s) that cause breakage. Submit matched and complete C++ and Python snippets that can be easily compiled and run to diagnose the issue.) diff --git a/plugins/python/pybind11/.github/ISSUE_TEMPLATE/config.yml b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/config.yml new file mode 100644 index 0000000..20e7431 --- /dev/null +++ b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/config.yml @@ -0,0 +1,5 @@ +blank_issues_enabled: false +contact_links: + - name: Gitter room + url: https://gitter.im/pybind/Lobby + about: A room for discussing pybind11 with an active community diff --git a/plugins/python/pybind11/.github/ISSUE_TEMPLATE/feature-request.md b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/feature-request.md new file mode 100644 index 0000000..5f6ec81 --- /dev/null +++ b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/feature-request.md @@ -0,0 +1,16 @@ +--- +name: Feature Request +about: File an issue about adding a feature +title: "[FEAT] " +--- + + +Make sure you've completed the following steps before submitting your issue -- thank you! + +1. Check if your feature has already been mentioned / rejected / planned in other issues. +2. If those resources didn't help, consider asking in the [Gitter chat room][] to see if this is interesting / useful to a larger audience and possible to implement reasonably, +4. If you have a useful feature that passes the previous items (or not suitable for chat), please fill in the details below. + +[Gitter chat room]: https://gitter.im/pybind/Lobby + +*After reading, remove this checklist.* diff --git a/plugins/python/pybind11/.github/ISSUE_TEMPLATE/question.md b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/question.md new file mode 100644 index 0000000..b199b6e --- /dev/null +++ b/plugins/python/pybind11/.github/ISSUE_TEMPLATE/question.md @@ -0,0 +1,21 @@ +--- +name: Question +about: File an issue about unexplained behavior +title: "[QUESTION] " +--- + +If you have a question, please check the following first: + +1. Check if your question has already been answered in the [FAQ][] section. +2. Make sure you've read the [documentation][]. Your issue may be addressed there. +3. If those resources didn't help and you only have a short question (not a bug report), consider asking in the [Gitter chat room][] +4. Search the [issue tracker][], including the closed issues, to see if your question has already been asked/answered. +1 or comment if it has been asked but has no answer. +5. If you have a more complex question which is not answered in the previous items (or not suitable for chat), please fill in the details below. +6. Include a self-contained and minimal piece of code that illustrates your question. If that's not possible, try to make the description as clear as possible. + +[FAQ]: http://pybind11.readthedocs.io/en/latest/faq.html +[documentation]: https://pybind11.readthedocs.io +[issue tracker]: https://github.com/pybind/pybind11/issues +[Gitter chat room]: https://gitter.im/pybind/Lobby + +*After reading, remove this checklist.* diff --git a/plugins/python/pybind11/.github/dependabot.yml b/plugins/python/pybind11/.github/dependabot.yml new file mode 100644 index 0000000..c1eac3c --- /dev/null +++ b/plugins/python/pybind11/.github/dependabot.yml @@ -0,0 +1,11 @@ +version: 2 +updates: + # Maintain dependencies for GitHub Actions + - package-ecosystem: "github-actions" + directory: "/" + schedule: + interval: "daily" + ignore: + # Offical actions have moving tags like v1 + # that are used, so they don't need updates here + - dependency-name: "actions/*" diff --git a/plugins/python/pybind11/.github/labeler.yml b/plugins/python/pybind11/.github/labeler.yml new file mode 100644 index 0000000..abb0d05 --- /dev/null +++ b/plugins/python/pybind11/.github/labeler.yml @@ -0,0 +1,8 @@ +docs: +- any: + - 'docs/**/*.rst' + - '!docs/changelog.rst' + - '!docs/upgrade.rst' + +ci: +- '.github/workflows/*.yml' diff --git a/plugins/python/pybind11/.github/labeler_merged.yml b/plugins/python/pybind11/.github/labeler_merged.yml new file mode 100644 index 0000000..2374ad4 --- /dev/null +++ b/plugins/python/pybind11/.github/labeler_merged.yml @@ -0,0 +1,3 @@ +needs changelog: +- all: + - '!docs/changelog.rst' diff --git a/plugins/python/pybind11/.github/pull_request_template.md b/plugins/python/pybind11/.github/pull_request_template.md new file mode 100644 index 0000000..5570f6f --- /dev/null +++ b/plugins/python/pybind11/.github/pull_request_template.md @@ -0,0 +1,14 @@ +## Description + + + + +## Suggested changelog entry: + + + +```rst + +``` + + diff --git a/plugins/python/pybind11/.github/workflows/ci.yml b/plugins/python/pybind11/.github/workflows/ci.yml new file mode 100644 index 0000000..73424f9 --- /dev/null +++ b/plugins/python/pybind11/.github/workflows/ci.yml @@ -0,0 +1,676 @@ +name: CI + +on: + workflow_dispatch: + pull_request: + push: + branches: + - master + - stable + - v* + +jobs: + # This is the "main" test suite, which tests a large number of different + # versions of default compilers and Python versions in GitHub Actions. + standard: + strategy: + fail-fast: false + matrix: + runs-on: [ubuntu-latest, windows-latest, macos-latest] + python: + - 2.7 + - 3.5 + - 3.6 + - 3.7 + - 3.8 + - 3.9 + # - 3.10.0-alpha.1 - need next release for pybind11 fix + - pypy2 + - pypy3 + + # Items in here will either be added to the build matrix (if not + # present), or add new keys to an existing matrix element if all the + # existing keys match. + # + # We support three optional keys: args (both build), args1 (first + # build), and args2 (second build). + include: + # Just add a key + - runs-on: ubuntu-latest + python: 3.6 + args: > + -DPYBIND11_FINDPYTHON=ON + - runs-on: windows-latest + python: 3.6 + args: > + -DPYBIND11_FINDPYTHON=ON + - runs-on: ubuntu-latest + python: 3.8 + args: > + -DPYBIND11_FINDPYTHON=ON + + # These items will be removed from the build matrix, keys must match. + exclude: + # Currently 32bit only, and we build 64bit + - runs-on: windows-latest + python: pypy2 + - runs-on: windows-latest + python: pypy3 + + # Let's drop a few macOS runs since that tends to be 2.7 or 3.8+ + - runs-on: macos-latest + python: 3.6 + - runs-on: macos-latest + python: 3.7 + + name: "🐍 ${{ matrix.python }} • ${{ matrix.runs-on }} • x64 ${{ matrix.args }}" + runs-on: ${{ matrix.runs-on }} + + steps: + - uses: actions/checkout@v2 + + - name: Setup Python ${{ matrix.python }} + uses: actions/setup-python@v2 + with: + python-version: ${{ matrix.python }} + + - name: Setup Boost (Windows / Linux latest) + shell: bash + run: echo "BOOST_ROOT=$BOOST_ROOT_1_72_0" >> $GITHUB_ENV + + - name: Update CMake + uses: jwlawson/actions-setup-cmake@v1.4 + + - name: Cache wheels + if: runner.os == 'macOS' + uses: actions/cache@v2 + with: + # This path is specific to macOS - we really only need it for PyPy NumPy wheels + # See https://github.com/actions/cache/blob/master/examples.md#python---pip + # for ways to do this more generally + path: ~/Library/Caches/pip + # Look to see if there is a cache hit for the corresponding requirements file + key: ${{ runner.os }}-pip-${{ matrix.python }}-x64-${{ hashFiles('tests/requirements.txt') }} + + - name: Prepare env + run: python -m pip install -r tests/requirements.txt --prefer-binary + + - name: Setup annotations on Linux + if: runner.os == 'Linux' + run: python -m pip install pytest-github-actions-annotate-failures + + # First build - C++11 mode and inplace + - name: Configure C++11 ${{ matrix.args }} + run: > + cmake -S . -B . + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DDOWNLOAD_EIGEN=ON + -DCMAKE_CXX_STANDARD=11 + ${{ matrix.args }} + + - name: Build C++11 + run: cmake --build . -j 2 + + - name: Python tests C++11 + run: cmake --build . --target pytest -j 2 + + - name: C++11 tests + # TODO: Figure out how to load the DLL on Python 3.8+ + if: "!(runner.os == 'Windows' && (matrix.python == 3.8 || matrix.python == 3.9))" + run: cmake --build . --target cpptest -j 2 + + - name: Interface test C++11 + run: cmake --build . --target test_cmake_build + + - name: Clean directory + run: git clean -fdx + + # Second build - C++17 mode and in a build directory + - name: Configure ${{ matrix.args2 }} + run: > + cmake -S . -B build2 + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DDOWNLOAD_EIGEN=ON + -DCMAKE_CXX_STANDARD=17 + ${{ matrix.args }} + ${{ matrix.args2 }} + + - name: Build + run: cmake --build build2 -j 2 + + - name: Python tests + run: cmake --build build2 --target pytest + + - name: C++ tests + # TODO: Figure out how to load the DLL on Python 3.8+ + if: "!(runner.os == 'Windows' && (matrix.python == 3.8 || matrix.python == 3.9))" + run: cmake --build build2 --target cpptest + + - name: Interface test + run: cmake --build build2 --target test_cmake_build + + # Eventually Microsoft might have an action for setting up + # MSVC, but for now, this action works: + - name: Prepare compiler environment for Windows 🐍 2.7 + if: matrix.python == 2.7 && runner.os == 'Windows' + uses: ilammy/msvc-dev-cmd@v1 + with: + arch: x64 + + # This makes two environment variables available in the following step(s) + - name: Set Windows 🐍 2.7 environment variables + if: matrix.python == 2.7 && runner.os == 'Windows' + shell: bash + run: | + echo "DISTUTILS_USE_SDK=1" >> $GITHUB_ENV + echo "MSSdk=1" >> $GITHUB_ENV + + # This makes sure the setup_helpers module can build packages using + # setuptools + - name: Setuptools helpers test + run: pytest tests/extra_setuptools + + + # Testing on clang using the excellent silkeh clang docker images + clang: + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + clang: + - 3.6 + - 3.7 + - 3.9 + - 7 + - 9 + - dev + std: + - 11 + include: + - clang: 5 + std: 14 + - clang: 10 + std: 20 + - clang: 10 + std: 17 + + name: "🐍 3 • Clang ${{ matrix.clang }} • C++${{ matrix.std }} • x64" + container: "silkeh/clang:${{ matrix.clang }}" + + steps: + - uses: actions/checkout@v2 + + - name: Add wget and python3 + run: apt-get update && apt-get install -y python3-dev python3-numpy python3-pytest libeigen3-dev + + - name: Configure + shell: bash + run: > + cmake -S . -B build + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DCMAKE_CXX_STANDARD=${{ matrix.std }} + -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") + + - name: Build + run: cmake --build build -j 2 + + - name: Python tests + run: cmake --build build --target pytest + + - name: C++ tests + run: cmake --build build --target cpptest + + - name: Interface test + run: cmake --build build --target test_cmake_build + + + # Testing NVCC; forces sources to behave like .cu files + cuda: + runs-on: ubuntu-latest + name: "🐍 3.8 • CUDA 11 • Ubuntu 20.04" + container: nvidia/cuda:11.0-devel-ubuntu20.04 + + steps: + - uses: actions/checkout@v2 + + # tzdata will try to ask for the timezone, so set the DEBIAN_FRONTEND + - name: Install 🐍 3 + run: apt-get update && DEBIAN_FRONTEND="noninteractive" apt-get install -y cmake git python3-dev python3-pytest python3-numpy + + - name: Configure + run: cmake -S . -B build -DPYBIND11_CUDA_TESTS=ON -DPYBIND11_WERROR=ON -DDOWNLOAD_CATCH=ON + + - name: Build + run: cmake --build build -j2 --verbose + + - name: Python tests + run: cmake --build build --target pytest + + + # Testing CentOS 8 + PGI compilers + centos-nvhpc8: + runs-on: ubuntu-latest + name: "🐍 3 • CentOS8 / PGI 20.7 • x64" + container: centos:8 + + steps: + - uses: actions/checkout@v2 + + - name: Add Python 3 and a few requirements + run: yum update -y && yum install -y git python3-devel python3-numpy python3-pytest make environment-modules + + - name: Install CMake with pip + run: | + python3 -m pip install --upgrade pip + python3 -m pip install cmake --prefer-binary + + - name: Install NVidia HPC SDK + run: yum -y install https://developer.download.nvidia.com/hpc-sdk/nvhpc-20-7-20.7-1.x86_64.rpm https://developer.download.nvidia.com/hpc-sdk/nvhpc-2020-20.7-1.x86_64.rpm + + - name: Configure + shell: bash + run: | + source /etc/profile.d/modules.sh + module load /opt/nvidia/hpc_sdk/modulefiles/nvhpc/20.7 + cmake -S . -B build -DDOWNLOAD_CATCH=ON -DCMAKE_CXX_STANDARD=14 -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") + + - name: Build + run: cmake --build build -j 2 --verbose + + - name: Python tests + run: cmake --build build --target pytest + + - name: C++ tests + run: cmake --build build --target cpptest + + - name: Interface test + run: cmake --build build --target test_cmake_build + + + # Testing on CentOS 7 + PGI compilers, which seems to require more workarounds + centos-nvhpc7: + runs-on: ubuntu-latest + name: "🐍 3 • CentOS7 / PGI 20.9 • x64" + container: centos:7 + + steps: + - uses: actions/checkout@v2 + + - name: Add Python 3 and a few requirements + run: yum update -y && yum install -y epel-release && yum install -y git python3-devel make environment-modules cmake3 + + - name: Install NVidia HPC SDK + run: yum -y install https://developer.download.nvidia.com/hpc-sdk/20.9/nvhpc-20-9-20.9-1.x86_64.rpm https://developer.download.nvidia.com/hpc-sdk/20.9/nvhpc-2020-20.9-1.x86_64.rpm + + # On CentOS 7, we have to filter a few tests (compiler internal error) + # and allow deeper templete recursion (not needed on CentOS 8 with a newer + # standard library). On some systems, you many need further workarounds: + # https://github.com/pybind/pybind11/pull/2475 + - name: Configure + shell: bash + run: | + source /etc/profile.d/modules.sh + module load /opt/nvidia/hpc_sdk/modulefiles/nvhpc/20.9 + cmake3 -S . -B build -DDOWNLOAD_CATCH=ON \ + -DCMAKE_CXX_STANDARD=11 \ + -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") \ + -DCMAKE_CXX_FLAGS="-Wc,--pending_instantiations=0" \ + -DPYBIND11_TEST_FILTER="test_smart_ptr.cpp;test_virtual_functions.cpp" + + # Building before installing Pip should produce a warning but not an error + - name: Build + run: cmake3 --build build -j 2 --verbose + + - name: Install CMake with pip + run: | + python3 -m pip install --upgrade pip + python3 -m pip install pytest + + - name: Python tests + run: cmake3 --build build --target pytest + + - name: C++ tests + run: cmake3 --build build --target cpptest + + - name: Interface test + run: cmake3 --build build --target test_cmake_build + + # Testing on GCC using the GCC docker images (only recent images supported) + gcc: + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + gcc: + - 7 + - latest + std: + - 11 + include: + - gcc: 10 + std: 20 + + name: "🐍 3 • GCC ${{ matrix.gcc }} • C++${{ matrix.std }}• x64" + container: "gcc:${{ matrix.gcc }}" + + steps: + - uses: actions/checkout@v1 + + - name: Add Python 3 + run: apt-get update; apt-get install -y python3-dev python3-numpy python3-pytest python3-pip libeigen3-dev + + - name: Update pip + run: python3 -m pip install --upgrade pip + + - name: Setup CMake 3.18 + uses: jwlawson/actions-setup-cmake@v1.4 + with: + cmake-version: 3.18 + + - name: Configure + shell: bash + run: > + cmake -S . -B build + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DCMAKE_CXX_STANDARD=${{ matrix.std }} + -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") + + - name: Build + run: cmake --build build -j 2 + + - name: Python tests + run: cmake --build build --target pytest + + - name: C++ tests + run: cmake --build build --target cpptest + + - name: Interface test + run: cmake --build build --target test_cmake_build + + + # Testing on CentOS (manylinux uses a centos base, and this is an easy way + # to get GCC 4.8, which is the manylinux1 compiler). + centos: + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + centos: + - 7 # GCC 4.8 + - 8 + + name: "🐍 3 • CentOS ${{ matrix.centos }} • x64" + container: "centos:${{ matrix.centos }}" + + steps: + - uses: actions/checkout@v2 + + - name: Add Python 3 + run: yum update -y && yum install -y python3-devel gcc-c++ make git + + - name: Update pip + run: python3 -m pip install --upgrade pip + + - name: Install dependencies + run: python3 -m pip install cmake -r tests/requirements.txt --prefer-binary + + - name: Configure + shell: bash + run: > + cmake -S . -B build + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DDOWNLOAD_EIGEN=ON + -DCMAKE_CXX_STANDARD=11 + -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") + + - name: Build + run: cmake --build build -j 2 + + - name: Python tests + run: cmake --build build --target pytest + + - name: C++ tests + run: cmake --build build --target cpptest + + - name: Interface test + run: cmake --build build --target test_cmake_build + + + # This tests an "install" with the CMake tools + install-classic: + name: "🐍 3.5 • Debian • x86 • Install" + runs-on: ubuntu-latest + container: i386/debian:stretch + + steps: + - uses: actions/checkout@v1 + + - name: Install requirements + run: | + apt-get update + apt-get install -y git make cmake g++ libeigen3-dev python3-dev python3-pip + pip3 install "pytest==3.1.*" + + - name: Configure for install + run: > + cmake . + -DPYBIND11_INSTALL=1 -DPYBIND11_TEST=0 + -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") + + - name: Make and install + run: make install + + - name: Copy tests to new directory + run: cp -a tests /pybind11-tests + + - name: Make a new test directory + run: mkdir /build-tests + + - name: Configure tests + run: > + cmake ../pybind11-tests + -DDOWNLOAD_CATCH=ON + -DPYBIND11_WERROR=ON + -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") + working-directory: /build-tests + + - name: Run tests + run: make pytest -j 2 + working-directory: /build-tests + + + # This verifies that the documentation is not horribly broken, and does a + # basic sanity check on the SDist. + doxygen: + name: "Documentation build test" + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + + - uses: actions/setup-python@v2 + + - name: Install Doxygen + run: sudo apt-get install -y doxygen librsvg2-bin # Changed to rsvg-convert in 20.04 + + - name: Install docs & setup requirements + run: python3 -m pip install -r docs/requirements.txt + + - name: Build docs + run: python3 -m sphinx -W -b html docs docs/.build + + - name: Make SDist + run: python3 setup.py sdist + + - run: git status --ignored + + - name: Check local include dir + run: > + ls pybind11; + python3 -c "import pybind11, pathlib; assert (a := pybind11.get_include()) == (b := str(pathlib.Path('include').resolve())), f'{a} != {b}'" + + - name: Compare Dists (headers only) + working-directory: include + run: | + python3 -m pip install --user -U ../dist/* + installed=$(python3 -c "import pybind11; print(pybind11.get_include() + '/pybind11')") + diff -rq $installed ./pybind11 + + win32: + strategy: + fail-fast: false + matrix: + python: + - 3.5 + - 3.6 + - 3.7 + - 3.8 + - 3.9 + - pypy3 + # TODO: fix hang on pypy2 + + include: + - python: 3.9 + args: -DCMAKE_CXX_STANDARD=20 -DDOWNLOAD_EIGEN=OFF + - python: 3.8 + args: -DCMAKE_CXX_STANDARD=17 + + name: "🐍 ${{ matrix.python }} • MSVC 2019 • x86 ${{ matrix.args }}" + runs-on: windows-latest + + steps: + - uses: actions/checkout@v2 + + - name: Setup Python ${{ matrix.python }} + uses: actions/setup-python@v2 + with: + python-version: ${{ matrix.python }} + architecture: x86 + + - name: Update CMake + uses: jwlawson/actions-setup-cmake@v1.4 + + - name: Prepare MSVC + uses: ilammy/msvc-dev-cmd@v1 + with: + arch: x86 + + - name: Prepare env + run: python -m pip install -r tests/requirements.txt --prefer-binary + + # First build - C++11 mode and inplace + - name: Configure ${{ matrix.args }} + run: > + cmake -S . -B build + -G "Visual Studio 16 2019" -A Win32 + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DDOWNLOAD_EIGEN=ON + ${{ matrix.args }} + - name: Build C++11 + run: cmake --build build -j 2 + + - name: Run tests + run: cmake --build build -t pytest + + win32-msvc2015: + name: "🐍 ${{ matrix.python }} • MSVC 2015 • x64" + runs-on: windows-latest + strategy: + fail-fast: false + matrix: + python: + - 2.7 + - 3.6 + - 3.7 + # todo: check/cpptest does not support 3.8+ yet + + steps: + - uses: actions/checkout@v2 + + - name: Setup 🐍 ${{ matrix.python }} + uses: actions/setup-python@v2 + with: + python-version: ${{ matrix.python }} + + - name: Update CMake + uses: jwlawson/actions-setup-cmake@v1.4 + + - name: Prepare MSVC + uses: ilammy/msvc-dev-cmd@v1 + with: + toolset: 14.0 + + - name: Prepare env + run: python -m pip install -r tests/requirements.txt --prefer-binary + + # First build - C++11 mode and inplace + - name: Configure + run: > + cmake -S . -B build + -G "Visual Studio 14 2015" -A x64 + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DDOWNLOAD_EIGEN=ON + + - name: Build C++14 + run: cmake --build build -j 2 + + - name: Run all checks + run: cmake --build build -t check + + + win32-msvc2017: + name: "🐍 ${{ matrix.python }} • MSVC 2017 • x64" + runs-on: windows-2016 + strategy: + fail-fast: false + matrix: + python: + - 2.7 + - 3.5 + - 3.7 + std: + - 14 + + include: + - python: 2.7 + std: 17 + args: > + -DCMAKE_CXX_FLAGS="/permissive- /EHsc /GR" + + steps: + - uses: actions/checkout@v2 + + - name: Setup 🐍 ${{ matrix.python }} + uses: actions/setup-python@v2 + with: + python-version: ${{ matrix.python }} + + - name: Update CMake + uses: jwlawson/actions-setup-cmake@v1.4 + + - name: Prepare env + run: python -m pip install -r tests/requirements.txt --prefer-binary + + # First build - C++11 mode and inplace + - name: Configure + run: > + cmake -S . -B build + -G "Visual Studio 15 2017" -A x64 + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DDOWNLOAD_EIGEN=ON + -DCMAKE_CXX_STANDARD=${{ matrix.std }} + ${{ matrix.args }} + + - name: Build ${{ matrix.std }} + run: cmake --build build -j 2 + + - name: Run all checks + run: cmake --build build -t check diff --git a/plugins/python/pybind11/.github/workflows/configure.yml b/plugins/python/pybind11/.github/workflows/configure.yml new file mode 100644 index 0000000..23f6022 --- /dev/null +++ b/plugins/python/pybind11/.github/workflows/configure.yml @@ -0,0 +1,84 @@ +name: Config + +on: + workflow_dispatch: + pull_request: + push: + branches: + - master + - stable + - v* + +jobs: + # This tests various versions of CMake in various combinations, to make sure + # the configure step passes. + cmake: + strategy: + fail-fast: false + matrix: + runs-on: [ubuntu-latest, macos-latest, windows-latest] + arch: [x64] + cmake: [3.18] + + include: + - runs-on: ubuntu-latest + arch: x64 + cmake: 3.4 + + - runs-on: macos-latest + arch: x64 + cmake: 3.7 + + - runs-on: windows-2016 + arch: x86 + cmake: 3.8 + + - runs-on: windows-2016 + arch: x86 + cmake: 3.18 + + name: 🐍 3.7 • CMake ${{ matrix.cmake }} • ${{ matrix.runs-on }} + runs-on: ${{ matrix.runs-on }} + + steps: + - uses: actions/checkout@v2 + + - name: Setup Python 3.7 + uses: actions/setup-python@v2 + with: + python-version: 3.7 + architecture: ${{ matrix.arch }} + + - name: Prepare env + run: python -m pip install -r tests/requirements.txt + + # An action for adding a specific version of CMake: + # https://github.com/jwlawson/actions-setup-cmake + - name: Setup CMake ${{ matrix.cmake }} + uses: jwlawson/actions-setup-cmake@v1.3 + with: + cmake-version: ${{ matrix.cmake }} + + # These steps use a directory with a space in it intentionally + - name: Make build directories + run: mkdir "build dir" + + - name: Configure + working-directory: build dir + shell: bash + run: > + cmake .. + -DPYBIND11_WERROR=ON + -DDOWNLOAD_CATCH=ON + -DPYTHON_EXECUTABLE=$(python -c "import sys; print(sys.executable)") + + # Only build and test if this was manually triggered in the GitHub UI + - name: Build + working-directory: build dir + if: github.event_name == 'workflow_dispatch' + run: cmake --build . --config Release + + - name: Test + working-directory: build dir + if: github.event_name == 'workflow_dispatch' + run: cmake --build . --config Release --target check diff --git a/plugins/python/pybind11/.github/workflows/format.yml b/plugins/python/pybind11/.github/workflows/format.yml new file mode 100644 index 0000000..5cebed1 --- /dev/null +++ b/plugins/python/pybind11/.github/workflows/format.yml @@ -0,0 +1,46 @@ +# This is a format job. Pre-commit has a first-party GitHub action, so we use +# that: https://github.com/pre-commit/action + +name: Format + +on: + workflow_dispatch: + pull_request: + push: + branches: + - master + - stable + - "v*" + +jobs: + pre-commit: + name: Format + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - uses: actions/setup-python@v2 + - uses: pre-commit/action@v2.0.0 + with: + # Slow hooks are marked with manual - slow is okay here, run them too + extra_args: --hook-stage manual --all-files + + clang-tidy: + name: Clang-Tidy + runs-on: ubuntu-latest + container: silkeh/clang:10 + steps: + - uses: actions/checkout@v2 + + - name: Install requirements + run: apt-get update && apt-get install -y python3-dev python3-pytest + + - name: Configure + run: > + cmake -S . -B build + -DCMAKE_CXX_CLANG_TIDY="$(which clang-tidy);--warnings-as-errors=*" + -DDOWNLOAD_EIGEN=ON + -DDOWNLOAD_CATCH=ON + -DCMAKE_CXX_STANDARD=17 + + - name: Build + run: cmake --build build -j 2 diff --git a/plugins/python/pybind11/.github/workflows/labeler.yml b/plugins/python/pybind11/.github/workflows/labeler.yml new file mode 100644 index 0000000..d2b5979 --- /dev/null +++ b/plugins/python/pybind11/.github/workflows/labeler.yml @@ -0,0 +1,16 @@ +name: Labeler +on: + pull_request_target: + types: [closed] + +jobs: + label: + name: Labeler + runs-on: ubuntu-latest + steps: + + - uses: actions/labeler@main + if: github.event.pull_request.merged == true + with: + repo-token: ${{ secrets.GITHUB_TOKEN }} + configuration-path: .github/labeler_merged.yml diff --git a/plugins/python/pybind11/.github/workflows/pip.yml b/plugins/python/pybind11/.github/workflows/pip.yml new file mode 100644 index 0000000..4414a12 --- /dev/null +++ b/plugins/python/pybind11/.github/workflows/pip.yml @@ -0,0 +1,103 @@ +name: Pip + +on: + workflow_dispatch: + pull_request: + push: + branches: + - master + - stable + - v* + release: + types: + - published + +jobs: + # This builds the sdists and wheels and makes sure the files are exactly as + # expected. Using Windows and Python 2.7, since that is often the most + # challenging matrix element. + test-packaging: + name: 🐍 2.7 • 📦 tests • windows-latest + runs-on: windows-latest + + steps: + - uses: actions/checkout@v2 + + - name: Setup 🐍 2.7 + uses: actions/setup-python@v2 + with: + python-version: 2.7 + + - name: Prepare env + run: python -m pip install -r tests/requirements.txt --prefer-binary + + - name: Python Packaging tests + run: pytest tests/extra_python_package/ + + + # This runs the packaging tests and also builds and saves the packages as + # artifacts. + packaging: + name: 🐍 3.8 • 📦 & 📦 tests • ubuntu-latest + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + + - name: Setup 🐍 3.8 + uses: actions/setup-python@v2 + with: + python-version: 3.8 + + - name: Prepare env + run: python -m pip install -r tests/requirements.txt build twine --prefer-binary + + - name: Python Packaging tests + run: pytest tests/extra_python_package/ + + - name: Build SDist and wheels + run: | + python -m build + PYBIND11_GLOBAL_SDIST=1 python -m build + + - name: Check metadata + run: twine check dist/* + + - name: Save standard package + uses: actions/upload-artifact@v2 + with: + name: standard + path: dist/pybind11-* + + - name: Save global package + uses: actions/upload-artifact@v2 + with: + name: global + path: dist/pybind11_global-* + + + + # When a GitHub release is made, upload the artifacts to PyPI + upload: + name: Upload to PyPI + runs-on: ubuntu-latest + if: github.event_name == 'release' && github.event.action == 'published' + needs: [packaging] + + steps: + - uses: actions/setup-python@v2 + + # Downloads all to directories matching the artifact names + - uses: actions/download-artifact@v2 + + - name: Publish standard package + uses: pypa/gh-action-pypi-publish@v1.4.1 + with: + password: ${{ secrets.pypi_password }} + packages_dir: standard/ + + - name: Publish global package + uses: pypa/gh-action-pypi-publish@v1.4.1 + with: + password: ${{ secrets.pypi_password_global }} + packages_dir: global/ diff --git a/plugins/python/pybind11/.gitmodules b/plugins/python/pybind11/.gitmodules deleted file mode 100644 index 5191885..0000000 --- a/plugins/python/pybind11/.gitmodules +++ /dev/null @@ -1,3 +0,0 @@ -[submodule "tools/clang"] - path = tools/clang - url = https://github.com/wjakob/clang-cindex-python3 diff --git a/plugins/python/pybind11/.pre-commit-config.yaml b/plugins/python/pybind11/.pre-commit-config.yaml new file mode 100644 index 0000000..85254a8 --- /dev/null +++ b/plugins/python/pybind11/.pre-commit-config.yaml @@ -0,0 +1,100 @@ +# To use: +# +# pre-commit run -a +# +# Or: +# +# pre-commit install # (runs every time you commit in git) +# +# To update this file: +# +# pre-commit autoupdate +# +# See https://github.com/pre-commit/pre-commit + +repos: +# Standard hooks +- repo: https://github.com/pre-commit/pre-commit-hooks + rev: v3.2.0 + hooks: + - id: check-added-large-files + - id: check-case-conflict + - id: check-merge-conflict + - id: check-symlinks + - id: check-yaml + - id: debug-statements + - id: end-of-file-fixer + - id: mixed-line-ending + - id: requirements-txt-fixer + - id: trailing-whitespace + - id: fix-encoding-pragma + +# Black, the code formatter, natively supports pre-commit +- repo: https://github.com/psf/black + rev: 20.8b1 + hooks: + - id: black + # By default, this ignores pyi files, though black supports them + types: [text] + files: \.pyi?$ + +# Changes tabs to spaces +- repo: https://github.com/Lucas-C/pre-commit-hooks + rev: v1.1.9 + hooks: + - id: remove-tabs + +# Flake8 also supports pre-commit natively (same author) +- repo: https://gitlab.com/pycqa/flake8 + rev: 3.8.3 + hooks: + - id: flake8 + additional_dependencies: [flake8-bugbear, pep8-naming] + exclude: ^(docs/.*|tools/.*)$ + +# CMake formatting +- repo: https://github.com/cheshirekow/cmake-format-precommit + rev: v0.6.13 + hooks: + - id: cmake-format + additional_dependencies: [pyyaml] + types: [file] + files: (\.cmake|CMakeLists.txt)(.in)?$ + +# Check static types with mypy +- repo: https://github.com/pre-commit/mirrors-mypy + rev: v0.790 + hooks: + - id: mypy + # The default Python type ignores .pyi files, so let's rerun if detected + types: [text] + files: ^pybind11.*\.pyi?$ + # Running per-file misbehaves a bit, so just run on all files, it's fast + pass_filenames: false + +# Checks the manifest for missing files (native support) +- repo: https://github.com/mgedmin/check-manifest + rev: "0.43" + hooks: + - id: check-manifest + # This is a slow hook, so only run this if --hook-stage manual is passed + stages: [manual] + additional_dependencies: [cmake, ninja] + +# The original pybind11 checks for a few C++ style items +- repo: local + hooks: + - id: disallow-caps + name: Disallow improper capitalization + language: pygrep + entry: PyBind|Numpy|Cmake|CCache + exclude: .pre-commit-config.yaml + +- repo: local + hooks: + - id: check-style + name: Classic check-style + language: system + types: + - c++ + entry: ./tools/check-style.sh diff --git a/plugins/python/pybind11/.travis.yml b/plugins/python/pybind11/.travis.yml deleted file mode 100644 index 2d3f972..0000000 --- a/plugins/python/pybind11/.travis.yml +++ /dev/null @@ -1,212 +0,0 @@ -language: cpp -dist: trusty -sudo: false -matrix: - include: - # This config does a few things: - # - Checks C++ and Python code styles (check-style.sh and flake8). - # - Makes sure sphinx can build the docs without any errors or warnings. - # - Tests setup.py sdist and install (all header files should be present). - # - Makes sure that everything still works without optional deps (numpy/scipy/eigen) and - # also tests the automatic discovery functions in CMake (Python version, C++ standard). - - os: linux - env: STYLE DOCS PIP - cache: false - before_install: - - pyenv global $(pyenv whence 2to3) # activate all python versions - - PY_CMD=python3 - - $PY_CMD -m pip install --user --upgrade pip wheel - install: - - $PY_CMD -m pip install --user --upgrade sphinx sphinx_rtd_theme breathe flake8 pep8-naming pytest - - curl -fsSL ftp://ftp.stack.nl/pub/users/dimitri/doxygen-1.8.12.linux.bin.tar.gz | tar xz - - export PATH="$PWD/doxygen-1.8.12/bin:$PATH" - script: - - tools/check-style.sh - - flake8 - - $PY_CMD -m sphinx -W -b html docs docs/.build - - | - # Make sure setup.py distributes and installs all the headers - $PY_CMD setup.py sdist - $PY_CMD -m pip install --user -U ./dist/* - installed=$($PY_CMD -c "import pybind11; print(pybind11.get_include(True) + '/pybind11')") - diff -rq $installed ./include/pybind11 - - | - # Barebones build - cmake -DCMAKE_BUILD_TYPE=Debug -DPYBIND11_WERROR=ON -DDOWNLOAD_CATCH=ON - make pytest -j 2 - make cpptest -j 2 - # The following are regular test configurations, including optional dependencies. - # With regard to each other they differ in Python version, C++ standard and compiler. - - os: linux - env: PYTHON=2.7 CPP=11 GCC=4.8 - addons: - apt: - packages: [cmake=2.\*, cmake-data=2.\*] - - os: linux - env: PYTHON=3.6 CPP=11 GCC=4.8 - addons: - apt: - sources: [deadsnakes] - packages: [python3.6-dev python3.6-venv, cmake=2.\*, cmake-data=2.\*] - - sudo: true - services: docker - env: PYTHON=2.7 CPP=14 GCC=6 CMAKE=1 - - sudo: true - services: docker - env: PYTHON=3.5 CPP=14 GCC=6 DEBUG=1 - - sudo: true - services: docker - env: PYTHON=3.6 CPP=17 GCC=7 - - os: linux - env: PYTHON=3.6 CPP=17 CLANG=5.0 - addons: - apt: - sources: [deadsnakes, llvm-toolchain-trusty-5.0, ubuntu-toolchain-r-test] - packages: [python3.6-dev python3.6-venv clang-5.0 llvm-5.0-dev, lld-5.0] - - os: osx - osx_image: xcode7.3 - env: PYTHON=2.7 CPP=14 CLANG CMAKE=1 - - os: osx - osx_image: xcode9 - env: PYTHON=3.7 CPP=14 CLANG DEBUG=1 - # Test a PyPy 2.7 build - - os: linux - env: PYPY=5.8 PYTHON=2.7 CPP=11 GCC=4.8 - addons: - apt: - packages: [libblas-dev, liblapack-dev, gfortran] - # Build in 32-bit mode and tests against the CMake-installed version - - sudo: true - services: docker - env: ARCH=i386 PYTHON=3.5 CPP=14 GCC=6 INSTALL=1 - script: - - | - $SCRIPT_RUN_PREFIX sh -c "set -e - cmake ${CMAKE_EXTRA_ARGS} -DPYBIND11_INSTALL=1 -DPYBIND11_TEST=0 - make install - cp -a tests /pybind11-tests - mkdir /build-tests && cd /build-tests - cmake ../pybind11-tests ${CMAKE_EXTRA_ARGS} -DPYBIND11_WERROR=ON - make pytest -j 2" -cache: - directories: - - $HOME/.local/bin - - $HOME/.local/lib - - $HOME/.local/include - - $HOME/Library/Python -before_install: -- | - # Configure build variables - if [ "$TRAVIS_OS_NAME" = "linux" ]; then - if [ -n "$CLANG" ]; then - export CXX=clang++-$CLANG CC=clang-$CLANG - EXTRA_PACKAGES+=" clang-$CLANG llvm-$CLANG-dev" - else - if [ -z "$GCC" ]; then GCC=4.8 - else EXTRA_PACKAGES+=" g++-$GCC" - fi - export CXX=g++-$GCC CC=gcc-$GCC - fi - if [ "$GCC" = "6" ]; then DOCKER=${ARCH:+$ARCH/}debian:stretch - elif [ "$GCC" = "7" ]; then DOCKER=debian:buster EXTRA_PACKAGES+=" catch python3-distutils" DOWNLOAD_CATCH=OFF - fi - elif [ "$TRAVIS_OS_NAME" = "osx" ]; then - export CXX=clang++ CC=clang; - fi - if [ -n "$CPP" ]; then CPP=-std=c++$CPP; fi - if [ "${PYTHON:0:1}" = "3" ]; then PY=3; fi - if [ -n "$DEBUG" ]; then CMAKE_EXTRA_ARGS+=" -DCMAKE_BUILD_TYPE=Debug"; fi -- | - # Initialize environment - set -e - if [ -n "$DOCKER" ]; then - docker pull $DOCKER - - containerid=$(docker run --detach --tty \ - --volume="$PWD":/pybind11 --workdir=/pybind11 \ - --env="CC=$CC" --env="CXX=$CXX" --env="DEBIAN_FRONTEND=$DEBIAN_FRONTEND" \ - --env=GCC_COLORS=\ \ - $DOCKER) - SCRIPT_RUN_PREFIX="docker exec --tty $containerid" - $SCRIPT_RUN_PREFIX sh -c 'for s in 0 15; do sleep $s; apt-get update && apt-get -qy dist-upgrade && break; done' - else - if [ "$PYPY" = "5.8" ]; then - curl -fSL https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.8.0-linux64.tar.bz2 | tar xj - PY_CMD=$(echo `pwd`/pypy2-v5.8.0-linux64/bin/pypy) - CMAKE_EXTRA_ARGS+=" -DPYTHON_EXECUTABLE:FILEPATH=$PY_CMD" - else - PY_CMD=python$PYTHON - if [ "$TRAVIS_OS_NAME" = "osx" ]; then - if [ "$PY" = "3" ]; then - brew install python$PY; - else - curl -fsSL https://bootstrap.pypa.io/get-pip.py | $PY_CMD - --user - fi - fi - fi - if [ "$PY" = 3 ] || [ -n "$PYPY" ]; then - $PY_CMD -m ensurepip --user - fi - $PY_CMD -m pip install --user --upgrade pip wheel - fi - set +e -install: -- | - # Install dependencies - set -e - if [ -n "$DOCKER" ]; then - if [ -n "$DEBUG" ]; then - PY_DEBUG="python$PYTHON-dbg python$PY-scipy-dbg" - CMAKE_EXTRA_ARGS+=" -DPYTHON_EXECUTABLE=/usr/bin/python${PYTHON}dm" - fi - $SCRIPT_RUN_PREFIX sh -c "for s in 0 15; do sleep \$s; \ - apt-get -qy --no-install-recommends install \ - $PY_DEBUG python$PYTHON-dev python$PY-pytest python$PY-scipy \ - libeigen3-dev libboost-dev cmake make ${EXTRA_PACKAGES} && break; done" - else - - if [ "$CLANG" = "5.0" ]; then - if ! [ -d ~/.local/include/c++/v1 ]; then - # Neither debian nor llvm provide a libc++ 5.0 deb; luckily it's fairly quick - # to build, install (and cache), so do it ourselves: - git clone --depth=1 https://github.com/llvm-mirror/llvm.git llvm-source - git clone https://github.com/llvm-mirror/libcxx.git llvm-source/projects/libcxx -b release_50 - git clone https://github.com/llvm-mirror/libcxxabi.git llvm-source/projects/libcxxabi -b release_50 - mkdir llvm-build && cd llvm-build - # Building llvm requires a newer cmake than is provided by the trusty container: - CMAKE_VER=cmake-3.8.0-Linux-x86_64 - curl https://cmake.org/files/v3.8/$CMAKE_VER.tar.gz | tar xz - ./$CMAKE_VER/bin/cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=~/.local ../llvm-source - make -j2 install-cxxabi install-cxx - cp -a include/c++/v1/*cxxabi*.h ~/.local/include/c++/v1 - cd .. - fi - export CXXFLAGS="-isystem $HOME/.local/include/c++/v1 -stdlib=libc++" - export LDFLAGS="-L$HOME/.local/lib -fuse-ld=lld-$CLANG" - export LD_LIBRARY_PATH="$HOME/.local/lib${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}" - if [ "$CPP" = "-std=c++17" ]; then CPP="-std=c++1z"; fi - fi - - export NPY_NUM_BUILD_JOBS=2 - echo "Installing pytest, numpy, scipy..." - ${PYPY:+travis_wait 30} $PY_CMD -m pip install --user --upgrade pytest numpy scipy \ - ${PYPY:+--extra-index-url https://imaginary.ca/trusty-pypi} - echo "done." - - wget -q -O eigen.tar.gz https://bitbucket.org/eigen/eigen/get/3.3.3.tar.gz - tar xzf eigen.tar.gz - export CMAKE_INCLUDE_PATH="${CMAKE_INCLUDE_PATH:+$CMAKE_INCLUDE_PATH:}$PWD/eigen-eigen-67e894c6cd8f" - fi - set +e -script: -- $SCRIPT_RUN_PREFIX cmake ${CMAKE_EXTRA_ARGS} - -DPYBIND11_PYTHON_VERSION=$PYTHON - -DPYBIND11_CPP_STANDARD=$CPP - -DPYBIND11_WERROR=${WERROR:-ON} - -DDOWNLOAD_CATCH=${DOWNLOAD_CATCH:-ON} -- $SCRIPT_RUN_PREFIX make pytest -j 2 -- $SCRIPT_RUN_PREFIX make cpptest -j 2 -- if [ -n "$CMAKE" ]; then $SCRIPT_RUN_PREFIX make test_cmake_build; fi -after_failure: cat tests/test_cmake_build/*.log* -after_script: -- if [ -n "$DOCKER" ]; then docker stop "$containerid"; docker rm "$containerid"; fi diff --git a/plugins/python/pybind11/CMakeLists.txt b/plugins/python/pybind11/CMakeLists.txt index 85ecd90..2c08ff0 100644 --- a/plugins/python/pybind11/CMakeLists.txt +++ b/plugins/python/pybind11/CMakeLists.txt @@ -5,153 +5,266 @@ # All rights reserved. Use of this source code is governed by a # BSD-style license that can be found in the LICENSE file. -cmake_minimum_required(VERSION 2.8.12) +cmake_minimum_required(VERSION 3.4) -if (POLICY CMP0048) - # cmake warns if loaded from a min-3.0-required parent dir, so silence the warning: - cmake_policy(SET CMP0048 NEW) +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) endif() -# CMake versions < 3.4.0 do not support try_compile/pthread checks without C as active language. -if(CMAKE_VERSION VERSION_LESS 3.4.0) - project(pybind11) -else() - project(pybind11 CXX) +# Extract project version from source +file(STRINGS "${CMAKE_CURRENT_SOURCE_DIR}/include/pybind11/detail/common.h" + pybind11_version_defines REGEX "#define PYBIND11_VERSION_(MAJOR|MINOR|PATCH) ") + +foreach(ver ${pybind11_version_defines}) + if(ver MATCHES [[#define PYBIND11_VERSION_(MAJOR|MINOR|PATCH) +([^ ]+)$]]) + set(PYBIND11_VERSION_${CMAKE_MATCH_1} "${CMAKE_MATCH_2}") + endif() +endforeach() + +if(PYBIND11_VERSION_PATCH MATCHES [[\.([a-zA-Z0-9]+)$]]) + set(pybind11_VERSION_TYPE "${CMAKE_MATCH_1}") +endif() +string(REGEX MATCH "^[0-9]+" PYBIND11_VERSION_PATCH "${PYBIND11_VERSION_PATCH}") + +project( + pybind11 + LANGUAGES CXX + VERSION "${PYBIND11_VERSION_MAJOR}.${PYBIND11_VERSION_MINOR}.${PYBIND11_VERSION_PATCH}") + +# Standard includes +include(GNUInstallDirs) +include(CMakePackageConfigHelpers) +include(CMakeDependentOption) + +if(NOT pybind11_FIND_QUIETLY) + message(STATUS "pybind11 v${pybind11_VERSION} ${pybind11_VERSION_TYPE}") endif() # Check if pybind11 is being used directly or via add_subdirectory -set(PYBIND11_MASTER_PROJECT OFF) -if (CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR) +if(CMAKE_SOURCE_DIR STREQUAL PROJECT_SOURCE_DIR) + ### Warn if not an out-of-source builds + if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR) + set(lines + "You are building in-place. If that is not what you intended to " + "do, you can clean the source directory with:\n" + "rm -r CMakeCache.txt CMakeFiles/ cmake_uninstall.cmake pybind11Config.cmake " + "pybind11ConfigVersion.cmake tests/CMakeFiles/\n") + message(AUTHOR_WARNING ${lines}) + endif() + set(PYBIND11_MASTER_PROJECT ON) + + if(OSX AND CMAKE_VERSION VERSION_LESS 3.7) + # Bug in macOS CMake < 3.7 is unable to download catch + message(WARNING "CMAKE 3.7+ needed on macOS to download catch, and newer HIGHLY recommended") + elseif(WINDOWS AND CMAKE_VERSION VERSION_LESS 3.8) + # Only tested with 3.8+ in CI. + message(WARNING "CMAKE 3.8+ tested on Windows, previous versions untested") + endif() + + message(STATUS "CMake ${CMAKE_VERSION}") + + if(CMAKE_CXX_STANDARD) + set(CMAKE_CXX_EXTENSIONS OFF) + set(CMAKE_CXX_STANDARD_REQUIRED ON) + endif() +else() + set(PYBIND11_MASTER_PROJECT OFF) + set(pybind11_system SYSTEM) endif() +# Options option(PYBIND11_INSTALL "Install pybind11 header files?" ${PYBIND11_MASTER_PROJECT}) -option(PYBIND11_TEST "Build pybind11 test suite?" ${PYBIND11_MASTER_PROJECT}) - -list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/tools") +option(PYBIND11_TEST "Build pybind11 test suite?" ${PYBIND11_MASTER_PROJECT}) +option(PYBIND11_NOPYTHON "Disable search for Python" OFF) -include(pybind11Tools) +cmake_dependent_option( + USE_PYTHON_INCLUDE_DIR + "Install pybind11 headers in Python include directory instead of default installation prefix" + OFF "PYBIND11_INSTALL" OFF) -# Cache variables so pybind11_add_module can be used in parent projects -set(PYBIND11_INCLUDE_DIR "${CMAKE_CURRENT_LIST_DIR}/include" CACHE INTERNAL "") -set(PYTHON_INCLUDE_DIRS ${PYTHON_INCLUDE_DIRS} CACHE INTERNAL "") -set(PYTHON_LIBRARIES ${PYTHON_LIBRARIES} CACHE INTERNAL "") -set(PYTHON_MODULE_PREFIX ${PYTHON_MODULE_PREFIX} CACHE INTERNAL "") -set(PYTHON_MODULE_EXTENSION ${PYTHON_MODULE_EXTENSION} CACHE INTERNAL "") -set(PYTHON_VERSION_MAJOR ${PYTHON_VERSION_MAJOR} CACHE INTERNAL "") -set(PYTHON_VERSION_MINOR ${PYTHON_VERSION_MINOR} CACHE INTERNAL "") +cmake_dependent_option(PYBIND11_FINDPYTHON "Force new FindPython" OFF + "NOT CMAKE_VERSION VERSION_LESS 3.12" OFF) # NB: when adding a header don't forget to also add it to setup.py set(PYBIND11_HEADERS - include/pybind11/detail/class.h - include/pybind11/detail/common.h - include/pybind11/detail/descr.h - include/pybind11/detail/init.h - include/pybind11/detail/internals.h - include/pybind11/detail/typeid.h - include/pybind11/attr.h - include/pybind11/buffer_info.h - include/pybind11/cast.h - include/pybind11/chrono.h - include/pybind11/common.h - include/pybind11/complex.h - include/pybind11/options.h - include/pybind11/eigen.h - include/pybind11/embed.h - include/pybind11/eval.h - include/pybind11/functional.h - include/pybind11/numpy.h - include/pybind11/operators.h - include/pybind11/pybind11.h - include/pybind11/pytypes.h - include/pybind11/stl.h - include/pybind11/stl_bind.h -) -string(REPLACE "include/" "${CMAKE_CURRENT_SOURCE_DIR}/include/" - PYBIND11_HEADERS "${PYBIND11_HEADERS}") - -if (PYBIND11_TEST) - add_subdirectory(tests) + include/pybind11/detail/class.h + include/pybind11/detail/common.h + include/pybind11/detail/descr.h + include/pybind11/detail/init.h + include/pybind11/detail/internals.h + include/pybind11/detail/typeid.h + include/pybind11/attr.h + include/pybind11/buffer_info.h + include/pybind11/cast.h + include/pybind11/chrono.h + include/pybind11/common.h + include/pybind11/complex.h + include/pybind11/options.h + include/pybind11/eigen.h + include/pybind11/embed.h + include/pybind11/eval.h + include/pybind11/iostream.h + include/pybind11/functional.h + include/pybind11/numpy.h + include/pybind11/operators.h + include/pybind11/pybind11.h + include/pybind11/pytypes.h + include/pybind11/stl.h + include/pybind11/stl_bind.h) + +# Compare with grep and warn if mismatched +if(PYBIND11_MASTER_PROJECT AND NOT CMAKE_VERSION VERSION_LESS 3.12) + file( + GLOB_RECURSE _pybind11_header_check + LIST_DIRECTORIES false + RELATIVE "${CMAKE_CURRENT_SOURCE_DIR}" + CONFIGURE_DEPENDS "include/pybind11/*.h") + set(_pybind11_here_only ${PYBIND11_HEADERS}) + set(_pybind11_disk_only ${_pybind11_header_check}) + list(REMOVE_ITEM _pybind11_here_only ${_pybind11_header_check}) + list(REMOVE_ITEM _pybind11_disk_only ${PYBIND11_HEADERS}) + if(_pybind11_here_only) + message(AUTHOR_WARNING "PYBIND11_HEADERS has extra files:" ${_pybind11_here_only}) + endif() + if(_pybind11_disk_only) + message(AUTHOR_WARNING "PYBIND11_HEADERS is missing files:" ${_pybind11_disk_only}) + endif() endif() -include(GNUInstallDirs) -include(CMakePackageConfigHelpers) +# CMake 3.12 added list(TRANSFORM PREPEND +# But we can't use it yet +string(REPLACE "include/" "${CMAKE_CURRENT_SOURCE_DIR}/include/" PYBIND11_HEADERS + "${PYBIND11_HEADERS}") -# extract project version from source -file(STRINGS "${PYBIND11_INCLUDE_DIR}/pybind11/detail/common.h" pybind11_version_defines - REGEX "#define PYBIND11_VERSION_(MAJOR|MINOR|PATCH) ") -foreach(ver ${pybind11_version_defines}) - if (ver MATCHES "#define PYBIND11_VERSION_(MAJOR|MINOR|PATCH) +([^ ]+)$") - set(PYBIND11_VERSION_${CMAKE_MATCH_1} "${CMAKE_MATCH_2}" CACHE INTERNAL "") - endif() -endforeach() -set(${PROJECT_NAME}_VERSION ${PYBIND11_VERSION_MAJOR}.${PYBIND11_VERSION_MINOR}.${PYBIND11_VERSION_PATCH}) -message(STATUS "pybind11 v${${PROJECT_NAME}_VERSION}") +# Cache variable so this can be used in parent projects +set(pybind11_INCLUDE_DIR + "${CMAKE_CURRENT_LIST_DIR}/include" + CACHE INTERNAL "Directory where pybind11 headers are located") -option (USE_PYTHON_INCLUDE_DIR "Install pybind11 headers in Python include directory instead of default installation prefix" OFF) -if (USE_PYTHON_INCLUDE_DIR) - file(RELATIVE_PATH CMAKE_INSTALL_INCLUDEDIR ${CMAKE_INSTALL_PREFIX} ${PYTHON_INCLUDE_DIRS}) +# Backward compatible variable for add_subdirectory mode +if(NOT PYBIND11_MASTER_PROJECT) + set(PYBIND11_INCLUDE_DIR + "${pybind11_INCLUDE_DIR}" + CACHE INTERNAL "") endif() -if(NOT (CMAKE_VERSION VERSION_LESS 3.0)) # CMake >= 3.0 - # Build an interface library target: - add_library(pybind11 INTERFACE) - add_library(pybind11::pybind11 ALIAS pybind11) # to match exported target - target_include_directories(pybind11 INTERFACE $ - $ +# Note: when creating targets, you cannot use if statements at configure time - +# you need generator expressions, because those will be placed in the target file. +# You can also place ifs *in* the Config.in, but not here. + +# This section builds targets, but does *not* touch Python + +# Build the headers-only target (no Python included): +# (long name used here to keep this from clashing in subdirectory mode) +add_library(pybind11_headers INTERFACE) +add_library(pybind11::pybind11_headers ALIAS pybind11_headers) # to match exported target +add_library(pybind11::headers ALIAS pybind11_headers) # easier to use/remember + +include("${CMAKE_CURRENT_SOURCE_DIR}/tools/pybind11Common.cmake") + +# Relative directory setting +if(USE_PYTHON_INCLUDE_DIR AND DEFINED Python_INCLUDE_DIRS) + file(RELATIVE_PATH CMAKE_INSTALL_INCLUDEDIR ${CMAKE_INSTALL_PREFIX} ${Python_INCLUDE_DIRS}) +elseif(USE_PYTHON_INCLUDE_DIR AND DEFINED PYTHON_INCLUDE_DIR) + file(RELATIVE_PATH CMAKE_INSTALL_INCLUDEDIR ${CMAKE_INSTALL_PREFIX} ${PYTHON_INCLUDE_DIRS}) +endif() + +# Fill in headers target +target_include_directories( + pybind11_headers ${pybind11_system} INTERFACE $ $) - target_compile_options(pybind11 INTERFACE $) - add_library(module INTERFACE) - add_library(pybind11::module ALIAS module) - if(NOT MSVC) - target_compile_options(module INTERFACE -fvisibility=hidden) +target_compile_features(pybind11_headers INTERFACE cxx_inheriting_constructors cxx_user_literals + cxx_right_angle_brackets) + +if(PYBIND11_INSTALL) + install(DIRECTORY ${pybind11_INCLUDE_DIR}/pybind11 DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}) + set(PYBIND11_CMAKECONFIG_INSTALL_DIR + "${CMAKE_INSTALL_DATAROOTDIR}/cmake/${PROJECT_NAME}" + CACHE STRING "install path for pybind11Config.cmake") + + configure_package_config_file( + tools/${PROJECT_NAME}Config.cmake.in "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake" + INSTALL_DESTINATION ${PYBIND11_CMAKECONFIG_INSTALL_DIR}) + + if(CMAKE_VERSION VERSION_LESS 3.14) + # Remove CMAKE_SIZEOF_VOID_P from ConfigVersion.cmake since the library does + # not depend on architecture specific settings or libraries. + set(_PYBIND11_CMAKE_SIZEOF_VOID_P ${CMAKE_SIZEOF_VOID_P}) + unset(CMAKE_SIZEOF_VOID_P) + + write_basic_package_version_file( + ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake + VERSION ${PROJECT_VERSION} + COMPATIBILITY AnyNewerVersion) + + set(CMAKE_SIZEOF_VOID_P ${_PYBIND11_CMAKE_SIZEOF_VOID_P}) + else() + # CMake 3.14+ natively supports header-only libraries + write_basic_package_version_file( + ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake + VERSION ${PROJECT_VERSION} + COMPATIBILITY AnyNewerVersion ARCH_INDEPENDENT) endif() - target_link_libraries(module INTERFACE pybind11::pybind11) - if(WIN32 OR CYGWIN) - target_link_libraries(module INTERFACE $) - elseif(APPLE) - target_link_libraries(module INTERFACE "-undefined dynamic_lookup") + + install( + FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake + ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake + tools/FindPythonLibsNew.cmake + tools/pybind11Common.cmake + tools/pybind11Tools.cmake + tools/pybind11NewTools.cmake + DESTINATION ${PYBIND11_CMAKECONFIG_INSTALL_DIR}) + + if(NOT PYBIND11_EXPORT_NAME) + set(PYBIND11_EXPORT_NAME "${PROJECT_NAME}Targets") endif() - add_library(embed INTERFACE) - add_library(pybind11::embed ALIAS embed) - target_link_libraries(embed INTERFACE pybind11::pybind11 $) + install(TARGETS pybind11_headers EXPORT "${PYBIND11_EXPORT_NAME}") + + install( + EXPORT "${PYBIND11_EXPORT_NAME}" + NAMESPACE "pybind11::" + DESTINATION ${PYBIND11_CMAKECONFIG_INSTALL_DIR}) + + # Uninstall target + if(PYBIND11_MASTER_PROJECT) + configure_file("${CMAKE_CURRENT_SOURCE_DIR}/tools/cmake_uninstall.cmake.in" + "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake" IMMEDIATE @ONLY) + + add_custom_target(uninstall COMMAND ${CMAKE_COMMAND} -P + ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake) + endif() endif() -if (PYBIND11_INSTALL) - install(DIRECTORY ${PYBIND11_INCLUDE_DIR}/pybind11 DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}) - # GNUInstallDirs "DATADIR" wrong here; CMake search path wants "share". - set(PYBIND11_CMAKECONFIG_INSTALL_DIR "share/cmake/${PROJECT_NAME}" CACHE STRING "install path for pybind11Config.cmake") - - configure_package_config_file(tools/${PROJECT_NAME}Config.cmake.in - "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake" - INSTALL_DESTINATION ${PYBIND11_CMAKECONFIG_INSTALL_DIR}) - # Remove CMAKE_SIZEOF_VOID_P from ConfigVersion.cmake since the library does - # not depend on architecture specific settings or libraries. - set(_PYBIND11_CMAKE_SIZEOF_VOID_P ${CMAKE_SIZEOF_VOID_P}) - unset(CMAKE_SIZEOF_VOID_P) - write_basic_package_version_file(${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake - VERSION ${${PROJECT_NAME}_VERSION} - COMPATIBILITY AnyNewerVersion) - set(CMAKE_SIZEOF_VOID_P ${_PYBIND11_CMAKE_SIZEOF_VOID_P}) - install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake - ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake - tools/FindPythonLibsNew.cmake - tools/pybind11Tools.cmake - DESTINATION ${PYBIND11_CMAKECONFIG_INSTALL_DIR}) - - if(NOT (CMAKE_VERSION VERSION_LESS 3.0)) - if(NOT PYBIND11_EXPORT_NAME) - set(PYBIND11_EXPORT_NAME "${PROJECT_NAME}Targets") +# BUILD_TESTING takes priority, but only if this is the master project +if(PYBIND11_MASTER_PROJECT AND DEFINED BUILD_TESTING) + if(BUILD_TESTING) + if(_pybind11_nopython) + message(FATAL_ERROR "Cannot activate tests in NOPYTHON mode") + else() + add_subdirectory(tests) endif() - - install(TARGETS pybind11 module embed - EXPORT "${PYBIND11_EXPORT_NAME}") - if(PYBIND11_MASTER_PROJECT) - install(EXPORT "${PYBIND11_EXPORT_NAME}" - NAMESPACE "${PROJECT_NAME}::" - DESTINATION ${PYBIND11_CMAKECONFIG_INSTALL_DIR}) + endif() +else() + if(PYBIND11_TEST) + if(_pybind11_nopython) + message(FATAL_ERROR "Cannot activate tests in NOPYTHON mode") + else() + add_subdirectory(tests) endif() endif() endif() + +# Better symmetry with find_package(pybind11 CONFIG) mode. +if(NOT PYBIND11_MASTER_PROJECT) + set(pybind11_FOUND + TRUE + CACHE INTERNAL "True if pybind11 and all required components found on the system") +endif() diff --git a/plugins/python/pybind11/CONTRIBUTING.md b/plugins/python/pybind11/CONTRIBUTING.md deleted file mode 100644 index 375735f..0000000 --- a/plugins/python/pybind11/CONTRIBUTING.md +++ /dev/null @@ -1,47 +0,0 @@ -Thank you for your interest in this project! Please refer to the following -sections on how to contribute code and bug reports. - -### Reporting bugs - -At the moment, this project is run in the spare time of a single person -([Wenzel Jakob](http://rgl.epfl.ch/people/wjakob)) with very limited resources -for issue tracker tickets. Thus, before submitting a question or bug report, -please take a moment of your time and ensure that your issue isn't already -discussed in the project documentation provided at -[http://pybind11.readthedocs.org/en/latest](http://pybind11.readthedocs.org/en/latest). - -Assuming that you have identified a previously unknown problem or an important -question, it's essential that you submit a self-contained and minimal piece of -code that reproduces the problem. In other words: no external dependencies, -isolate the function(s) that cause breakage, submit matched and complete C++ -and Python snippets that can be easily compiled and run on my end. - -## Pull requests -Contributions are submitted, reviewed, and accepted using Github pull requests. -Please refer to [this -article](https://help.github.com/articles/using-pull-requests) for details and -adhere to the following rules to make the process as smooth as possible: - -* Make a new branch for every feature you're working on. -* Make small and clean pull requests that are easy to review but make sure they - do add value by themselves. -* Add tests for any new functionality and run the test suite (``make pytest``) - to ensure that no existing features break. -* This project has a strong focus on providing general solutions using a - minimal amount of code, thus small pull requests are greatly preferred. - -### Licensing of contributions - -pybind11 is provided under a BSD-style license that can be found in the -``LICENSE`` file. By using, distributing, or contributing to this project, you -agree to the terms and conditions of this license. - -You are under no obligation whatsoever to provide any bug fixes, patches, or -upgrades to the features, functionality or performance of the source code -("Enhancements") to anyone; however, if you choose to make your Enhancements -available either publicly, or directly to the author of this software, without -imposing a separate written license agreement for such Enhancements, then you -hereby grant the following license: a non-exclusive, royalty-free perpetual -license to install, use, modify, prepare derivative works, incorporate into -other computer software, distribute, and sublicense such enhancements or -derivative works thereof, in binary and source code form. diff --git a/plugins/python/pybind11/ISSUE_TEMPLATE.md b/plugins/python/pybind11/ISSUE_TEMPLATE.md deleted file mode 100644 index 75df399..0000000 --- a/plugins/python/pybind11/ISSUE_TEMPLATE.md +++ /dev/null @@ -1,17 +0,0 @@ -Make sure you've completed the following steps before submitting your issue -- thank you! - -1. Check if your question has already been answered in the [FAQ](http://pybind11.readthedocs.io/en/latest/faq.html) section. -2. Make sure you've read the [documentation](http://pybind11.readthedocs.io/en/latest/). Your issue may be addressed there. -3. If those resources didn't help and you only have a short question (not a bug report), consider asking in the [Gitter chat room](https://gitter.im/pybind/Lobby). -4. If you have a genuine bug report or a more complex question which is not answered in the previous items (or not suitable for chat), please fill in the details below. -5. Include a self-contained and minimal piece of code that reproduces the problem. If that's not possible, try to make the description as clear as possible. - -*After reading, remove this checklist and the template text in parentheses below.* - -## Issue description - -(Provide a short description, state the expected behavior and what actually happens.) - -## Reproducible example code - -(The code should be minimal, have no external dependencies, isolate the function(s) that cause breakage. Submit matched and complete C++ and Python snippets that can be easily compiled and run to diagnose the issue.) diff --git a/plugins/python/pybind11/LICENSE b/plugins/python/pybind11/LICENSE index 6f15578..e466b0d 100644 --- a/plugins/python/pybind11/LICENSE +++ b/plugins/python/pybind11/LICENSE @@ -25,5 +25,5 @@ CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -Please also refer to the file CONTRIBUTING.md, which clarifies licensing of +Please also refer to the file .github/CONTRIBUTING.md, which clarifies licensing of external contributions to this project including patches, pull requests, etc. diff --git a/plugins/python/pybind11/MANIFEST.in b/plugins/python/pybind11/MANIFEST.in index 6e57bae..aed183e 100644 --- a/plugins/python/pybind11/MANIFEST.in +++ b/plugins/python/pybind11/MANIFEST.in @@ -1,2 +1,6 @@ -recursive-include include/pybind11 *.h -include LICENSE README.md CONTRIBUTING.md +recursive-include pybind11/include/pybind11 *.h +recursive-include pybind11 *.py +recursive-include pybind11 py.typed +recursive-include pybind11 *.pyi +include pybind11/share/cmake/pybind11/*.cmake +include LICENSE README.rst pyproject.toml setup.py setup.cfg diff --git a/plugins/python/pybind11/README.md b/plugins/python/pybind11/README.md deleted file mode 100644 index 17cf115..0000000 --- a/plugins/python/pybind11/README.md +++ /dev/null @@ -1,129 +0,0 @@ -![pybind11 logo](https://github.com/pybind/pybind11/raw/master/docs/pybind11-logo.png) - -# pybind11 — Seamless operability between C++11 and Python - -[![Documentation Status](https://readthedocs.org/projects/pybind11/badge/?version=master)](http://pybind11.readthedocs.org/en/master/?badge=master) -[![Documentation Status](https://readthedocs.org/projects/pybind11/badge/?version=stable)](http://pybind11.readthedocs.org/en/stable/?badge=stable) -[![Gitter chat](https://img.shields.io/gitter/room/gitterHQ/gitter.svg)](https://gitter.im/pybind/Lobby) -[![Build Status](https://travis-ci.org/pybind/pybind11.svg?branch=master)](https://travis-ci.org/pybind/pybind11) -[![Build status](https://ci.appveyor.com/api/projects/status/riaj54pn4h08xy40?svg=true)](https://ci.appveyor.com/project/wjakob/pybind11) - -**pybind11** is a lightweight header-only library that exposes C++ types in Python -and vice versa, mainly to create Python bindings of existing C++ code. Its -goals and syntax are similar to the excellent -[Boost.Python](http://www.boost.org/doc/libs/1_58_0/libs/python/doc/) library -by David Abrahams: to minimize boilerplate code in traditional extension -modules by inferring type information using compile-time introspection. - -The main issue with Boost.Python—and the reason for creating such a similar -project—is Boost. Boost is an enormously large and complex suite of utility -libraries that works with almost every C++ compiler in existence. This -compatibility has its cost: arcane template tricks and workarounds are -necessary to support the oldest and buggiest of compiler specimens. Now that -C++11-compatible compilers are widely available, this heavy machinery has -become an excessively large and unnecessary dependency. - -Think of this library as a tiny self-contained version of Boost.Python with -everything stripped away that isn't relevant for binding generation. Without -comments, the core header files only require ~4K lines of code and depend on -Python (2.7 or 3.x, or PyPy2.7 >= 5.7) and the C++ standard library. This -compact implementation was possible thanks to some of the new C++11 language -features (specifically: tuples, lambda functions and variadic templates). Since -its creation, this library has grown beyond Boost.Python in many ways, leading -to dramatically simpler binding code in many common situations. - -Tutorial and reference documentation is provided at -[http://pybind11.readthedocs.org/en/master](http://pybind11.readthedocs.org/en/master). -A PDF version of the manual is available -[here](https://media.readthedocs.org/pdf/pybind11/master/pybind11.pdf). - -## Core features -pybind11 can map the following core C++ features to Python - -- Functions accepting and returning custom data structures per value, reference, or pointer -- Instance methods and static methods -- Overloaded functions -- Instance attributes and static attributes -- Arbitrary exception types -- Enumerations -- Callbacks -- Iterators and ranges -- Custom operators -- Single and multiple inheritance -- STL data structures -- Iterators and ranges -- Smart pointers with reference counting like ``std::shared_ptr`` -- Internal references with correct reference counting -- C++ classes with virtual (and pure virtual) methods can be extended in Python - -## Goodies -In addition to the core functionality, pybind11 provides some extra goodies: - -- Python 2.7, 3.x, and PyPy (PyPy2.7 >= 5.7) are supported with an - implementation-agnostic interface. - -- It is possible to bind C++11 lambda functions with captured variables. The - lambda capture data is stored inside the resulting Python function object. - -- pybind11 uses C++11 move constructors and move assignment operators whenever - possible to efficiently transfer custom data types. - -- It's easy to expose the internal storage of custom data types through - Pythons' buffer protocols. This is handy e.g. for fast conversion between - C++ matrix classes like Eigen and NumPy without expensive copy operations. - -- pybind11 can automatically vectorize functions so that they are transparently - applied to all entries of one or more NumPy array arguments. - -- Python's slice-based access and assignment operations can be supported with - just a few lines of code. - -- Everything is contained in just a few header files; there is no need to link - against any additional libraries. - -- Binaries are generally smaller by a factor of at least 2 compared to - equivalent bindings generated by Boost.Python. A recent pybind11 conversion - of PyRosetta, an enormous Boost.Python binding project, - [reported](http://graylab.jhu.edu/RosettaCon2016/PyRosetta-4.pdf) a binary - size reduction of **5.4x** and compile time reduction by **5.8x**. - -- When supported by the compiler, two new C++14 features (relaxed constexpr and - return value deduction) are used to precompute function signatures at compile - time, leading to smaller binaries. - -- With little extra effort, C++ types can be pickled and unpickled similar to - regular Python objects. - -## Supported compilers - -1. Clang/LLVM 3.3 or newer (for Apple Xcode's clang, this is 5.0.0 or newer) -2. GCC 4.8 or newer -3. Microsoft Visual Studio 2015 Update 3 or newer -4. Intel C++ compiler 17 or newer (16 with pybind11 v2.0 and 15 with pybind11 v2.0 and a [workaround](https://github.com/pybind/pybind11/issues/276)) -5. Cygwin/GCC (tested on 2.5.1) - -## About - -This project was created by [Wenzel Jakob](http://rgl.epfl.ch/people/wjakob). -Significant features and/or improvements to the code were contributed by -Jonas Adler, -Sylvain Corlay, -Trent Houliston, -Axel Huebl, -@hulucc, -Sergey Lyskov -Johan Mabille, -Tomasz Miąsko, -Dean Moldovan, -Ben Pritchard, -Jason Rhinelander, -Boris Schäling, -Pim Schellart, -Ivan Smirnov, and -Patrick Stewart. - -### License - -pybind11 is provided under a BSD-style license that can be found in the -``LICENSE`` file. By using, distributing, or contributing to this project, -you agree to the terms and conditions of this license. diff --git a/plugins/python/pybind11/README.rst b/plugins/python/pybind11/README.rst new file mode 100644 index 0000000..1474cb9 --- /dev/null +++ b/plugins/python/pybind11/README.rst @@ -0,0 +1,175 @@ +.. figure:: https://github.com/pybind/pybind11/raw/master/docs/pybind11-logo.png + :alt: pybind11 logo + +**pybind11 — Seamless operability between C++11 and Python** + +|Latest Documentation Status| |Stable Documentation Status| |Gitter chat| |CI| |Build status| + +.. warning:: + + Combining older versions of pybind11 (< 2.6.0) with the brand-new Python + 3.9.0 will trigger undefined behavior that typically manifests as crashes + during interpreter shutdown (but could also destroy your data. **You have been + warned.**) + + We recommend that you wait for Python 3.9.1 slated for release in December, + which will include a `fix `_ + that resolves this problem. In the meantime, please update to the latest + version of pybind11 (2.6.0 or newer), which includes a temporary workaround + specifically when Python 3.9.0 is detected at runtime. + +**pybind11** is a lightweight header-only library that exposes C++ types +in Python and vice versa, mainly to create Python bindings of existing +C++ code. Its goals and syntax are similar to the excellent +`Boost.Python `_ +library by David Abrahams: to minimize boilerplate code in traditional +extension modules by inferring type information using compile-time +introspection. + +The main issue with Boost.Python—and the reason for creating such a +similar project—is Boost. Boost is an enormously large and complex suite +of utility libraries that works with almost every C++ compiler in +existence. This compatibility has its cost: arcane template tricks and +workarounds are necessary to support the oldest and buggiest of compiler +specimens. Now that C++11-compatible compilers are widely available, +this heavy machinery has become an excessively large and unnecessary +dependency. + +Think of this library as a tiny self-contained version of Boost.Python +with everything stripped away that isn’t relevant for binding +generation. Without comments, the core header files only require ~4K +lines of code and depend on Python (2.7 or 3.5+, or PyPy) and the C++ +standard library. This compact implementation was possible thanks to +some of the new C++11 language features (specifically: tuples, lambda +functions and variadic templates). Since its creation, this library has +grown beyond Boost.Python in many ways, leading to dramatically simpler +binding code in many common situations. + +Tutorial and reference documentation is provided at +`pybind11.readthedocs.io `_. +A PDF version of the manual is available +`here `_. +And the source code is always available at +`github.com/pybind/pybind11 `_. + + +Core features +------------- + + +pybind11 can map the following core C++ features to Python: + +- Functions accepting and returning custom data structures per value, + reference, or pointer +- Instance methods and static methods +- Overloaded functions +- Instance attributes and static attributes +- Arbitrary exception types +- Enumerations +- Callbacks +- Iterators and ranges +- Custom operators +- Single and multiple inheritance +- STL data structures +- Smart pointers with reference counting like ``std::shared_ptr`` +- Internal references with correct reference counting +- C++ classes with virtual (and pure virtual) methods can be extended + in Python + +Goodies +------- + +In addition to the core functionality, pybind11 provides some extra +goodies: + +- Python 2.7, 3.5+, and PyPy/PyPy3 7.3 are supported with an + implementation-agnostic interface. + +- It is possible to bind C++11 lambda functions with captured + variables. The lambda capture data is stored inside the resulting + Python function object. + +- pybind11 uses C++11 move constructors and move assignment operators + whenever possible to efficiently transfer custom data types. + +- It’s easy to expose the internal storage of custom data types through + Pythons’ buffer protocols. This is handy e.g. for fast conversion + between C++ matrix classes like Eigen and NumPy without expensive + copy operations. + +- pybind11 can automatically vectorize functions so that they are + transparently applied to all entries of one or more NumPy array + arguments. + +- Python’s slice-based access and assignment operations can be + supported with just a few lines of code. + +- Everything is contained in just a few header files; there is no need + to link against any additional libraries. + +- Binaries are generally smaller by a factor of at least 2 compared to + equivalent bindings generated by Boost.Python. A recent pybind11 + conversion of PyRosetta, an enormous Boost.Python binding project, + `reported `_ + a binary size reduction of **5.4x** and compile time reduction by + **5.8x**. + +- Function signatures are precomputed at compile time (using + ``constexpr``), leading to smaller binaries. + +- With little extra effort, C++ types can be pickled and unpickled + similar to regular Python objects. + +Supported compilers +------------------- + +1. Clang/LLVM 3.3 or newer (for Apple Xcode’s clang, this is 5.0.0 or + newer) +2. GCC 4.8 or newer +3. Microsoft Visual Studio 2015 Update 3 or newer +4. Intel C++ compiler 18 or newer + (`possible issue `_ on 20.2) +5. Cygwin/GCC (tested on 2.5.1) +6. NVCC (CUDA 11.0 tested) +7. NVIDIA PGI (20.7 and 20.9 tested) + +About +----- + +This project was created by `Wenzel +Jakob `_. Significant features and/or +improvements to the code were contributed by Jonas Adler, Lori A. Burns, +Sylvain Corlay, Eric Cousineau, Ralf Grosse-Kunstleve, Trent Houliston, Axel +Huebl, @hulucc, Yannick Jadoul, Sergey Lyskov Johan Mabille, Tomasz Miąsko, +Dean Moldovan, Ben Pritchard, Jason Rhinelander, Boris Schäling, Pim +Schellart, Henry Schreiner, Ivan Smirnov, Boris Staletic, and Patrick Stewart. + +We thank Google for a generous financial contribution to the continuous +integration infrastructure used by this project. + + +Contributing +~~~~~~~~~~~~ + +See the `contributing +guide `_ +for information on building and contributing to pybind11. + +License +~~~~~~~ + +pybind11 is provided under a BSD-style license that can be found in the +`LICENSE `_ +file. By using, distributing, or contributing to this project, you agree +to the terms and conditions of this license. + +.. |Latest Documentation Status| image:: https://readthedocs.org/projects/pybind11/badge?version=latest + :target: http://pybind11.readthedocs.org/en/latest +.. |Stable Documentation Status| image:: https://img.shields.io/badge/docs-stable-blue + :target: http://pybind11.readthedocs.org/en/stable +.. |Gitter chat| image:: https://img.shields.io/gitter/room/gitterHQ/gitter.svg + :target: https://gitter.im/pybind/Lobby +.. |CI| image:: https://github.com/pybind/pybind11/workflows/CI/badge.svg + :target: https://github.com/pybind/pybind11/actions +.. |Build status| image:: https://ci.appveyor.com/api/projects/status/riaj54pn4h08xy40?svg=true + :target: https://ci.appveyor.com/project/wjakob/pybind11 diff --git a/plugins/python/pybind11/docs/Doxyfile b/plugins/python/pybind11/docs/Doxyfile index 1b9d129..c856295 100644 --- a/plugins/python/pybind11/docs/Doxyfile +++ b/plugins/python/pybind11/docs/Doxyfile @@ -18,3 +18,6 @@ ALIASES += "endrst=\endverbatim" QUIET = YES WARNINGS = YES WARN_IF_UNDOCUMENTED = NO +PREDEFINED = DOXYGEN_SHOULD_SKIP_THIS \ + PY_MAJOR_VERSION=3 \ + PYBIND11_NOINLINE diff --git a/plugins/python/pybind11/docs/advanced/cast/chrono.rst b/plugins/python/pybind11/docs/advanced/cast/chrono.rst index 8c6b3d7..fbd4605 100644 --- a/plugins/python/pybind11/docs/advanced/cast/chrono.rst +++ b/plugins/python/pybind11/docs/advanced/cast/chrono.rst @@ -59,7 +59,7 @@ Provided conversions .. rubric:: Python to C++ -- ``datetime.datetime`` → ``std::chrono::system_clock::time_point`` +- ``datetime.datetime`` or ``datetime.date`` or ``datetime.time`` → ``std::chrono::system_clock::time_point`` Date/time objects are converted into system clock timepoints. Any timezone information is ignored and the type is treated as a naive object. diff --git a/plugins/python/pybind11/docs/advanced/cast/custom.rst b/plugins/python/pybind11/docs/advanced/cast/custom.rst index e4f99ac..a779444 100644 --- a/plugins/python/pybind11/docs/advanced/cast/custom.rst +++ b/plugins/python/pybind11/docs/advanced/cast/custom.rst @@ -29,9 +29,9 @@ The following Python snippet demonstrates the intended usage from the Python sid from example import print print(A()) -To register the necessary conversion routines, it is necessary to add -a partial overload to the ``pybind11::detail::type_caster`` template. -Although this is an implementation detail, adding partial overloads to this +To register the necessary conversion routines, it is necessary to add an +instantiation of the ``pybind11::detail::type_caster`` template. +Although this is an implementation detail, adding an instantiation of this type is explicitly allowed. .. code-block:: cpp diff --git a/plugins/python/pybind11/docs/advanced/cast/eigen.rst b/plugins/python/pybind11/docs/advanced/cast/eigen.rst index 7cbeac0..e01472d 100644 --- a/plugins/python/pybind11/docs/advanced/cast/eigen.rst +++ b/plugins/python/pybind11/docs/advanced/cast/eigen.rst @@ -37,7 +37,7 @@ that maps into the source ``numpy.ndarray`` data: this requires both that the data types are the same (e.g. ``dtype='float64'`` and ``MatrixType::Scalar`` is ``double``); and that the storage is layout compatible. The latter limitation is discussed in detail in the section below, and requires careful -consideration: by default, numpy matrices and eigen matrices are *not* storage +consideration: by default, numpy matrices and Eigen matrices are *not* storage compatible. If the numpy matrix cannot be used as is (either because its types differ, e.g. @@ -226,7 +226,7 @@ order. Failing rather than copying =========================== -The default behaviour when binding ``Eigen::Ref`` eigen +The default behaviour when binding ``Eigen::Ref`` Eigen references is to copy matrix values when passed a numpy array that does not conform to the element type of ``MatrixType`` or does not have a compatible stride layout. If you want to explicitly avoid copying in such a case, you @@ -274,7 +274,7 @@ Vectors versus column/row matrices Eigen and numpy have fundamentally different notions of a vector. In Eigen, a vector is simply a matrix with the number of columns or rows set to 1 at -compile time (for a column vector or row vector, respectively). Numpy, in +compile time (for a column vector or row vector, respectively). NumPy, in contrast, has comparable 2-dimensional 1xN and Nx1 arrays, but *also* has 1-dimensional arrays of size N. @@ -289,13 +289,13 @@ will be passed as such a column vector. If not, but the Eigen type constraints will accept a row vector, it will be passed as a row vector. (The column vector takes precedence when both are supported, for example, when passing a 1D numpy array to a MatrixXd argument). Note that the type need not be -expicitly a vector: it is permitted to pass a 1D numpy array of size 5 to an +explicitly a vector: it is permitted to pass a 1D numpy array of size 5 to an Eigen ``Matrix``: you would end up with a 1x5 Eigen matrix. Passing the same to an ``Eigen::MatrixXd`` would result in a 5x1 Eigen matrix. -When returning an eigen vector to numpy, the conversion is ambiguous: a row +When returning an Eigen vector to numpy, the conversion is ambiguous: a row vector of length 4 could be returned as either a 1D array of length 4, or as a -2D array of size 1x4. When encoutering such a situation, pybind11 compromises +2D array of size 1x4. When encountering such a situation, pybind11 compromises by considering the returned Eigen type: if it is a compile-time vector--that is, the type has either the number of rows or columns set to 1 at compile time--pybind11 converts to a 1D numpy array when returning the value. For diff --git a/plugins/python/pybind11/docs/advanced/cast/index.rst b/plugins/python/pybind11/docs/advanced/cast/index.rst index 54c1057..3ce9ea0 100644 --- a/plugins/python/pybind11/docs/advanced/cast/index.rst +++ b/plugins/python/pybind11/docs/advanced/cast/index.rst @@ -1,3 +1,5 @@ +.. _type-conversions: + Type conversions ################ @@ -39,4 +41,3 @@ the last case of the above list. chrono eigen custom - diff --git a/plugins/python/pybind11/docs/advanced/cast/overview.rst b/plugins/python/pybind11/docs/advanced/cast/overview.rst index 2ac7d30..b0e32a5 100644 --- a/plugins/python/pybind11/docs/advanced/cast/overview.rst +++ b/plugins/python/pybind11/docs/advanced/cast/overview.rst @@ -131,6 +131,8 @@ as arguments and return values, refer to the section on binding :ref:`classes`. +------------------------------------+---------------------------+-------------------------------+ | ``std::vector`` | STL dynamic array | :file:`pybind11/stl.h` | +------------------------------------+---------------------------+-------------------------------+ +| ``std::deque`` | STL double-ended queue | :file:`pybind11/stl.h` | ++------------------------------------+---------------------------+-------------------------------+ | ``std::valarray`` | STL value array | :file:`pybind11/stl.h` | +------------------------------------+---------------------------+-------------------------------+ | ``std::list`` | STL linked list | :file:`pybind11/stl.h` | diff --git a/plugins/python/pybind11/docs/advanced/cast/stl.rst b/plugins/python/pybind11/docs/advanced/cast/stl.rst index 3f30c02..70fde0d 100644 --- a/plugins/python/pybind11/docs/advanced/cast/stl.rst +++ b/plugins/python/pybind11/docs/advanced/cast/stl.rst @@ -5,7 +5,7 @@ Automatic conversion ==================== When including the additional header file :file:`pybind11/stl.h`, conversions -between ``std::vector<>``/``std::list<>``/``std::array<>``, +between ``std::vector<>``/``std::deque<>``/``std::list<>``/``std::array<>``/``std::valarray<>``, ``std::set<>``/``std::unordered_set<>``, and ``std::map<>``/``std::unordered_map<>`` and the Python ``list``, ``set`` and ``dict`` data structures are automatically enabled. The types ``std::pair<>`` @@ -157,7 +157,7 @@ the declaration before any binding code (e.g. invocations to ``class_::def()``, etc.). This macro must be specified at the top level (and outside of any namespaces), since -it instantiates a partial template overload. If your binding code consists of +it adds a template instantiation of ``type_caster``. If your binding code consists of multiple compilation units, it must be present in every file (typically via a common header) preceding any usage of ``std::vector``. Opaque types must also have a corresponding ``class_`` declaration to associate them with a name @@ -175,9 +175,6 @@ in Python, and to define a set of available operations, e.g.: }, py::keep_alive<0, 1>()) /* Keep vector alive while iterator is used */ // .... -Please take a look at the :ref:`macro_notes` before using the -``PYBIND11_MAKE_OPAQUE`` macro. - .. seealso:: The file :file:`tests/test_opaque_types.cpp` contains a complete diff --git a/plugins/python/pybind11/docs/advanced/classes.rst b/plugins/python/pybind11/docs/advanced/classes.rst index 93deeec..4927902 100644 --- a/plugins/python/pybind11/docs/advanced/classes.rst +++ b/plugins/python/pybind11/docs/advanced/classes.rst @@ -46,11 +46,10 @@ Normally, the binding code for these classes would look as follows: .. code-block:: cpp PYBIND11_MODULE(example, m) { - py::class_ animal(m, "Animal"); - animal + py::class_(m, "Animal") .def("go", &Animal::go); - py::class_(m, "Dog", animal) + py::class_(m, "Dog") .def(py::init<>()); m.def("call_go", &call_go); @@ -72,7 +71,7 @@ helper class that is defined as follows: /* Trampoline (need one for each virtual function) */ std::string go(int n_times) override { - PYBIND11_OVERLOAD_PURE( + PYBIND11_OVERRIDE_PURE( std::string, /* Return type */ Animal, /* Parent class */ go, /* Name of function in C++ (must match Python name) */ @@ -81,10 +80,10 @@ helper class that is defined as follows: } }; -The macro :func:`PYBIND11_OVERLOAD_PURE` should be used for pure virtual -functions, and :func:`PYBIND11_OVERLOAD` should be used for functions which have +The macro :c:macro:`PYBIND11_OVERRIDE_PURE` should be used for pure virtual +functions, and :c:macro:`PYBIND11_OVERRIDE` should be used for functions which have a default implementation. There are also two alternate macros -:func:`PYBIND11_OVERLOAD_PURE_NAME` and :func:`PYBIND11_OVERLOAD_NAME` which +:c:macro:`PYBIND11_OVERRIDE_PURE_NAME` and :c:macro:`PYBIND11_OVERRIDE_NAME` which take a string-valued name argument between the *Parent class* and *Name of the function* slots, which defines the name of function in Python. This is required when the C++ and Python versions of the @@ -93,15 +92,14 @@ function have different names, e.g. ``operator()`` vs ``__call__``. The binding code also needs a few minor adaptations (highlighted): .. code-block:: cpp - :emphasize-lines: 2,4,5 + :emphasize-lines: 2,3 PYBIND11_MODULE(example, m) { - py::class_ animal(m, "Animal"); - animal + py::class_(m, "Animal") .def(py::init<>()) .def("go", &Animal::go); - py::class_(m, "Dog", animal) + py::class_(m, "Dog") .def(py::init<>()); m.def("call_go", &call_go); @@ -116,15 +114,15 @@ define a constructor as usual. Bindings should be made against the actual class, not the trampoline helper class. .. code-block:: cpp + :emphasize-lines: 3 - py::class_ animal(m, "Animal"); - animal - .def(py::init<>()) - .def("go", &PyAnimal::go); /* <--- THIS IS WRONG, use &Animal::go */ + py::class_(m, "Animal"); + .def(py::init<>()) + .def("go", &PyAnimal::go); /* <--- THIS IS WRONG, use &Animal::go */ Note, however, that the above is sufficient for allowing python classes to extend ``Animal``, but not ``Dog``: see :ref:`virtual_and_inheritance` for the -necessary steps required to providing proper overload support for inherited +necessary steps required to providing proper overriding support for inherited classes. The Python session below shows how to override ``Animal::go`` and invoke it via @@ -151,13 +149,17 @@ memory for the C++ portion of the instance will be left uninitialized, which will generally leave the C++ instance in an invalid state and cause undefined behavior if the C++ instance is subsequently used. +.. versionchanged:: 2.6 + The default pybind11 metaclass will throw a ``TypeError`` when it detects + that ``__init__`` was not called by a derived class. + Here is an example: .. code-block:: python - class Dachschund(Dog): + class Dachshund(Dog): def __init__(self, name): - Dog.__init__(self) # Without this, undefind behavior may occur if the C++ portions are referenced. + Dog.__init__(self) # Without this, a TypeError is raised. self.name = name def bark(self): return "yap!" @@ -179,15 +181,24 @@ Please take a look at the :ref:`macro_notes` before using this feature. - because in these cases there is no C++ variable to reference (the value is stored in the referenced Python variable), pybind11 provides one in - the PYBIND11_OVERLOAD macros (when needed) with static storage duration. - Note that this means that invoking the overloaded method on *any* + the PYBIND11_OVERRIDE macros (when needed) with static storage duration. + Note that this means that invoking the overridden method on *any* instance will change the referenced value stored in *all* instances of that type. - Attempts to modify a non-const reference will not have the desired effect: it will change only the static cache variable, but this change will not propagate to underlying Python instance, and the change will be - replaced the next time the overload is invoked. + replaced the next time the override is invoked. + +.. warning:: + + The :c:macro:`PYBIND11_OVERRIDE` and accompanying macros used to be called + ``PYBIND11_OVERLOAD`` up until pybind11 v2.5.0, and :func:`get_override` + used to be called ``get_overload``. This naming was corrected and the older + macro and function names may soon be deprecated, in order to reduce + confusion with overloaded functions and methods and ``py::overload_cast`` + (see :ref:`classes`). .. seealso:: @@ -235,20 +246,20 @@ override the ``name()`` method): class PyAnimal : public Animal { public: using Animal::Animal; // Inherit constructors - std::string go(int n_times) override { PYBIND11_OVERLOAD_PURE(std::string, Animal, go, n_times); } - std::string name() override { PYBIND11_OVERLOAD(std::string, Animal, name, ); } + std::string go(int n_times) override { PYBIND11_OVERRIDE_PURE(std::string, Animal, go, n_times); } + std::string name() override { PYBIND11_OVERRIDE(std::string, Animal, name, ); } }; class PyDog : public Dog { public: using Dog::Dog; // Inherit constructors - std::string go(int n_times) override { PYBIND11_OVERLOAD_PURE(std::string, Dog, go, n_times); } - std::string name() override { PYBIND11_OVERLOAD(std::string, Dog, name, ); } - std::string bark() override { PYBIND11_OVERLOAD(std::string, Dog, bark, ); } + std::string go(int n_times) override { PYBIND11_OVERRIDE(std::string, Dog, go, n_times); } + std::string name() override { PYBIND11_OVERRIDE(std::string, Dog, name, ); } + std::string bark() override { PYBIND11_OVERRIDE(std::string, Dog, bark, ); } }; .. note:: - Note the trailing commas in the ``PYBIND11_OVERLOAD`` calls to ``name()`` + Note the trailing commas in the ``PYBIND11_OVERIDE`` calls to ``name()`` and ``bark()``. These are needed to portably implement a trampoline for a function that does not take any arguments. For functions that take a nonzero number of arguments, the trailing comma must be omitted. @@ -263,9 +274,9 @@ declare or override any virtual methods itself: class PyHusky : public Husky { public: using Husky::Husky; // Inherit constructors - std::string go(int n_times) override { PYBIND11_OVERLOAD_PURE(std::string, Husky, go, n_times); } - std::string name() override { PYBIND11_OVERLOAD(std::string, Husky, name, ); } - std::string bark() override { PYBIND11_OVERLOAD(std::string, Husky, bark, ); } + std::string go(int n_times) override { PYBIND11_OVERRIDE_PURE(std::string, Husky, go, n_times); } + std::string name() override { PYBIND11_OVERRIDE(std::string, Husky, name, ); } + std::string bark() override { PYBIND11_OVERRIDE(std::string, Husky, bark, ); } }; There is, however, a technique that can be used to avoid this duplication @@ -278,15 +289,15 @@ follows: template class PyAnimal : public AnimalBase { public: using AnimalBase::AnimalBase; // Inherit constructors - std::string go(int n_times) override { PYBIND11_OVERLOAD_PURE(std::string, AnimalBase, go, n_times); } - std::string name() override { PYBIND11_OVERLOAD(std::string, AnimalBase, name, ); } + std::string go(int n_times) override { PYBIND11_OVERRIDE_PURE(std::string, AnimalBase, go, n_times); } + std::string name() override { PYBIND11_OVERRIDE(std::string, AnimalBase, name, ); } }; template class PyDog : public PyAnimal { public: using PyAnimal::PyAnimal; // Inherit constructors // Override PyAnimal's pure virtual go() with a non-pure one: - std::string go(int n_times) override { PYBIND11_OVERLOAD(std::string, DogBase, go, n_times); } - std::string bark() override { PYBIND11_OVERLOAD(std::string, DogBase, bark, ); } + std::string go(int n_times) override { PYBIND11_OVERRIDE(std::string, DogBase, go, n_times); } + std::string bark() override { PYBIND11_OVERRIDE(std::string, DogBase, bark, ); } }; This technique has the advantage of requiring just one trampoline method to be @@ -300,8 +311,8 @@ The classes are then registered with pybind11 using: .. code-block:: cpp py::class_> animal(m, "Animal"); - py::class_> dog(m, "Dog"); - py::class_> husky(m, "Husky"); + py::class_> dog(m, "Dog"); + py::class_> husky(m, "Husky"); // ... add animal, dog, husky definitions Note that ``Husky`` did not require a dedicated trampoline template class at @@ -327,6 +338,10 @@ can now create a python class that inherits from ``Dog``: Extended trampoline class functionality ======================================= +.. _extended_class_functionality_forced_trampoline: + +Forced trampoline class initialisation +-------------------------------------- The trampoline classes described in the previous sections are, by default, only initialized when needed. More specifically, they are initialized when a python class actually inherits from a registered type (instead of merely creating an @@ -335,7 +350,7 @@ valid for the trampoline class but not the registered class. This is primarily for performance reasons: when the trampoline class is not needed for anything except virtual method dispatching, not initializing the trampoline class improves performance by avoiding needing to do a run-time check to see if the -inheriting python instance has an overloaded method. +inheriting python instance has an overridden method. Sometimes, however, it is useful to always initialize a trampoline class as an intermediate class that does more than just handle virtual method dispatching. @@ -354,6 +369,45 @@ ensuring member initialization and (eventual) destruction. See the file :file:`tests/test_virtual_functions.cpp` for complete examples showing both normal and forced trampoline instantiation. +Different method signatures +--------------------------- +The macro's introduced in :ref:`overriding_virtuals` cover most of the standard +use cases when exposing C++ classes to Python. Sometimes it is hard or unwieldy +to create a direct one-on-one mapping between the arguments and method return +type. + +An example would be when the C++ signature contains output arguments using +references (See also :ref:`faq_reference_arguments`). Another way of solving +this is to use the method body of the trampoline class to do conversions to the +input and return of the Python method. + +The main building block to do so is the :func:`get_override`, this function +allows retrieving a method implemented in Python from within the trampoline's +methods. Consider for example a C++ method which has the signature +``bool myMethod(int32_t& value)``, where the return indicates whether +something should be done with the ``value``. This can be made convenient on the +Python side by allowing the Python function to return ``None`` or an ``int``: + +.. code-block:: cpp + + bool MyClass::myMethod(int32_t& value) + { + pybind11::gil_scoped_acquire gil; // Acquire the GIL while in this scope. + // Try to look up the overridden method on the Python side. + pybind11::function override = pybind11::get_override(this, "myMethod"); + if (override) { // method is found + auto obj = override(value); // Call the Python function. + if (py::isinstance(obj)) { // check if it returned a Python integer type + value = obj.cast(); // Cast it and assign it to the value. + return true; // Return true; value should be used. + } else { + return false; // Python returned none, return false. + } + } + return false; // Alternatively return MyClass::myMethod(value); + } + + .. _custom_constructors: Custom constructors @@ -513,6 +567,46 @@ crucial that instances are deallocated on the C++ side to avoid memory leaks. py::class_>(m, "MyClass") .def(py::init<>()) +.. _destructors_that_call_python: + +Destructors that call Python +============================ + +If a Python function is invoked from a C++ destructor, an exception may be thrown +of type :class:`error_already_set`. If this error is thrown out of a class destructor, +``std::terminate()`` will be called, terminating the process. Class destructors +must catch all exceptions of type :class:`error_already_set` to discard the Python +exception using :func:`error_already_set::discard_as_unraisable`. + +Every Python function should be treated as *possibly throwing*. When a Python generator +stops yielding items, Python will throw a ``StopIteration`` exception, which can pass +though C++ destructors if the generator's stack frame holds the last reference to C++ +objects. + +For more information, see :ref:`the documentation on exceptions `. + +.. code-block:: cpp + + class MyClass { + public: + ~MyClass() { + try { + py::print("Even printing is dangerous in a destructor"); + py::exec("raise ValueError('This is an unraisable exception')"); + } catch (py::error_already_set &e) { + // error_context should be information about where/why the occurred, + // e.g. use __func__ to get the name of the current function + e.discard_as_unraisable(__func__); + } + } + }; + +.. note:: + + pybind11 does not support C++ destructors marked ``noexcept(false)``. + +.. versionadded:: 2.6 + .. _implicit_conversions: Implicit conversions @@ -621,6 +715,7 @@ to Python. .def(py::self *= float()) .def(float() * py::self) .def(py::self * float()) + .def(-py::self) .def("__repr__", &Vector2::toString); } @@ -726,13 +821,17 @@ An instance can now be pickled as follows: p.setExtra(15) data = pickle.dumps(p, 2) -Note that only the cPickle module is supported on Python 2.7. The second -argument to ``dumps`` is also crucial: it selects the pickle protocol version -2, since the older version 1 is not supported. Newer versions are also fine—for -instance, specify ``-1`` to always use the latest available version. Beware: -failure to follow these instructions will cause important pybind11 memory -allocation routines to be skipped during unpickling, which will likely lead to -memory corruption and/or segmentation faults. + +.. note:: + Note that only the cPickle module is supported on Python 2.7. + + The second argument to ``dumps`` is also crucial: it selects the pickle + protocol version 2, since the older version 1 is not supported. Newer + versions are also fine—for instance, specify ``-1`` to always use the + latest available version. Beware: failure to follow these instructions + will cause important pybind11 memory allocation routines to be skipped + during unpickling, which will likely lead to memory corruption and/or + segmentation faults. .. seealso:: @@ -742,6 +841,38 @@ memory corruption and/or segmentation faults. .. [#f3] http://docs.python.org/3/library/pickle.html#pickling-class-instances +Deepcopy support +================ + +Python normally uses references in assignments. Sometimes a real copy is needed +to prevent changing all copies. The ``copy`` module [#f5]_ provides these +capabilities. + +On Python 3, a class with pickle support is automatically also (deep)copy +compatible. However, performance can be improved by adding custom +``__copy__`` and ``__deepcopy__`` methods. With Python 2.7, these custom methods +are mandatory for (deep)copy compatibility, because pybind11 only supports +cPickle. + +For simple classes (deep)copy can be enabled by using the copy constructor, +which should look as follows: + +.. code-block:: cpp + + py::class_(m, "Copyable") + .def("__copy__", [](const Copyable &self) { + return Copyable(self); + }) + .def("__deepcopy__", [](const Copyable &self, py::dict) { + return Copyable(self); + }, "memo"_a); + +.. note:: + + Dynamic attributes will not be copied in this example. + +.. [#f5] https://docs.python.org/3/library/copy.html + Multiple Inheritance ==================== @@ -760,7 +891,7 @@ document)---pybind11 will automatically find out which is which. The only requirement is that the first template argument is the type to be declared. It is also permitted to inherit multiply from exported C++ classes in Python, -as well as inheriting from multiple Python and/or pybind-exported classes. +as well as inheriting from multiple Python and/or pybind11-exported classes. There is one caveat regarding the implementation of this feature: @@ -781,7 +912,7 @@ are listed. Module-local class bindings =========================== -When creating a binding for a class, pybind by default makes that binding +When creating a binding for a class, pybind11 by default makes that binding "global" across modules. What this means is that a type defined in one module can be returned from any module resulting in the same Python type. For example, this allows the following: @@ -982,7 +1113,7 @@ described trampoline: class Trampoline : public A { public: - int foo() const override { PYBIND11_OVERLOAD(int, A, foo, ); } + int foo() const override { PYBIND11_OVERRIDE(int, A, foo, ); } }; class Publicist : public A { @@ -999,3 +1130,132 @@ described trampoline: requires a more explicit function binding in the form of ``.def("foo", static_cast(&Publicist::foo));`` where ``int (A::*)() const`` is the type of ``A::foo``. + +Binding final classes +===================== + +Some classes may not be appropriate to inherit from. In C++11, classes can +use the ``final`` specifier to ensure that a class cannot be inherited from. +The ``py::is_final`` attribute can be used to ensure that Python classes +cannot inherit from a specified type. The underlying C++ type does not need +to be declared final. + +.. code-block:: cpp + + class IsFinal final {}; + + py::class_(m, "IsFinal", py::is_final()); + +When you try to inherit from such a class in Python, you will now get this +error: + +.. code-block:: pycon + + >>> class PyFinalChild(IsFinal): + ... pass + TypeError: type 'IsFinal' is not an acceptable base type + +.. note:: This attribute is currently ignored on PyPy + +.. versionadded:: 2.6 + +Custom automatic downcasters +============================ + +As explained in :ref:`inheritance`, pybind11 comes with built-in +understanding of the dynamic type of polymorphic objects in C++; that +is, returning a Pet to Python produces a Python object that knows it's +wrapping a Dog, if Pet has virtual methods and pybind11 knows about +Dog and this Pet is in fact a Dog. Sometimes, you might want to +provide this automatic downcasting behavior when creating bindings for +a class hierarchy that does not use standard C++ polymorphism, such as +LLVM [#f4]_. As long as there's some way to determine at runtime +whether a downcast is safe, you can proceed by specializing the +``pybind11::polymorphic_type_hook`` template: + +.. code-block:: cpp + + enum class PetKind { Cat, Dog, Zebra }; + struct Pet { // Not polymorphic: has no virtual methods + const PetKind kind; + int age = 0; + protected: + Pet(PetKind _kind) : kind(_kind) {} + }; + struct Dog : Pet { + Dog() : Pet(PetKind::Dog) {} + std::string sound = "woof!"; + std::string bark() const { return sound; } + }; + + namespace pybind11 { + template<> struct polymorphic_type_hook { + static const void *get(const Pet *src, const std::type_info*& type) { + // note that src may be nullptr + if (src && src->kind == PetKind::Dog) { + type = &typeid(Dog); + return static_cast(src); + } + return src; + } + }; + } // namespace pybind11 + +When pybind11 wants to convert a C++ pointer of type ``Base*`` to a +Python object, it calls ``polymorphic_type_hook::get()`` to +determine if a downcast is possible. The ``get()`` function should use +whatever runtime information is available to determine if its ``src`` +parameter is in fact an instance of some class ``Derived`` that +inherits from ``Base``. If it finds such a ``Derived``, it sets ``type += &typeid(Derived)`` and returns a pointer to the ``Derived`` object +that contains ``src``. Otherwise, it just returns ``src``, leaving +``type`` at its default value of nullptr. If you set ``type`` to a +type that pybind11 doesn't know about, no downcasting will occur, and +the original ``src`` pointer will be used with its static type +``Base*``. + +It is critical that the returned pointer and ``type`` argument of +``get()`` agree with each other: if ``type`` is set to something +non-null, the returned pointer must point to the start of an object +whose type is ``type``. If the hierarchy being exposed uses only +single inheritance, a simple ``return src;`` will achieve this just +fine, but in the general case, you must cast ``src`` to the +appropriate derived-class pointer (e.g. using +``static_cast(src)``) before allowing it to be returned as a +``void*``. + +.. [#f4] https://llvm.org/docs/HowToSetUpLLVMStyleRTTI.html + +.. note:: + + pybind11's standard support for downcasting objects whose types + have virtual methods is implemented using + ``polymorphic_type_hook`` too, using the standard C++ ability to + determine the most-derived type of a polymorphic object using + ``typeid()`` and to cast a base pointer to that most-derived type + (even if you don't know what it is) using ``dynamic_cast``. + +.. seealso:: + + The file :file:`tests/test_tagbased_polymorphic.cpp` contains a + more complete example, including a demonstration of how to provide + automatic downcasting for an entire class hierarchy without + writing one get() function for each class. + +Accessing the type object +========================= + +You can get the type object from a C++ class that has already been registered using: + +.. code-block:: python + + py::type T_py = py::type::of(); + +You can directly use ``py::type::of(ob)`` to get the type object from any python +object, just like ``type(ob)`` in Python. + +.. note:: + + Other types, like ``py::type::of()``, do not work, see :ref:`type-conversions`. + +.. versionadded:: 2.6 diff --git a/plugins/python/pybind11/docs/advanced/embedding.rst b/plugins/python/pybind11/docs/advanced/embedding.rst index 3930316..dfdaad2 100644 --- a/plugins/python/pybind11/docs/advanced/embedding.rst +++ b/plugins/python/pybind11/docs/advanced/embedding.rst @@ -18,7 +18,7 @@ information, see :doc:`/compiling`. .. code-block:: cmake - cmake_minimum_required(VERSION 3.0) + cmake_minimum_required(VERSION 3.4) project(example) find_package(pybind11 REQUIRED) # or `add_subdirectory(pybind11)` @@ -108,11 +108,11 @@ The two approaches can also be combined: Importing modules ================= -Python modules can be imported using `module::import()`: +Python modules can be imported using `module_::import()`: .. code-block:: cpp - py::module sys = py::module::import("sys"); + py::module_ sys = py::module_::import("sys"); py::print(sys.attr("path")); For convenience, the current working directory is included in ``sys.path`` when @@ -128,12 +128,12 @@ embedding the interpreter. This makes it easy to import local Python files: .. code-block:: cpp - py::module calc = py::module::import("calc"); + py::module_ calc = py::module_::import("calc"); py::object result = calc.attr("add")(1, 2); int n = result.cast(); assert(n == 3); -Modules can be reloaded using `module::reload()` if the source is modified e.g. +Modules can be reloaded using `module_::reload()` if the source is modified e.g. by an external process. This can be useful in scenarios where the application imports a user defined data processing script which needs to be updated after changes by the user. Note that this function does not reload modules recursively. @@ -153,7 +153,7 @@ like any other module. namespace py = pybind11; PYBIND11_EMBEDDED_MODULE(fast_calc, m) { - // `m` is a `py::module` which is used to bind functions and classes + // `m` is a `py::module_` which is used to bind functions and classes m.def("add", [](int i, int j) { return i + j; }); @@ -162,7 +162,7 @@ like any other module. int main() { py::scoped_interpreter guard{}; - auto fast_calc = py::module::import("fast_calc"); + auto fast_calc = py::module_::import("fast_calc"); auto result = fast_calc.attr("add")(1, 2).cast(); assert(result == 3); } @@ -196,7 +196,7 @@ naturally: int main() { py::scoped_interpreter guard{}; - auto py_module = py::module::import("py_module"); + auto py_module = py::module_::import("py_module"); auto locals = py::dict("fmt"_a="{} + {} = {}", **py_module.attr("__dict__")); assert(locals["a"].cast() == 1); diff --git a/plugins/python/pybind11/docs/advanced/exceptions.rst b/plugins/python/pybind11/docs/advanced/exceptions.rst index 3122c37..5eae556 100644 --- a/plugins/python/pybind11/docs/advanced/exceptions.rst +++ b/plugins/python/pybind11/docs/advanced/exceptions.rst @@ -1,59 +1,62 @@ Exceptions ########## -Built-in exception translation -============================== +Built-in C++ to Python exception translation +============================================ + +When Python calls C++ code through pybind11, pybind11 provides a C++ exception handler +that will trap C++ exceptions, translate them to the corresponding Python exception, +and raise them so that Python code can handle them. -When C++ code invoked from Python throws an ``std::exception``, it is -automatically converted into a Python ``Exception``. pybind11 defines multiple -special exception classes that will map to different types of Python -exceptions: +pybind11 defines translations for ``std::exception`` and its standard +subclasses, and several special exception classes that translate to specific +Python exceptions. Note that these are not actually Python exceptions, so they +cannot be examined using the Python C API. Instead, they are pure C++ objects +that pybind11 will translate the corresponding Python exception when they arrive +at its exception handler. .. tabularcolumns:: |p{0.5\textwidth}|p{0.45\textwidth}| -+--------------------------------------+------------------------------+ -| C++ exception type | Python exception type | -+======================================+==============================+ -| :class:`std::exception` | ``RuntimeError`` | -+--------------------------------------+------------------------------+ -| :class:`std::bad_alloc` | ``MemoryError`` | -+--------------------------------------+------------------------------+ -| :class:`std::domain_error` | ``ValueError`` | -+--------------------------------------+------------------------------+ -| :class:`std::invalid_argument` | ``ValueError`` | -+--------------------------------------+------------------------------+ -| :class:`std::length_error` | ``ValueError`` | -+--------------------------------------+------------------------------+ -| :class:`std::out_of_range` | ``ValueError`` | -+--------------------------------------+------------------------------+ -| :class:`std::range_error` | ``ValueError`` | -+--------------------------------------+------------------------------+ -| :class:`pybind11::stop_iteration` | ``StopIteration`` (used to | -| | implement custom iterators) | -+--------------------------------------+------------------------------+ -| :class:`pybind11::index_error` | ``IndexError`` (used to | -| | indicate out of bounds | -| | accesses in ``__getitem__``, | -| | ``__setitem__``, etc.) | -+--------------------------------------+------------------------------+ -| :class:`pybind11::value_error` | ``ValueError`` (used to | -| | indicate wrong value passed | -| | in ``container.remove(...)`` | -+--------------------------------------+------------------------------+ -| :class:`pybind11::key_error` | ``KeyError`` (used to | -| | indicate out of bounds | -| | accesses in ``__getitem__``, | -| | ``__setitem__`` in dict-like | -| | objects, etc.) | -+--------------------------------------+------------------------------+ -| :class:`pybind11::error_already_set` | Indicates that the Python | -| | exception flag has already | -| | been initialized | -+--------------------------------------+------------------------------+ - -When a Python function invoked from C++ throws an exception, it is converted -into a C++ exception of type :class:`error_already_set` whose string payload -contains a textual summary. ++--------------------------------------+--------------------------------------+ +| Exception thrown by C++ | Translated to Python exception type | ++======================================+======================================+ +| :class:`std::exception` | ``RuntimeError`` | ++--------------------------------------+--------------------------------------+ +| :class:`std::bad_alloc` | ``MemoryError`` | ++--------------------------------------+--------------------------------------+ +| :class:`std::domain_error` | ``ValueError`` | ++--------------------------------------+--------------------------------------+ +| :class:`std::invalid_argument` | ``ValueError`` | ++--------------------------------------+--------------------------------------+ +| :class:`std::length_error` | ``ValueError`` | ++--------------------------------------+--------------------------------------+ +| :class:`std::out_of_range` | ``IndexError`` | ++--------------------------------------+--------------------------------------+ +| :class:`std::range_error` | ``ValueError`` | ++--------------------------------------+--------------------------------------+ +| :class:`std::overflow_error` | ``OverflowError`` | ++--------------------------------------+--------------------------------------+ +| :class:`pybind11::stop_iteration` | ``StopIteration`` (used to implement | +| | custom iterators) | ++--------------------------------------+--------------------------------------+ +| :class:`pybind11::index_error` | ``IndexError`` (used to indicate out | +| | of bounds access in ``__getitem__``, | +| | ``__setitem__``, etc.) | ++--------------------------------------+--------------------------------------+ +| :class:`pybind11::value_error` | ``ValueError`` (used to indicate | +| | wrong value passed in | +| | ``container.remove(...)``) | ++--------------------------------------+--------------------------------------+ +| :class:`pybind11::key_error` | ``KeyError`` (used to indicate out | +| | of bounds access in ``__getitem__``, | +| | ``__setitem__`` in dict-like | +| | objects, etc.) | ++--------------------------------------+--------------------------------------+ + +Exception translation is not bidirectional. That is, *catching* the C++ +exceptions defined above above will not trap exceptions that originate from +Python. For that, catch :class:`pybind11::error_already_set`. See :ref:`below +` for further details. There is also a special exception :class:`cast_error` that is thrown by :func:`handle::call` when the input arguments cannot be converted to Python @@ -76,6 +79,19 @@ This call creates a Python exception class with the name ``PyExp`` in the given module and automatically converts any encountered exceptions of type ``CppExp`` into Python exceptions of type ``PyExp``. +It is possible to specify base class for the exception using the third +parameter, a `handle`: + +.. code-block:: cpp + + py::register_exception(module, "PyExp", PyExc_RuntimeError); + +Then `PyExp` can be caught both as `PyExp` and `RuntimeError`. + +The class objects of the built-in Python exceptions are listed in the Python +documentation on `Standard Exceptions `_. +The default base class is `PyExc_Exception`. + When more advanced exception translation is needed, the function ``py::register_exception_translator(translator)`` can be used to register functions that can translate arbitrary exception types (and which may include @@ -98,7 +114,6 @@ and use this in the associated exception translator (note: it is often useful to make this a static declaration when using it inside a lambda expression without requiring capturing). - The following example demonstrates this for a hypothetical exception classes ``MyCustomException`` and ``OtherException``: the first is translated to a custom python exception ``MyCustomError``, while the second is translated to a @@ -132,7 +147,7 @@ section. .. note:: - You must call either ``PyErr_SetString`` or a custom exception's call + Call either ``PyErr_SetString`` or a custom exception's call operator (``exc(string)``) for every exception caught in a custom exception translator. Failure to do so will cause Python to crash with ``SystemError: error return without exception set``. @@ -140,3 +155,144 @@ section. Exceptions that you do not plan to handle should simply not be caught, or may be explicitly (re-)thrown to delegate it to the other, previously-declared existing exception translators. + +.. _handling_python_exceptions_cpp: + +Handling exceptions from Python in C++ +====================================== + +When C++ calls Python functions, such as in a callback function or when +manipulating Python objects, and Python raises an ``Exception``, pybind11 +converts the Python exception into a C++ exception of type +:class:`pybind11::error_already_set` whose payload contains a C++ string textual +summary and the actual Python exception. ``error_already_set`` is used to +propagate Python exception back to Python (or possibly, handle them in C++). + +.. tabularcolumns:: |p{0.5\textwidth}|p{0.45\textwidth}| + ++--------------------------------------+--------------------------------------+ +| Exception raised in Python | Thrown as C++ exception type | ++======================================+======================================+ +| Any Python ``Exception`` | :class:`pybind11::error_already_set` | ++--------------------------------------+--------------------------------------+ + +For example: + +.. code-block:: cpp + + try { + // open("missing.txt", "r") + auto file = py::module_::import("io").attr("open")("missing.txt", "r"); + auto text = file.attr("read")(); + file.attr("close")(); + } catch (py::error_already_set &e) { + if (e.matches(PyExc_FileNotFoundError)) { + py::print("missing.txt not found"); + } else if (e.match(PyExc_PermissionError)) { + py::print("missing.txt found but not accessible"); + } else { + throw; + } + } + +Note that C++ to Python exception translation does not apply here, since that is +a method for translating C++ exceptions to Python, not vice versa. The error raised +from Python is always ``error_already_set``. + +This example illustrates this behavior: + +.. code-block:: cpp + + try { + py::eval("raise ValueError('The Ring')"); + } catch (py::value_error &boromir) { + // Boromir never gets the ring + assert(false); + } catch (py::error_already_set &frodo) { + // Frodo gets the ring + py::print("I will take the ring"); + } + + try { + // py::value_error is a request for pybind11 to raise a Python exception + throw py::value_error("The ball"); + } catch (py::error_already_set &cat) { + // cat won't catch the ball since + // py::value_error is not a Python exception + assert(false); + } catch (py::value_error &dog) { + // dog will catch the ball + py::print("Run Spot run"); + throw; // Throw it again (pybind11 will raise ValueError) + } + +Handling errors from the Python C API +===================================== + +Where possible, use :ref:`pybind11 wrappers ` instead of calling +the Python C API directly. When calling the Python C API directly, in +addition to manually managing reference counts, one must follow the pybind11 +error protocol, which is outlined here. + +After calling the Python C API, if Python returns an error, +``throw py::error_already_set();``, which allows pybind11 to deal with the +exception and pass it back to the Python interpreter. This includes calls to +the error setting functions such as ``PyErr_SetString``. + +.. code-block:: cpp + + PyErr_SetString(PyExc_TypeError, "C API type error demo"); + throw py::error_already_set(); + + // But it would be easier to simply... + throw py::type_error("pybind11 wrapper type error"); + +Alternately, to ignore the error, call `PyErr_Clear +`_. + +Any Python error must be thrown or cleared, or Python/pybind11 will be left in +an invalid state. + +.. _unraisable_exceptions: + +Handling unraisable exceptions +============================== + +If a Python function invoked from a C++ destructor or any function marked +``noexcept(true)`` (collectively, "noexcept functions") throws an exception, there +is no way to propagate the exception, as such functions may not throw. +Should they throw or fail to catch any exceptions in their call graph, +the C++ runtime calls ``std::terminate()`` to abort immediately. + +Similarly, Python exceptions raised in a class's ``__del__`` method do not +propagate, but are logged by Python as an unraisable error. In Python 3.8+, a +`system hook is triggered +`_ +and an auditing event is logged. + +Any noexcept function should have a try-catch block that traps +class:`error_already_set` (or any other exception that can occur). Note that +pybind11 wrappers around Python exceptions such as +:class:`pybind11::value_error` are *not* Python exceptions; they are C++ +exceptions that pybind11 catches and converts to Python exceptions. Noexcept +functions cannot propagate these exceptions either. A useful approach is to +convert them to Python exceptions and then ``discard_as_unraisable`` as shown +below. + +.. code-block:: cpp + + void nonthrowing_func() noexcept(true) { + try { + // ... + } catch (py::error_already_set &eas) { + // Discard the Python error using Python APIs, using the C++ magic + // variable __func__. Python already knows the type and value and of the + // exception object. + eas.discard_as_unraisable(__func__); + } catch (const std::exception &e) { + // Log and discard C++ exceptions. + third_party::log(e); + } + } + +.. versionadded:: 2.6 diff --git a/plugins/python/pybind11/docs/advanced/functions.rst b/plugins/python/pybind11/docs/advanced/functions.rst index e3acff0..ebdff9c 100644 --- a/plugins/python/pybind11/docs/advanced/functions.rst +++ b/plugins/python/pybind11/docs/advanced/functions.rst @@ -17,7 +17,7 @@ bindings for functions that return a non-trivial type. Just by looking at the type information, it is not clear whether Python should take charge of the returned value and eventually free its resources, or if this is handled on the C++ side. For this reason, pybind11 provides a several *return value policy* -annotations that can be passed to the :func:`module::def` and +annotations that can be passed to the :func:`module_::def` and :func:`class_::def` functions. The default policy is :enum:`return_value_policy::automatic`. @@ -360,7 +360,55 @@ like so: .. code-block:: cpp py::class_("MyClass") - .def("myFunction", py::arg("arg") = (SomeType *) nullptr); + .def("myFunction", py::arg("arg") = static_cast(nullptr)); + +Keyword-only arguments +====================== + +Python 3 introduced keyword-only arguments by specifying an unnamed ``*`` +argument in a function definition: + +.. code-block:: python + + def f(a, *, b): # a can be positional or via keyword; b must be via keyword + pass + + f(a=1, b=2) # good + f(b=2, a=1) # good + f(1, b=2) # good + f(1, 2) # TypeError: f() takes 1 positional argument but 2 were given + +Pybind11 provides a ``py::kw_only`` object that allows you to implement +the same behaviour by specifying the object between positional and keyword-only +argument annotations when registering the function: + +.. code-block:: cpp + + m.def("f", [](int a, int b) { /* ... */ }, + py::arg("a"), py::kw_only(), py::arg("b")); + +Note that you currently cannot combine this with a ``py::args`` argument. This +feature does *not* require Python 3 to work. + +.. versionadded:: 2.6 + +Positional-only arguments +========================= + +Python 3.8 introduced a new positional-only argument syntax, using ``/`` in the +function definition (note that this has been a convention for CPython +positional arguments, such as in ``pow()``, since Python 2). You can +do the same thing in any version of Python using ``py::pos_only()``: + +.. code-block:: cpp + + m.def("f", [](int a, int b) { /* ... */ }, + py::arg("a"), py::pos_only(), py::arg("b")); + +You now cannot give argument ``a`` by keyword. This can be combined with +keyword-only arguments, as well. + +.. versionadded:: 2.6 .. _nonconverting_arguments: @@ -438,7 +486,7 @@ To explicitly enable or disable this behaviour, using the py::class_(m, "Cat").def(py::init<>()); m.def("bark", [](Dog *dog) -> std::string { if (dog) return "woof!"; /* Called with a Dog instance */ - else return "(no dog)"; /* Called with None, d == nullptr */ + else return "(no dog)"; /* Called with None, dog == nullptr */ }, py::arg("dog").none(true)); m.def("meow", [](Cat *cat) -> std::string { // Can't be called with None argument @@ -467,6 +515,15 @@ dog)"``, while attempting to call ``meow(None)`` will raise a ``TypeError``: The default behaviour when the tag is unspecified is to allow ``None``. +.. note:: + + Even when ``.none(true)`` is specified for an argument, ``None`` will be converted to a + ``nullptr`` *only* for custom and :ref:`opaque ` types. Pointers to built-in types + (``double *``, ``int *``, ...) and STL types (``std::vector *``, ...; if ``pybind11/stl.h`` + is included) are copied when converted to C++ (see :doc:`/advanced/cast/overview`) and will + not allow ``None`` as argument. To pass optional argument of these copied types consider + using ``std::optional`` + Overload resolution order ========================= @@ -483,11 +540,13 @@ an explicit ``py::arg().noconvert()`` attribute in the function definition). If the second pass also fails a ``TypeError`` is raised. Within each pass, overloads are tried in the order they were registered with -pybind11. +pybind11. If the ``py::prepend()`` tag is added to the definition, a function +can be placed at the beginning of the overload sequence instead, allowing user +overloads to proceed built in functions. What this means in practice is that pybind11 will prefer any overload that does -not require conversion of arguments to an overload that does, but otherwise prefers -earlier-defined overloads to later-defined ones. +not require conversion of arguments to an overload that does, but otherwise +prefers earlier-defined overloads to later-defined ones. .. note:: @@ -496,3 +555,7 @@ earlier-defined overloads to later-defined ones. requiring one conversion over one requiring three, but only prioritizes overloads requiring no conversion at all to overloads that require conversion of at least one argument. + +.. versionadded:: 2.6 + + The ``py::prepend()`` tag. diff --git a/plugins/python/pybind11/docs/advanced/misc.rst b/plugins/python/pybind11/docs/advanced/misc.rst index 87481ba..b3f3b22 100644 --- a/plugins/python/pybind11/docs/advanced/misc.rst +++ b/plugins/python/pybind11/docs/advanced/misc.rst @@ -7,13 +7,32 @@ General notes regarding convenience macros ========================================== pybind11 provides a few convenience macros such as -:func:`PYBIND11_MAKE_OPAQUE` and :func:`PYBIND11_DECLARE_HOLDER_TYPE`, and -``PYBIND11_OVERLOAD_*``. Since these are "just" macros that are evaluated -in the preprocessor (which has no concept of types), they *will* get confused -by commas in a template argument such as ``PYBIND11_OVERLOAD(MyReturnValue, myFunc)``. In this case, the preprocessor assumes that the comma indicates -the beginning of the next parameter. Use a ``typedef`` to bind the template to -another name and use it in the macro to avoid this problem. +:func:`PYBIND11_DECLARE_HOLDER_TYPE` and ``PYBIND11_OVERRIDE_*``. Since these +are "just" macros that are evaluated in the preprocessor (which has no concept +of types), they *will* get confused by commas in a template argument; for +example, consider: + +.. code-block:: cpp + + PYBIND11_OVERRIDE(MyReturnType, Class, func) + +The limitation of the C preprocessor interprets this as five arguments (with new +arguments beginning after each comma) rather than three. To get around this, +there are two alternatives: you can use a type alias, or you can wrap the type +using the ``PYBIND11_TYPE`` macro: + +.. code-block:: cpp + + // Version 1: using a type alias + using ReturnType = MyReturnType; + using ClassType = Class; + PYBIND11_OVERRIDE(ReturnType, ClassType, func); + + // Version 2: using the PYBIND11_TYPE macro: + PYBIND11_OVERRIDE(PYBIND11_TYPE(MyReturnType), + PYBIND11_TYPE(Class), func) + +The ``PYBIND11_MAKE_OPAQUE`` macro does *not* require the above workarounds. .. _gil: @@ -40,7 +59,7 @@ could be realized as follows (important changes highlighted): /* Acquire GIL before calling Python code */ py::gil_scoped_acquire acquire; - PYBIND11_OVERLOAD_PURE( + PYBIND11_OVERRIDE_PURE( std::string, /* Return type */ Animal, /* Parent class */ go, /* Name of function */ @@ -113,7 +132,7 @@ However, it can be acquired as follows: .. code-block:: cpp - py::object pet = (py::object) py::module::import("basic").attr("Pet"); + py::object pet = (py::object) py::module_::import("basic").attr("Pet"); py::class_(m, "Dog", pet) .def(py::init()) @@ -127,7 +146,7 @@ has been executed: .. code-block:: cpp - py::module::import("basic"); + py::module_::import("basic"); py::class_(m, "Dog") .def(py::init()) @@ -137,7 +156,7 @@ Naturally, both methods will fail when there are cyclic dependencies. Note that pybind11 code compiled with hidden-by-default symbol visibility (e.g. via the command line flag ``-fvisibility=hidden`` on GCC/Clang), which is -required proper pybind11 functionality, can interfere with the ability to +required for proper pybind11 functionality, can interfere with the ability to access types defined in another extension module. Working around this requires manually exporting types that are accessed by multiple extension modules; pybind11 provides a macro to do just this: @@ -157,9 +176,9 @@ pybind11 version. Consider the following example: .. code-block:: cpp - auto data = (MyData *) py::get_shared_data("mydata"); + auto data = reinterpret_cast(py::get_shared_data("mydata")); if (!data) - data = (MyData *) py::set_shared_data("mydata", new MyData(42)); + data = static_cast(py::set_shared_data("mydata", new MyData(42))); If the above snippet was used in several separately compiled extension modules, the first one to be imported would create a ``MyData`` instance and associate @@ -199,12 +218,12 @@ collected: Both approaches also expose a potentially dangerous ``_cleanup`` attribute in Python, which may be undesirable from an API standpoint (a premature explicit -call from Python might lead to undefined behavior). Yet another approach that +call from Python might lead to undefined behavior). Yet another approach that avoids this issue involves weak reference with a cleanup callback: .. code-block:: cpp - // Register a callback function that is invoked when the BaseClass object is colelcted + // Register a callback function that is invoked when the BaseClass object is collected py::cpp_function cleanup_callback( [](py::handle weakref) { // perform cleanup here -- this function is called with the GIL held @@ -216,6 +235,21 @@ avoids this issue involves weak reference with a cleanup callback: // Create a weak reference with a cleanup callback and initially leak it (void) py::weakref(m.attr("BaseClass"), cleanup_callback).release(); +.. note:: + + PyPy does not garbage collect objects when the interpreter exits. An alternative + approach (which also works on CPython) is to use the :py:mod:`atexit` module [#f7]_, + for example: + + .. code-block:: cpp + + auto atexit = py::module_::import("atexit"); + atexit.attr("register")(py::cpp_function([]() { + // perform cleanup here -- this function is called with the GIL held + })); + + .. [#f7] https://docs.python.org/3/library/atexit.html + Generating documentation using Sphinx ===================================== @@ -249,9 +283,9 @@ work, it is important that all lines are indented consistently, i.e.: ---------- )mydelimiter"); -By default, pybind11 automatically generates and prepends a signature to the docstring of a function -registered with ``module::def()`` and ``class_::def()``. Sometimes this -behavior is not desirable, because you want to provide your own signature or remove +By default, pybind11 automatically generates and prepends a signature to the docstring of a function +registered with ``module_::def()`` and ``class_::def()``. Sometimes this +behavior is not desirable, because you want to provide your own signature or remove the docstring completely to exclude the function from the Sphinx documentation. The class ``options`` allows you to selectively suppress auto-generated signatures: @@ -264,9 +298,40 @@ The class ``options`` allows you to selectively suppress auto-generated signatur m.def("add", [](int a, int b) { return a + b; }, "A function which adds two numbers"); } -Note that changes to the settings affect only function bindings created during the -lifetime of the ``options`` instance. When it goes out of scope at the end of the module's init function, +Note that changes to the settings affect only function bindings created during the +lifetime of the ``options`` instance. When it goes out of scope at the end of the module's init function, the default settings are restored to prevent unwanted side effects. .. [#f4] http://www.sphinx-doc.org .. [#f5] http://github.com/pybind/python_example + +.. _avoiding-cpp-types-in-docstrings: + +Avoiding C++ types in docstrings +================================ + +Docstrings are generated at the time of the declaration, e.g. when ``.def(...)`` is called. +At this point parameter and return types should be known to pybind11. +If a custom type is not exposed yet through a ``py::class_`` constructor or a custom type caster, +its C++ type name will be used instead to generate the signature in the docstring: + +.. code-block:: text + + | __init__(...) + | __init__(self: example.Foo, arg0: ns::Bar) -> None + ^^^^^^^ + + +This limitation can be circumvented by ensuring that C++ classes are registered with pybind11 +before they are used as a parameter or return type of a function: + +.. code-block:: cpp + + PYBIND11_MODULE(example, m) { + + auto pyFoo = py::class_(m, "Foo"); + auto pyBar = py::class_(m, "Bar"); + + pyFoo.def(py::init()); + pyBar.def(py::init()); + } diff --git a/plugins/python/pybind11/docs/advanced/pycpp/numpy.rst b/plugins/python/pybind11/docs/advanced/pycpp/numpy.rst index 50e5533..19ed10b 100644 --- a/plugins/python/pybind11/docs/advanced/pycpp/numpy.rst +++ b/plugins/python/pybind11/docs/advanced/pycpp/numpy.rst @@ -41,7 +41,7 @@ completely avoid copy operations with Python expressions like py::format_descriptor::format(), /* Python struct-style format descriptor */ 2, /* Number of dimensions */ { m.rows(), m.cols() }, /* Buffer dimensions */ - { sizeof(float) * m.rows(), /* Strides (in bytes) for each index */ + { sizeof(float) * m.cols(), /* Strides (in bytes) for each index */ sizeof(float) } ); }); @@ -57,17 +57,17 @@ specification. struct buffer_info { void *ptr; - ssize_t itemsize; + py::ssize_t itemsize; std::string format; - ssize_t ndim; - std::vector shape; - std::vector strides; + py::ssize_t ndim; + std::vector shape; + std::vector strides; }; To create a C++ function that can take a Python buffer object as an argument, simply use the type ``py::buffer`` as one of its arguments. Buffers can exist in a great variety of configurations, hence some safety checks are usually -necessary in the function body. Below, you can see an basic example on how to +necessary in the function body. Below, you can see a basic example on how to define a custom constructor for the Eigen double precision matrix (``Eigen::MatrixXd``) type, which supports initialization from compatible buffer objects (e.g. a NumPy matrix). @@ -81,7 +81,7 @@ buffer objects (e.g. a NumPy matrix). constexpr bool rowMajor = Matrix::Flags & Eigen::RowMajorBit; py::class_(m, "Matrix", py::buffer_protocol()) - .def("__init__", [](Matrix &m, py::buffer b) { + .def(py::init([](py::buffer b) { typedef Eigen::Stride Strides; /* Request a buffer descriptor from Python */ @@ -101,8 +101,8 @@ buffer objects (e.g. a NumPy matrix). auto map = Eigen::Map( static_cast(info.ptr), info.shape[0], info.shape[1], strides); - new (&m) Matrix(map); - }); + return Matrix(map); + })); For reference, the ``def_buffer()`` call for this Eigen data type should look as follows: @@ -274,9 +274,9 @@ simply using ``vectorize``). py::buffer_info buf3 = result.request(); - double *ptr1 = (double *) buf1.ptr, - *ptr2 = (double *) buf2.ptr, - *ptr3 = (double *) buf3.ptr; + double *ptr1 = static_cast(buf1.ptr); + double *ptr2 = static_cast(buf2.ptr); + double *ptr3 = static_cast(buf3.ptr); for (size_t idx = 0; idx < buf1.shape[0]; idx++) ptr3[idx] = ptr1[idx] + ptr2[idx]; @@ -309,17 +309,17 @@ where ``N`` gives the required dimensionality of the array: m.def("sum_3d", [](py::array_t x) { auto r = x.unchecked<3>(); // x must have ndim = 3; can be non-writeable double sum = 0; - for (ssize_t i = 0; i < r.shape(0); i++) - for (ssize_t j = 0; j < r.shape(1); j++) - for (ssize_t k = 0; k < r.shape(2); k++) + for (py::ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t j = 0; j < r.shape(1); j++) + for (py::ssize_t k = 0; k < r.shape(2); k++) sum += r(i, j, k); return sum; }); m.def("increment_3d", [](py::array_t x) { auto r = x.mutable_unchecked<3>(); // Will throw if ndim != 3 or flags.writeable is false - for (ssize_t i = 0; i < r.shape(0); i++) - for (ssize_t j = 0; j < r.shape(1); j++) - for (ssize_t k = 0; k < r.shape(2); k++) + for (py::ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t j = 0; j < r.shape(1); j++) + for (py::ssize_t k = 0; k < r.shape(2); k++) r(i, j, k) += 1.0; }, py::arg().noconvert()); @@ -364,3 +364,73 @@ uses of ``py::array``: The file :file:`tests/test_numpy_array.cpp` contains additional examples demonstrating the use of this feature. + +Ellipsis +======== + +Python 3 provides a convenient ``...`` ellipsis notation that is often used to +slice multidimensional arrays. For instance, the following snippet extracts the +middle dimensions of a tensor with the first and last index set to zero. +In Python 2, the syntactic sugar ``...`` is not available, but the singleton +``Ellipsis`` (of type ``ellipsis``) can still be used directly. + +.. code-block:: python + + a = # a NumPy array + b = a[0, ..., 0] + +The function ``py::ellipsis()`` function can be used to perform the same +operation on the C++ side: + +.. code-block:: cpp + + py::array a = /* A NumPy array */; + py::array b = a[py::make_tuple(0, py::ellipsis(), 0)]; + +.. versionchanged:: 2.6 + ``py::ellipsis()`` is now also avaliable in Python 2. + +Memory view +=========== + +For a case when we simply want to provide a direct accessor to C/C++ buffer +without a concrete class object, we can return a ``memoryview`` object. Suppose +we wish to expose a ``memoryview`` for 2x4 uint8_t array, we can do the +following: + +.. code-block:: cpp + + const uint8_t buffer[] = { + 0, 1, 2, 3, + 4, 5, 6, 7 + }; + m.def("get_memoryview2d", []() { + return py::memoryview::from_buffer( + buffer, // buffer pointer + { 2, 4 }, // shape (rows, cols) + { sizeof(uint8_t) * 4, sizeof(uint8_t) } // strides in bytes + ); + }) + +This approach is meant for providing a ``memoryview`` for a C/C++ buffer not +managed by Python. The user is responsible for managing the lifetime of the +buffer. Using a ``memoryview`` created in this way after deleting the buffer in +C++ side results in undefined behavior. + +We can also use ``memoryview::from_memory`` for a simple 1D contiguous buffer: + +.. code-block:: cpp + + m.def("get_memoryview1d", []() { + return py::memoryview::from_memory( + buffer, // buffer pointer + sizeof(uint8_t) * 8 // buffer size + ); + }) + +.. note:: + + ``memoryview::from_memory`` is not available in Python 2. + +.. versionchanged:: 2.6 + ``memoryview::from_memory`` added. diff --git a/plugins/python/pybind11/docs/advanced/pycpp/object.rst b/plugins/python/pybind11/docs/advanced/pycpp/object.rst index 117131e..6c7525c 100644 --- a/plugins/python/pybind11/docs/advanced/pycpp/object.rst +++ b/plugins/python/pybind11/docs/advanced/pycpp/object.rst @@ -1,6 +1,8 @@ Python types ############ +.. _wrappers: + Available wrappers ================== @@ -13,6 +15,13 @@ Available types include :class:`handle`, :class:`object`, :class:`bool_`, :class:`iterable`, :class:`iterator`, :class:`function`, :class:`buffer`, :class:`array`, and :class:`array_t`. +.. warning:: + + Be sure to review the :ref:`pytypes_gotchas` before using this heavily in + your C++ API. + +.. _casting_back_and_forth: + Casting back and forth ====================== @@ -47,20 +56,21 @@ This example obtains a reference to the Python ``Decimal`` class. .. code-block:: cpp // Equivalent to "from decimal import Decimal" - py::object Decimal = py::module::import("decimal").attr("Decimal"); + py::object Decimal = py::module_::import("decimal").attr("Decimal"); .. code-block:: cpp // Try to import scipy - py::object scipy = py::module::import("scipy"); + py::object scipy = py::module_::import("scipy"); return scipy.attr("__version__"); + .. _calling_python_functions: Calling Python functions ======================== -It is also possible to call Python classes, functions and methods +It is also possible to call Python classes, functions and methods via ``operator()``. .. code-block:: cpp @@ -71,11 +81,11 @@ via ``operator()``. .. code-block:: cpp // Use Python to make our directories - py::object os = py::module::import("os"); + py::object os = py::module_::import("os"); py::object makedirs = os.attr("makedirs"); makedirs("/tmp/path/to/somewhere"); -One can convert the result obtained from Python to a pure C++ version +One can convert the result obtained from Python to a pure C++ version if a ``py::class_`` or type conversion is defined. .. code-block:: cpp @@ -99,8 +109,8 @@ Python method. py::print(py::str(exp_pi)); In the example above ``pi.attr("exp")`` is a *bound method*: it will always call -the method for that same instance of the class. Alternately one can create an -*unbound method* via the Python class (instead of instance) and pass the ``self`` +the method for that same instance of the class. Alternately one can create an +*unbound method* via the Python class (instead of instance) and pass the ``self`` object explicitly, followed by other arguments. .. code-block:: cpp @@ -168,3 +178,74 @@ Generalized unpacking according to PEP448_ is also supported: Python functions from C++, including keywords arguments and unpacking. .. _PEP448: https://www.python.org/dev/peps/pep-0448/ + +.. _implicit_casting: + +Implicit casting +================ + +When using the C++ interface for Python types, or calling Python functions, +objects of type :class:`object` are returned. It is possible to invoke implicit +conversions to subclasses like :class:`dict`. The same holds for the proxy objects +returned by ``operator[]`` or ``obj.attr()``. +Casting to subtypes improves code readability and allows values to be passed to +C++ functions that require a specific subtype rather than a generic :class:`object`. + +.. code-block:: cpp + + #include + using namespace pybind11::literals; + + py::module_ os = py::module_::import("os"); + py::module_ path = py::module_::import("os.path"); // like 'import os.path as path' + py::module_ np = py::module_::import("numpy"); // like 'import numpy as np' + + py::str curdir_abs = path.attr("abspath")(path.attr("curdir")); + py::print(py::str("Current directory: ") + curdir_abs); + py::dict environ = os.attr("environ"); + py::print(environ["HOME"]); + py::array_t arr = np.attr("ones")(3, "dtype"_a="float32"); + py::print(py::repr(arr + py::int_(1))); + +These implicit conversions are available for subclasses of :class:`object`; there +is no need to call ``obj.cast()`` explicitly as for custom classes, see +:ref:`casting_back_and_forth`. + +.. note:: + If a trivial conversion via move constructor is not possible, both implicit and + explicit casting (calling ``obj.cast()``) will attempt a "rich" conversion. + For instance, ``py::list env = os.attr("environ");`` will succeed and is + equivalent to the Python code ``env = list(os.environ)`` that produces a + list of the dict keys. + +.. TODO: Adapt text once PR #2349 has landed + +Handling exceptions +=================== + +Python exceptions from wrapper classes will be thrown as a ``py::error_already_set``. +See :ref:`Handling exceptions from Python in C++ +` for more information on handling exceptions +raised when calling C++ wrapper classes. + +.. _pytypes_gotchas: + +Gotchas +======= + +Default-Constructed Wrappers +---------------------------- + +When a wrapper type is default-constructed, it is **not** a valid Python object (i.e. it is not ``py::none()``). It is simply the same as +``PyObject*`` null pointer. To check for this, use +``static_cast(my_wrapper)``. + +Assigning py::none() to wrappers +-------------------------------- + +You may be tempted to use types like ``py::str`` and ``py::dict`` in C++ +signatures (either pure C++, or in bound signatures), and assign them default +values of ``py::none()``. However, in a best case scenario, it will fail fast +because ``None`` is not convertible to that type (e.g. ``py::dict``), or in a +worse case scenario, it will silently work but corrupt the types you want to +work with (e.g. ``py::str(py::none())`` will yield ``"None"`` in Python). diff --git a/plugins/python/pybind11/docs/advanced/pycpp/utilities.rst b/plugins/python/pybind11/docs/advanced/pycpp/utilities.rst index 369e7c9..c15051f 100644 --- a/plugins/python/pybind11/docs/advanced/pycpp/utilities.rst +++ b/plugins/python/pybind11/docs/advanced/pycpp/utilities.rst @@ -42,7 +42,7 @@ redirects output to the corresponding Python streams: m.def("noisy_func", []() { py::scoped_ostream_redirect stream( std::cout, // std::ostream& - py::module::import("sys").attr("stdout") // Python output + py::module_::import("sys").attr("stdout") // Python output ); call_noisy_func(); }); @@ -104,7 +104,7 @@ can be used. ... // Evaluate in scope of main module - py::object scope = py::module::import("__main__").attr("__dict__"); + py::object scope = py::module_::import("__main__").attr("__dict__"); // Evaluate an isolated expression int result = py::eval("my_variable + 10", scope).cast(); diff --git a/plugins/python/pybind11/docs/basics.rst b/plugins/python/pybind11/docs/basics.rst index 447250e..b9d386c 100644 --- a/plugins/python/pybind11/docs/basics.rst +++ b/plugins/python/pybind11/docs/basics.rst @@ -11,11 +11,11 @@ included set of test cases. Compiling the test cases ======================== -Linux/MacOS +Linux/macOS ----------- On Linux you'll need to install the **python-dev** or **python3-dev** packages as -well as **cmake**. On Mac OS, the included python version works out of the box, +well as **cmake**. On macOS, the included python version works out of the box, but **cmake** must still be installed. After installing the prerequisites, run @@ -35,6 +35,14 @@ Windows On Windows, only **Visual Studio 2015** and newer are supported since pybind11 relies on various C++11 language features that break older versions of Visual Studio. +.. Note:: + + To use the C++17 in Visual Studio 2017 (MSVC 14.1), pybind11 requires the flag + ``/permissive-`` to be passed to the compiler `to enforce standard conformance`_. When + building with Visual Studio 2019, this is not strictly necessary, but still advised. + +.. _`to enforce standard conformance`: https://docs.microsoft.com/en-us/cpp/build/reference/permissive-standards-conformance?view=vs-2017 + To compile and run the tests: .. code-block:: batch @@ -110,8 +118,8 @@ a file named :file:`example.cpp` with the following contents: The :func:`PYBIND11_MODULE` macro creates a function that will be called when an ``import`` statement is issued from within Python. The module name (``example``) is given as the first macro argument (it should not be in quotes). The second -argument (``m``) defines a variable of type :class:`py::module ` which -is the main interface for creating bindings. The method :func:`module::def` +argument (``m``) defines a variable of type :class:`py::module_ ` which +is the main interface for creating bindings. The method :func:`module_::def` generates binding code that exposes the ``add()`` function to Python. .. note:: @@ -130,7 +138,7 @@ On Linux, the above example can be compiled using the following command: $ c++ -O3 -Wall -shared -std=c++11 -fPIC `python3 -m pybind11 --includes` example.cpp -o example`python3-config --extension-suffix` -For more details on the required compiler flags on Linux and MacOS, see +For more details on the required compiler flags on Linux and macOS, see :ref:`building_manually`. For complete cross-platform compilation instructions, refer to the :ref:`compiling` page. @@ -164,7 +172,7 @@ load and execute the example: Keyword arguments ================= -With a simple modification code, it is possible to inform Python about the +With a simple code modification, it is possible to inform Python about the names of the arguments ("i" and "j" in this case). .. code-block:: cpp @@ -173,7 +181,7 @@ names of the arguments ("i" and "j" in this case). py::arg("i"), py::arg("j")); :class:`arg` is one of several special tag classes which can be used to pass -metadata into :func:`module::def`. With this modified binding code, we can now +metadata into :func:`module_::def`. With this modified binding code, we can now call the function using keyword arguments, which is a more readable alternative particularly for functions taking many parameters: diff --git a/plugins/python/pybind11/docs/benchmark.py b/plugins/python/pybind11/docs/benchmark.py index 6dc0604..33d78fb 100644 --- a/plugins/python/pybind11/docs/benchmark.py +++ b/plugins/python/pybind11/docs/benchmark.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- import random import os import time @@ -13,7 +14,7 @@ def generate_dummy_code_pybind11(nclasses=10): for cl in range(nclasses): decl += "class cl%03i;\n" % cl - decl += '\n' + decl += "\n" for cl in range(nclasses): decl += "class cl%03i {\n" % cl @@ -21,18 +22,17 @@ def generate_dummy_code_pybind11(nclasses=10): bindings += ' py::class_(m, "cl%03i")\n' % (cl, cl) for fn in range(nfns): ret = random.randint(0, nclasses - 1) - params = [random.randint(0, nclasses - 1) for i in range(nargs)] + params = [random.randint(0, nclasses - 1) for i in range(nargs)] decl += " cl%03i *fn_%03i(" % (ret, fn) decl += ", ".join("cl%03i *" % p for p in params) decl += ");\n" - bindings += ' .def("fn_%03i", &cl%03i::fn_%03i)\n' % \ - (fn, cl, fn) + bindings += ' .def("fn_%03i", &cl%03i::fn_%03i)\n' % (fn, cl, fn) decl += "};\n\n" - bindings += ' ;\n' + bindings += " ;\n" result = "#include \n\n" result += "namespace py = pybind11;\n\n" - result += decl + '\n' + result += decl + "\n" result += "PYBIND11_MODULE(example, m) {\n" result += bindings result += "}" @@ -45,7 +45,7 @@ def generate_dummy_code_boost(nclasses=10): for cl in range(nclasses): decl += "class cl%03i;\n" % cl - decl += '\n' + decl += "\n" for cl in range(nclasses): decl += "class cl%03i {\n" % cl @@ -53,18 +53,20 @@ def generate_dummy_code_boost(nclasses=10): bindings += ' py::class_("cl%03i")\n' % (cl, cl) for fn in range(nfns): ret = random.randint(0, nclasses - 1) - params = [random.randint(0, nclasses - 1) for i in range(nargs)] + params = [random.randint(0, nclasses - 1) for i in range(nargs)] decl += " cl%03i *fn_%03i(" % (ret, fn) decl += ", ".join("cl%03i *" % p for p in params) decl += ");\n" - bindings += ' .def("fn_%03i", &cl%03i::fn_%03i, py::return_value_policy())\n' % \ - (fn, cl, fn) + bindings += ( + ' .def("fn_%03i", &cl%03i::fn_%03i, py::return_value_policy())\n' + % (fn, cl, fn) + ) decl += "};\n\n" - bindings += ' ;\n' + bindings += " ;\n" result = "#include \n\n" result += "namespace py = boost::python;\n\n" - result += decl + '\n' + result += decl + "\n" result += "BOOST_PYTHON_MODULE(example) {\n" result += bindings result += "}" @@ -72,17 +74,19 @@ def generate_dummy_code_boost(nclasses=10): for codegen in [generate_dummy_code_pybind11, generate_dummy_code_boost]: - print ("{") + print("{") for i in range(0, 10): nclasses = 2 ** i with open("test.cpp", "w") as f: f.write(codegen(nclasses)) n1 = dt.datetime.now() - os.system("g++ -Os -shared -rdynamic -undefined dynamic_lookup " + os.system( + "g++ -Os -shared -rdynamic -undefined dynamic_lookup " "-fvisibility=hidden -std=c++14 test.cpp -I include " - "-I /System/Library/Frameworks/Python.framework/Headers -o test.so") + "-I /System/Library/Frameworks/Python.framework/Headers -o test.so" + ) n2 = dt.datetime.now() elapsed = (n2 - n1).total_seconds() - size = os.stat('test.so').st_size + size = os.stat("test.so").st_size print(" {%i, %f, %i}," % (nclasses * nfns, elapsed, size)) - print ("}") + print("}") diff --git a/plugins/python/pybind11/docs/benchmark.rst b/plugins/python/pybind11/docs/benchmark.rst index 59d533d..02c2ccd 100644 --- a/plugins/python/pybind11/docs/benchmark.rst +++ b/plugins/python/pybind11/docs/benchmark.rst @@ -93,5 +93,3 @@ favor. .. only:: latex .. image:: pybind11_vs_boost_python2.png - - diff --git a/plugins/python/pybind11/docs/changelog.rst b/plugins/python/pybind11/docs/changelog.rst index 1a7fd56..561baa5 100644 --- a/plugins/python/pybind11/docs/changelog.rst +++ b/plugins/python/pybind11/docs/changelog.rst @@ -6,6 +6,497 @@ Changelog Starting with version 1.8.0, pybind11 releases use a `semantic versioning `_ policy. +v2.6.1 (Nov 11, 2020) +--------------------- + +* ``py::exec``, ``py::eval``, and ``py::eval_file`` now add the builtins module + as ``"__builtins__"`` to their ``globals`` argument, better matching ``exec`` + and ``eval`` in pure Python. + `#2616 `_ + +* ``setup_helpers`` will no longer set a minimum macOS version lower than the + current version. + `#2622 `_ + +* Allow deleting static properties. + `#2629 `_ + +* Seal a leak in ``def_buffer``, cleaning up the ``capture`` object after the + ``class_`` object goes out of scope. + `#2634 `_ + +* ``pybind11_INCLUDE_DIRS`` was incorrect, potentially causing a regression if + it was expected to include ``PYTHON_INCLUDE_DIRS`` (please use targets + instead). + `#2636 `_ + +* Added parameter names to the ``py::enum_`` constructor and methods, avoiding + ``arg0`` in the generated docstrings. + `#2637 `_ + +* Added ``needs_recompile`` optional function to the ``ParallelCompiler`` + helper, to allow a recompile to be skipped based on a user-defined function. + `#2643 `_ + + +v2.6.0 (Oct 21, 2020) +--------------------- + +See :ref:`upgrade-guide-2.6` for help upgrading to the new version. + +New features: + +* Keyword-only arguments supported in Python 2 or 3 with ``py::kw_only()``. + `#2100 `_ + +* Positional-only arguments supported in Python 2 or 3 with ``py::pos_only()``. + `#2459 `_ + +* ``py::is_final()`` class modifier to block subclassing (CPython only). + `#2151 `_ + +* Added ``py::prepend()``, allowing a function to be placed at the beginning of + the overload chain. + `#1131 `_ + +* Access to the type object now provided with ``py::type::of()`` and + ``py::type::of(h)``. + `#2364 `_ + +* Perfect forwarding support for methods. + `#2048 `_ + +* Added ``py::error_already_set::discard_as_unraisable()``. + `#2372 `_ + +* ``py::hash`` is now public. + `#2217 `_ + +* ``py::class_`` is now supported. Note that writing to one data + member of the union and reading another (type punning) is UB in C++. Thus + pybind11-bound enums should never be used for such conversions. + `#2320 `_. + +* Classes now check local scope when registering members, allowing a subclass + to have a member with the same name as a parent (such as an enum). + `#2335 `_ + +Code correctness features: + +* Error now thrown when ``__init__`` is forgotten on subclasses. + `#2152 `_ + +* Throw error if conversion to a pybind11 type if the Python object isn't a + valid instance of that type, such as ``py::bytes(o)`` when ``py::object o`` + isn't a bytes instance. + `#2349 `_ + +* Throw if conversion to ``str`` fails. + `#2477 `_ + + +API changes: + +* ``py::module`` was renamed ``py::module_`` to avoid issues with C++20 when + used unqualified, but an alias ``py::module`` is provided for backward + compatibility. + `#2489 `_ + +* Public constructors for ``py::module_`` have been deprecated; please use + ``pybind11::module_::create_extension_module`` if you were using the public + constructor (fairly rare after ``PYBIND11_MODULE`` was introduced). + `#2552 `_ + +* ``PYBIND11_OVERLOAD*`` macros and ``get_overload`` function replaced by + correctly-named ``PYBIND11_OVERRIDE*`` and ``get_override``, fixing + inconsistencies in the presence of a closing ``;`` in these macros. + ``get_type_overload`` is deprecated. + `#2325 `_ + +Packaging / building improvements: + +* The Python package was reworked to be more powerful and useful. + `#2433 `_ + + * :ref:`build-setuptools` is easier thanks to a new + ``pybind11.setup_helpers`` module, which provides utilities to use + setuptools with pybind11. It can be used via PEP 518, ``setup_requires``, + or by directly importing or copying ``setup_helpers.py`` into your project. + + * CMake configuration files are now included in the Python package. Use + ``pybind11.get_cmake_dir()`` or ``python -m pybind11 --cmakedir`` to get + the directory with the CMake configuration files, or include the + site-packages location in your ``CMAKE_MODULE_PATH``. Or you can use the + new ``pybind11[global]`` extra when you install ``pybind11``, which + installs the CMake files and headers into your base environment in the + standard location. + + * ``pybind11-config`` is another way to write ``python -m pybind11`` if you + have your PATH set up. + + * Added external typing support to the helper module, code from + ``import pybind11`` can now be type checked. + `#2588 `_ + +* Minimum CMake required increased to 3.4. + `#2338 `_ and + `#2370 `_ + + * Full integration with CMake’s C++ standard system and compile features + replaces ``PYBIND11_CPP_STANDARD``. + + * Generated config file is now portable to different Python/compiler/CMake + versions. + + * Virtual environments prioritized if ``PYTHON_EXECUTABLE`` is not set + (``venv``, ``virtualenv``, and ``conda``) (similar to the new FindPython + mode). + + * Other CMake features now natively supported, like + ``CMAKE_INTERPROCEDURAL_OPTIMIZATION``, ``set(CMAKE_CXX_VISIBILITY_PRESET + hidden)``. + + * ``CUDA`` as a language is now supported. + + * Helper functions ``pybind11_strip``, ``pybind11_extension``, + ``pybind11_find_import`` added, see :doc:`cmake/index`. + + * Optional :ref:`find-python-mode` and :ref:`nopython-mode` with CMake. + `#2370 `_ + +* Uninstall target added. + `#2265 `_ and + `#2346 `_ + +* ``pybind11_add_module()`` now accepts an optional ``OPT_SIZE`` flag that + switches the binding target to size-based optimization if the global build + type can not always be fixed to ``MinSizeRel`` (except in debug mode, where + optimizations remain disabled). ``MinSizeRel`` or this flag reduces binary + size quite substantially (~25% on some platforms). + `#2463 `_ + +Smaller or developer focused features and fixes: + +* Moved ``mkdoc.py`` to a new repo, `pybind11-mkdoc`_. There are no longer + submodules in the main repo. + +* ``py::memoryview`` segfault fix and update, with new + ``py::memoryview::from_memory`` in Python 3, and documentation. + `#2223 `_ + +* Fix for ``buffer_info`` on Python 2. + `#2503 `_ + +* If ``__eq__`` defined but not ``__hash__``, ``__hash__`` is now set to + ``None``. + `#2291 `_ + +* ``py::ellipsis`` now also works on Python 2. + `#2360 `_ + +* Pointer to ``std::tuple`` & ``std::pair`` supported in cast. + `#2334 `_ + +* Small fixes in NumPy support. ``py::array`` now uses ``py::ssize_t`` as first + argument type. + `#2293 `_ + +* Added missing signature for ``py::array``. + `#2363 `_ + +* ``unchecked_mutable_reference`` has access to operator ``()`` and ``[]`` when + const. + `#2514 `_ + +* ``py::vectorize`` is now supported on functions that return void. + `#1969 `_ + +* ``py::capsule`` supports ``get_pointer`` and ``set_pointer``. + `#1131 `_ + +* Fix crash when different instances share the same pointer of the same type. + `#2252 `_ + +* Fix for ``py::len`` not clearing Python's error state when it fails and throws. + `#2575 `_ + +* Bugfixes related to more extensive testing, new GitHub Actions CI. + `#2321 `_ + +* Bug in timezone issue in Eastern hemisphere midnight fixed. + `#2438 `_ + +* ``std::chrono::time_point`` now works when the resolution is not the same as + the system. + `#2481 `_ + +* Bug fixed where ``py::array_t`` could accept arrays that did not match the + requested ordering. + `#2484 `_ + +* Avoid a segfault on some compilers when types are removed in Python. + `#2564 `_ + +* ``py::arg::none()`` is now also respected when passing keyword arguments. + `#2611 `_ + +* PyPy fixes, PyPy 7.3.x now supported, including PyPy3. (Known issue with + PyPy2 and Windows `#2596 `_). + `#2146 `_ + +* CPython 3.9.0 workaround for undefined behavior (macOS segfault). + `#2576 `_ + +* CPython 3.9 warning fixes. + `#2253 `_ + +* Improved C++20 support, now tested in CI. + `#2489 `_ + `#2599 `_ + +* Improved but still incomplete debug Python interpreter support. + `#2025 `_ + +* NVCC (CUDA 11) now supported and tested in CI. + `#2461 `_ + +* NVIDIA PGI compilers now supported and tested in CI. + `#2475 `_ + +* At least Intel 18 now explicitly required when compiling with Intel. + `#2577 `_ + +* Extensive style checking in CI, with `pre-commit`_ support. Code + modernization, checked by clang-tidy. + +* Expanded docs, including new main page, new installing section, and CMake + helpers page, along with over a dozen new sections on existing pages. + +* In GitHub, new docs for contributing and new issue templates. + +.. _pre-commit: https://pre-commit.com + +.. _pybind11-mkdoc: https://github.com/pybind/pybind11-mkdoc + +v2.5.0 (Mar 31, 2020) +----------------------------------------------------- + +* Use C++17 fold expressions in type casters, if available. This can + improve performance during overload resolution when functions have + multiple arguments. + `#2043 `_. + +* Changed include directory resolution in ``pybind11/__init__.py`` + and installation in ``setup.py``. This fixes a number of open issues + where pybind11 headers could not be found in certain environments. + `#1995 `_. + +* C++20 ``char8_t`` and ``u8string`` support. `#2026 + `_. + +* CMake: search for Python 3.9. `bb9c91 + `_. + +* Fixes for MSYS-based build environments. + `#2087 `_, + `#2053 `_. + +* STL bindings for ``std::vector<...>::clear``. `#2074 + `_. + +* Read-only flag for ``py::buffer``. `#1466 + `_. + +* Exception handling during module initialization. + `bf2b031 `_. + +* Support linking against a CPython debug build. + `#2025 `_. + +* Fixed issues involving the availability and use of aligned ``new`` and + ``delete``. `#1988 `_, + `759221 `_. + +* Fixed a resource leak upon interpreter shutdown. + `#2020 `_. + +* Fixed error handling in the boolean caster. + `#1976 `_. + +v2.4.3 (Oct 15, 2019) +----------------------------------------------------- + +* Adapt pybind11 to a C API convention change in Python 3.8. `#1950 + `_. + +v2.4.2 (Sep 21, 2019) +----------------------------------------------------- + +* Replaced usage of a C++14 only construct. `#1929 + `_. + +* Made an ifdef future-proof for Python >= 4. `f3109d + `_. + +v2.4.1 (Sep 20, 2019) +----------------------------------------------------- + +* Fixed a problem involving implicit conversion from enumerations to integers + on Python 3.8. `#1780 `_. + +v2.4.0 (Sep 19, 2019) +----------------------------------------------------- + +* Try harder to keep pybind11-internal data structures separate when there + are potential ABI incompatibilities. Fixes crashes that occurred when loading + multiple pybind11 extensions that were e.g. compiled by GCC (libstdc++) + and Clang (libc++). + `#1588 `_ and + `c9f5a `_. + +* Added support for ``__await__``, ``__aiter__``, and ``__anext__`` protocols. + `#1842 `_. + +* ``pybind11_add_module()``: don't strip symbols when compiling in + ``RelWithDebInfo`` mode. `#1980 + `_. + +* ``enum_``: Reproduce Python behavior when comparing against invalid values + (e.g. ``None``, strings, etc.). Add back support for ``__invert__()``. + `#1912 `_, + `#1907 `_. + +* List insertion operation for ``py::list``. + Added ``.empty()`` to all collection types. + Added ``py::set::contains()`` and ``py::dict::contains()``. + `#1887 `_, + `#1884 `_, + `#1888 `_. + +* ``py::details::overload_cast_impl`` is available in C++11 mode, can be used + like ``overload_cast`` with an additional set of parantheses. + `#1581 `_. + +* Fixed ``get_include()`` on Conda. + `#1877 `_. + +* ``stl_bind.h``: negative indexing support. + `#1882 `_. + +* Minor CMake fix to add MinGW compatibility. + `#1851 `_. + +* GIL-related fixes. + `#1836 `_, + `8b90b `_. + +* Other very minor/subtle fixes and improvements. + `#1329 `_, + `#1910 `_, + `#1863 `_, + `#1847 `_, + `#1890 `_, + `#1860 `_, + `#1848 `_, + `#1821 `_, + `#1837 `_, + `#1833 `_, + `#1748 `_, + `#1852 `_. + +v2.3.0 (June 11, 2019) +----------------------------------------------------- + +* Significantly reduced module binary size (10-20%) when compiled in C++11 mode + with GCC/Clang, or in any mode with MSVC. Function signatures are now always + precomputed at compile time (this was previously only available in C++14 mode + for non-MSVC compilers). + `#934 `_. + +* Add basic support for tag-based static polymorphism, where classes + provide a method to returns the desired type of an instance. + `#1326 `_. + +* Python type wrappers (``py::handle``, ``py::object``, etc.) + now support map Python's number protocol onto C++ arithmetic + operators such as ``operator+``, ``operator/=``, etc. + `#1511 `_. + +* A number of improvements related to enumerations: + + 1. The ``enum_`` implementation was rewritten from scratch to reduce + code bloat. Rather than instantiating a full implementation for each + enumeration, most code is now contained in a generic base class. + `#1511 `_. + + 2. The ``value()`` method of ``py::enum_`` now accepts an optional + docstring that will be shown in the documentation of the associated + enumeration. `#1160 `_. + + 3. check for already existing enum value and throw an error if present. + `#1453 `_. + +* Support for over-aligned type allocation via C++17's aligned ``new`` + statement. `#1582 `_. + +* Added ``py::ellipsis()`` method for slicing of multidimensional NumPy arrays + `#1502 `_. + +* Numerous Improvements to the ``mkdoc.py`` script for extracting documentation + from C++ header files. + `#1788 `_. + +* ``pybind11_add_module()``: allow including Python as a ``SYSTEM`` include path. + `#1416 `_. + +* ``pybind11/stl.h`` does not convert strings to ``vector`` anymore. + `#1258 `_. + +* Mark static methods as such to fix auto-generated Sphinx documentation. + `#1732 `_. + +* Re-throw forced unwind exceptions (e.g. during pthread termination). + `#1208 `_. + +* Added ``__contains__`` method to the bindings of maps (``std::map``, + ``std::unordered_map``). + `#1767 `_. + +* Improvements to ``gil_scoped_acquire``. + `#1211 `_. + +* Type caster support for ``std::deque``. + `#1609 `_. + +* Support for ``std::unique_ptr`` holders, whose deleters differ between a base and derived + class. `#1353 `_. + +* Construction of STL array/vector-like data structures from + iterators. Added an ``extend()`` operation. + `#1709 `_, + +* CMake build system improvements for projects that include non-C++ + files (e.g. plain C, CUDA) in ``pybind11_add_module`` et al. + `#1678 `_. + +* Fixed asynchronous invocation and deallocation of Python functions + wrapped in ``std::function``. + `#1595 `_. + +* Fixes regarding return value policy propagation in STL type casters. + `#1603 `_. + +* Fixed scoped enum comparisons. + `#1571 `_. + +* Fixed iostream redirection for code that releases the GIL. + `#1368 `_, + +* A number of CI-related fixes. + `#1757 `_, + `#1744 `_, + `#1670 `_. + v2.2.4 (September 11, 2018) ----------------------------------------------------- @@ -14,7 +505,7 @@ v2.2.4 (September 11, 2018) `#1517 `_. * Fixes for newer MSVC versions and C++17 mode. - `#1347 `_. + `#1347 `_, `#1462 `_. * Propagate return value policies to type-specific casters @@ -50,6 +541,11 @@ v2.2.4 (September 11, 2018) * A few minor typo fixes and improvements to the test suite, and patches that silence compiler warnings. +* Vectors now support construction from generators, as well as ``extend()`` from a + list or generator. + `#1496 `_. + + v2.2.3 (April 29, 2018) ----------------------------------------------------- @@ -69,10 +565,6 @@ v2.2.3 (April 29, 2018) * Fixed an endianness-related fault in the test suite. `#1287 `_. -* Intel compilers have needed to be >= 17.0 since v2.1. Now the check - is explicit and a compile-time error is raised if the compiler does - not meet the requirements. - v2.2.2 (February 7, 2018) ----------------------------------------------------- @@ -141,7 +633,7 @@ v2.2.2 (February 7, 2018) v2.2.1 (September 14, 2017) ----------------------------------------------------- -* Added ``py::module::reload()`` member function for reloading a module. +* Added ``py::module_::reload()`` member function for reloading a module. `#1040 `_. * Fixed a reference leak in the number converter. @@ -316,7 +808,7 @@ v2.2.0 (August 31, 2017) in reference cycles. `#856 `_. -* Numpy and buffer protocol related improvements: +* NumPy and buffer protocol related improvements: 1. Support for negative strides in Python buffer objects/numpy arrays. This required changing integers from unsigned to signed for the related C++ APIs. @@ -363,6 +855,9 @@ v2.2.0 (August 31, 2017) * Fixed overriding static properties in derived classes. `#784 `_. +* Added support for write only properties. + `#1144 `_. + * Improved deduction of member functions of a derived class when its bases aren't registered with pybind11. `#855 `_. @@ -1044,7 +1539,7 @@ Happy Christmas! * Improved support for ``std::shared_ptr<>`` conversions * Initial support for ``std::set<>`` conversions * Fixed type resolution issue for types defined in a separate plugin module -* Cmake build system improvements +* CMake build system improvements * Factored out generic functionality to non-templated code (smaller code size) * Added a code size / compile time benchmark vs Boost.Python * Added an appveyor CI script diff --git a/plugins/python/pybind11/docs/classes.rst b/plugins/python/pybind11/docs/classes.rst index ca2477e..f3610ef 100644 --- a/plugins/python/pybind11/docs/classes.rst +++ b/plugins/python/pybind11/docs/classes.rst @@ -74,7 +74,7 @@ Note how ``print(p)`` produced a rather useless summary of our data structure in >>> print(p) -To address this, we could bind an utility function that returns a human-readable +To address this, we could bind a utility function that returns a human-readable summary to the special method slot named ``__repr__``. Unfortunately, there is no suitable functionality in the ``Pet`` data structure, and it would be nice if we did not have to change it. This can easily be accomplished by binding a @@ -155,6 +155,9 @@ the setter and getter functions: .def_property("name", &Pet::getName, &Pet::setName) // ... remainder ... +Write only properties can be defined by passing ``nullptr`` as the +input for the read function. + .. seealso:: Similar functions :func:`class_::def_readwrite_static`, @@ -225,8 +228,8 @@ just brings them on par. .. _inheritance: -Inheritance and automatic upcasting -=================================== +Inheritance and automatic downcasting +===================================== Suppose now that the example consists of two data structures with an inheritance relationship: @@ -295,7 +298,7 @@ inheritance relationship. This is reflected in Python: >>> p = example.pet_store() >>> type(p) # `Dog` instance behind `Pet` pointer - Pet # no pointer upcasting for regular non-polymorphic types + Pet # no pointer downcasting for regular non-polymorphic types >>> p.bark() AttributeError: 'Pet' object has no attribute 'bark' @@ -327,11 +330,11 @@ will automatically recognize this: >>> p = example.pet_store2() >>> type(p) - PolymorphicDog # automatically upcast + PolymorphicDog # automatically downcast >>> p.bark() u'woof!' -Given a pointer to a polymorphic base, pybind11 performs automatic upcasting +Given a pointer to a polymorphic base, pybind11 performs automatic downcasting to the actual derived type. Note that this goes beyond the usual situation in C++: we don't just get access to the virtual functions of the base, we get the concrete derived type including functions and attributes that the base type may @@ -370,8 +373,8 @@ sequence. py::class_(m, "Pet") .def(py::init()) - .def("set", (void (Pet::*)(int)) &Pet::set, "Set the pet's age") - .def("set", (void (Pet::*)(const std::string &)) &Pet::set, "Set the pet's name"); + .def("set", static_cast(&Pet::set), "Set the pet's age") + .def("set", static_cast(&Pet::set), "Set the pet's name"); The overload signatures are also visible in the method's docstring: @@ -419,6 +422,17 @@ on constness, the ``py::const_`` tag should be used: .def("foo_mutable", py::overload_cast(&Widget::foo)) .def("foo_const", py::overload_cast(&Widget::foo, py::const_)); +If you prefer the ``py::overload_cast`` syntax but have a C++11 compatible compiler only, +you can use ``py::detail::overload_cast_impl`` with an additional set of parentheses: + +.. code-block:: cpp + + template + using overload_cast_ = pybind11::detail::overload_cast_impl; + + py::class_(m, "Pet") + .def("set", overload_cast_()(&Pet::set), "Set the pet's age") + .def("set", overload_cast_()(&Pet::set), "Set the pet's name"); .. [#cpp14] A compiler which supports the ``-std=c++14`` flag or Visual Studio 2015 Update 2 and newer. @@ -485,6 +499,24 @@ The entries defined by the enumeration type are exposed in the ``__members__`` p >>> Pet.Kind.__members__ {'Dog': Kind.Dog, 'Cat': Kind.Cat} +The ``name`` property returns the name of the enum value as a unicode string. + +.. note:: + + It is also possible to use ``str(enum)``, however these accomplish different + goals. The following shows how these two approaches differ. + + .. code-block:: pycon + + >>> p = Pet( "Lucy", Pet.Cat ) + >>> pet_type = p.type + >>> pet_type + Pet.Cat + >>> str(pet_type) + 'Pet.Cat' + >>> pet_type.name + 'Cat' + .. note:: When the special tag ``py::arithmetic()`` is specified to the ``enum_`` diff --git a/plugins/python/pybind11/docs/cmake/index.rst b/plugins/python/pybind11/docs/cmake/index.rst new file mode 100644 index 0000000..eaf66d7 --- /dev/null +++ b/plugins/python/pybind11/docs/cmake/index.rst @@ -0,0 +1,8 @@ +CMake helpers +------------- + +Pybind11 can be used with ``add_subdirectory(extern/pybind11)``, or from an +install with ``find_package(pybind11 CONFIG)``. The interface provided in +either case is functionally identical. + +.. cmake-module:: ../../tools/pybind11Config.cmake.in diff --git a/plugins/python/pybind11/docs/compiling.rst b/plugins/python/pybind11/docs/compiling.rst index b5d6ce9..f26e6cf 100644 --- a/plugins/python/pybind11/docs/compiling.rst +++ b/plugins/python/pybind11/docs/compiling.rst @@ -3,6 +3,8 @@ Build systems ############# +.. _build-setuptools: + Building with setuptools ======================== @@ -13,6 +15,203 @@ the [python_example]_ repository. .. [python_example] https://github.com/pybind/python_example +A helper file is provided with pybind11 that can simplify usage with setuptools. + +To use pybind11 inside your ``setup.py``, you have to have some system to +ensure that ``pybind11`` is installed when you build your package. There are +four possible ways to do this, and pybind11 supports all four: You can ask all +users to install pybind11 beforehand (bad), you can use +:ref:`setup_helpers-pep518` (good, but very new and requires Pip 10), +:ref:`setup_helpers-setup_requires` (discouraged by Python packagers now that +PEP 518 is available, but it still works everywhere), or you can +:ref:`setup_helpers-copy-manually` (always works but you have to manually sync +your copy to get updates). + +An example of a ``setup.py`` using pybind11's helpers: + +.. code-block:: python + + from glob import glob + from setuptools import setup + from pybind11.setup_helpers import Pybind11Extension + + ext_modules = [ + Pybind11Extension( + "python_example", + sorted(glob("src/*.cpp")), # Sort source files for reproducibility + ), + ] + + setup( + ..., + ext_modules=ext_modules + ) + +If you want to do an automatic search for the highest supported C++ standard, +that is supported via a ``build_ext`` command override; it will only affect +``Pybind11Extensions``: + +.. code-block:: python + + from glob import glob + from setuptools import setup + from pybind11.setup_helpers import Pybind11Extension, build_ext + + ext_modules = [ + Pybind11Extension( + "python_example", + sorted(glob("src/*.cpp")), + ), + ] + + setup( + ..., + cmdclass={"build_ext": build_ext}, + ext_modules=ext_modules + ) + +Since pybind11 does not require NumPy when building, a light-weight replacement +for NumPy's parallel compilation distutils tool is included. Use it like this: + +.. code-block:: python + + from pybind11.setup_helpers import ParallelCompile + + # Optional multithreaded build + ParallelCompile("NPY_NUM_BUILD_JOBS").install() + + setup(...) + +The argument is the name of an environment variable to control the number of +threads, such as ``NPY_NUM_BUILD_JOBS`` (as used by NumPy), though you can set +something different if you want. You can also pass ``default=N`` to set the +default number of threads (0 will take the number of threads available) and +``max=N``, the maximum number of threads; if you have a large extension you may +want set this to a memory dependent number. + +If you are developing rapidly and have a lot of C++ files, you may want to +avoid rebuilding files that have not changed. For simple cases were you are +using ``pip install -e .`` and do not have local headers, you can skip the +rebuild if a object file is newer than it's source (headers are not checked!) +with the following: + +.. code-block:: python + + from pybind11.setup_helpers import ParallelCompile, naive_recompile + + SmartCompile("NPY_NUM_BUILD_JOBS", needs_recompile=naive_recompile).install() + + +If you have a more complex build, you can implement a smarter function and pass +it to ``needs_recompile``, or you can use [Ccache]_ instead. ``CXX="cache g++" +pip install -e .`` would be the way to use it with GCC, for example. Unlike the +simple solution, this even works even when not compiling in editable mode, but +it does require Ccache to be installed. + +Keep in mind that Pip will not even attempt to rebuild if it thinks it has +already built a copy of your code, which it deduces from the version number. +One way to avoid this is to use [setuptools_scm]_, which will generate a +version number that includes the number of commits since your last tag and a +hash for a dirty directory. Another way to force a rebuild is purge your cache +or use Pip's ``--no-cache-dir`` option. + +.. [Ccache] https://ccache.dev + +.. [setuptools_scm] https://github.com/pypa/setuptools_scm + +.. _setup_helpers-pep518: + +PEP 518 requirements (Pip 10+ required) +--------------------------------------- + +If you use `PEP 518's `_ +``pyproject.toml`` file, you can ensure that ``pybind11`` is available during +the compilation of your project. When this file exists, Pip will make a new +virtual environment, download just the packages listed here in ``requires=``, +and build a wheel (binary Python package). It will then throw away the +environment, and install your wheel. + +Your ``pyproject.toml`` file will likely look something like this: + +.. code-block:: toml + + [build-system] + requires = ["setuptools", "wheel", "pybind11==2.6.0"] + build-backend = "setuptools.build_meta" + +.. note:: + + The main drawback to this method is that a `PEP 517`_ compliant build tool, + such as Pip 10+, is required for this approach to work; older versions of + Pip completely ignore this file. If you distribute binaries (called wheels + in Python) using something like `cibuildwheel`_, remember that ``setup.py`` + and ``pyproject.toml`` are not even contained in the wheel, so this high + Pip requirement is only for source builds, and will not affect users of + your binary wheels. + +.. _PEP 517: https://www.python.org/dev/peps/pep-0517/ +.. _cibuildwheel: https://cibuildwheel.readthedocs.io + +.. _setup_helpers-setup_requires: + +Classic ``setup_requires`` +-------------------------- + +If you want to support old versions of Pip with the classic +``setup_requires=["pybind11"]`` keyword argument to setup, which triggers a +two-phase ``setup.py`` run, then you will need to use something like this to +ensure the first pass works (which has not yet installed the ``setup_requires`` +packages, since it can't install something it does not know about): + +.. code-block:: python + + try: + from pybind11.setup_helpers import Pybind11Extension + except ImportError: + from setuptools import Extension as Pybind11Extension + + +It doesn't matter that the Extension class is not the enhanced subclass for the +first pass run; and the second pass will have the ``setup_requires`` +requirements. + +This is obviously more of a hack than the PEP 518 method, but it supports +ancient versions of Pip. + +.. _setup_helpers-copy-manually: + +Copy manually +------------- + +You can also copy ``setup_helpers.py`` directly to your project; it was +designed to be usable standalone, like the old example ``setup.py``. You can +set ``include_pybind11=False`` to skip including the pybind11 package headers, +so you can use it with git submodules and a specific git version. If you use +this, you will need to import from a local file in ``setup.py`` and ensure the +helper file is part of your MANIFEST. + + +Closely related, if you include pybind11 as a subproject, you can run the +``setup_helpers.py`` inplace. If loaded correctly, this should even pick up +the correct include for pybind11, though you can turn it off as shown above if +you want to input it manually. + +Suggested usage if you have pybind11 as a submodule in ``extern/pybind11``: + +.. code-block:: python + + DIR = os.path.abspath(os.path.dirname(__file__)) + + sys.path.append(os.path.join(DIR, "extern", "pybind11")) + from pybind11.setup_helpers import Pybind11Extension # noqa: E402 + + del sys.path[-1] + + +.. versionchanged:: 2.6 + + Added ``setup_helpers`` file. + Building with cppimport ======================== @@ -33,8 +232,8 @@ extension module can be created with just a few lines of code: .. code-block:: cmake - cmake_minimum_required(VERSION 2.8.12) - project(example) + cmake_minimum_required(VERSION 3.4...3.18) + project(example LANGUAGES CXX) add_subdirectory(pybind11) pybind11_add_module(example example.cpp) @@ -50,6 +249,11 @@ PyPI integration, can be found in the [cmake_example]_ repository. .. [cmake_example] https://github.com/pybind/cmake_example +.. versionchanged:: 2.6 + CMake 3.4+ is required. + +Further information can be found at :doc:`cmake/index`. + pybind11_add_module ------------------- @@ -59,7 +263,7 @@ function with the following signature: .. code-block:: cmake pybind11_add_module( [MODULE | SHARED] [EXCLUDE_FROM_ALL] - [NO_EXTRAS] [THIN_LTO] source1 [source2 ...]) + [NO_EXTRAS] [THIN_LTO] [OPT_SIZE] source1 [source2 ...]) This function behaves very much like CMake's builtin ``add_library`` (in fact, it's a wrapper function around that command). It will add a library target @@ -89,46 +293,65 @@ will result in code bloat and is generally not recommended. As stated above, LTO is enabled by default. Some newer compilers also support different flavors of LTO such as `ThinLTO`_. Setting ``THIN_LTO`` will cause the function to prefer this flavor if available. The function falls back to -regular LTO if ``-flto=thin`` is not available. +regular LTO if ``-flto=thin`` is not available. If +``CMAKE_INTERPROCEDURAL_OPTIMIZATION`` is set (either ``ON`` or ``OFF``), then +that will be respected instead of the built-in flag search. + +.. note:: + + If you want to set the property form on targets or the + ``CMAKE_INTERPROCEDURAL_OPTIMIZATION_`` versions of this, you should + still use ``set(CMAKE_INTERPROCEDURAL_OPTIMIZATION OFF)`` (otherwise a + no-op) to disable pybind11's ipo flags. + +The ``OPT_SIZE`` flag enables size-based optimization equivalent to the +standard ``/Os`` or ``-Os`` compiler flags and the ``MinSizeRel`` build type, +which avoid optimizations that that can substantially increase the size of the +resulting binary. This flag is particularly useful in projects that are split +into performance-critical parts and associated bindings. In this case, we can +compile the project in release mode (and hence, optimize performance globally), +and specify ``OPT_SIZE`` for the binding target, where size might be the main +concern as performance is often less critical here. A ~25% size reduction has +been observed in practice. This flag only changes the optimization behavior at +a per-target level and takes precedence over the global CMake build type +(``Release``, ``RelWithDebInfo``) except for ``Debug`` builds, where +optimizations remain disabled. .. _ThinLTO: http://clang.llvm.org/docs/ThinLTO.html Configuration variables ----------------------- -By default, pybind11 will compile modules with the C++14 standard, if available -on the target compiler, falling back to C++11 if C++14 support is not -available. Note, however, that this default is subject to change: future -pybind11 releases are expected to migrate to newer C++ standards as they become -available. To override this, the standard flag can be given explicitly in -``PYBIND11_CPP_STANDARD``: +By default, pybind11 will compile modules with the compiler default or the +minimum standard required by pybind11, whichever is higher. You can set the +standard explicitly with +`CMAKE_CXX_STANDARD `_: .. code-block:: cmake - # Use just one of these: - # GCC/clang: - set(PYBIND11_CPP_STANDARD -std=c++11) - set(PYBIND11_CPP_STANDARD -std=c++14) - set(PYBIND11_CPP_STANDARD -std=c++1z) # Experimental C++17 support - # MSVC: - set(PYBIND11_CPP_STANDARD /std:c++14) - set(PYBIND11_CPP_STANDARD /std:c++latest) # Enables some MSVC C++17 features + set(CMAKE_CXX_STANDARD 14 CACHE STRING "C++ version selection") # or 11, 14, 17, 20 + set(CMAKE_CXX_STANDARD_REQUIRED ON) # optional, ensure standard is supported + set(CMAKE_CXX_EXTENSIONS OFF) # optional, keep compiler extensionsn off - add_subdirectory(pybind11) # or find_package(pybind11) +The variables can also be set when calling CMake from the command line using +the ``-D=`` flag. You can also manually set ``CXX_STANDARD`` +on a target or use ``target_compile_features`` on your targets - anything that +CMake supports. -Note that this and all other configuration variables must be set **before** the -call to ``add_subdirectory`` or ``find_package``. The variables can also be set -when calling CMake from the command line using the ``-D=`` flag. - -The target Python version can be selected by setting ``PYBIND11_PYTHON_VERSION`` -or an exact Python installation can be specified with ``PYTHON_EXECUTABLE``. -For example: +Classic Python support: The target Python version can be selected by setting +``PYBIND11_PYTHON_VERSION`` or an exact Python installation can be specified +with ``PYTHON_EXECUTABLE``. For example: .. code-block:: bash cmake -DPYBIND11_PYTHON_VERSION=3.6 .. - # or - cmake -DPYTHON_EXECUTABLE=path/to/python .. + + # Another method: + cmake -DPYTHON_EXECUTABLE=/path/to/python .. + + # This often is a good way to get the current Python, works in environments: + cmake -DPYTHON_EXECUTABLE=$(python3 -c "import sys; print(sys.executable)") .. + find_package vs. add_subdirectory --------------------------------- @@ -139,12 +362,31 @@ See the `Config file`_ docstring for details of relevant CMake variables. .. code-block:: cmake - cmake_minimum_required(VERSION 2.8.12) - project(example) + cmake_minimum_required(VERSION 3.4...3.18) + project(example LANGUAGES CXX) find_package(pybind11 REQUIRED) pybind11_add_module(example example.cpp) +Note that ``find_package(pybind11)`` will only work correctly if pybind11 +has been correctly installed on the system, e. g. after downloading or cloning +the pybind11 repository : + +.. code-block:: bash + + # Classic CMake + cd pybind11 + mkdir build + cd build + cmake .. + make install + + # CMake 3.15+ + cd pybind11 + cmake -S . -B build + cmake --build build -j 2 # Build on 2 cores + cmake --install build + Once detected, the aforementioned ``pybind11_add_module`` can be employed as before. The function usage and configuration variables are identical no matter if pybind11 is added as a subdirectory or found as an installed package. You @@ -153,41 +395,134 @@ can refer to the same [cmake_example]_ repository for a full sample project .. _Config file: https://github.com/pybind/pybind11/blob/master/tools/pybind11Config.cmake.in -Advanced: interface library target ----------------------------------- -When using a version of CMake greater than 3.0, pybind11 can additionally -be used as a special *interface library* . The target ``pybind11::module`` -is available with pybind11 headers, Python headers and libraries as needed, -and C++ compile definitions attached. This target is suitable for linking -to an independently constructed (through ``add_library``, not -``pybind11_add_module``) target in the consuming project. +.. _find-python-mode: + +FindPython mode +--------------- + +CMake 3.12+ (3.15+ recommended) added a new module called FindPython that had a +highly improved search algorithm and modern targets and tools. If you use +FindPython, pybind11 will detect this and use the existing targets instead: .. code-block:: cmake - cmake_minimum_required(VERSION 3.0) - project(example) + cmake_minumum_required(VERSION 3.15...3.18) + project(example LANGUAGES CXX) + + find_package(Python COMPONENTS Interpreter Development REQUIRED) + find_package(pybind11 CONFIG REQUIRED) + # or add_subdirectory(pybind11) + + pybind11_add_module(example example.cpp) + +You can also use the targets (as listed below) with FindPython. If you define +``PYBIND11_FINDPYTHON``, pybind11 will perform the FindPython step for you +(mostly useful when building pybind11's own tests, or as a way to change search +algorithms from the CMake invocation, with ``-DPYBIND11_FINDPYTHON=ON``. + +.. warning:: + + If you use FindPython2 and FindPython3 to dual-target Python, use the + individual targets listed below, and avoid targets that directly include + Python parts. + +There are `many ways to hint or force a discovery of a specific Python +installation `_), +setting ``Python_ROOT_DIR`` may be the most common one (though with +virtualenv/venv support, and Conda support, this tends to find the correct +Python version more often than the old system did). + +.. versionadded:: 2.6 + +Advanced: interface library targets +----------------------------------- + +Pybind11 supports modern CMake usage patterns with a set of interface targets, +available in all modes. The targets provided are: + + ``pybind11::headers`` + Just the pybind11 headers and minimum compile requirements + + ``pybind11::python2_no_register`` + Quiets the warning/error when mixing C++14 or higher and Python 2 + + ``pybind11::pybind11`` + Python headers + ``pybind11::headers`` + ``pybind11::python2_no_register`` (Python 2 only) + + ``pybind11::python_link_helper`` + Just the "linking" part of pybind11:module + + ``pybind11::module`` + Everything for extension modules - ``pybind11::pybind11`` + ``Python::Module`` (FindPython CMake 3.15+) or ``pybind11::python_link_helper`` + + ``pybind11::embed`` + Everything for embedding the Python interpreter - ``pybind11::pybind11`` + ``Python::Embed`` (FindPython) or Python libs + + ``pybind11::lto`` / ``pybind11::thin_lto`` + An alternative to `INTERPROCEDURAL_OPTIMIZATION` for adding link-time optimization. + + ``pybind11::windows_extras`` + ``/bigobj`` and ``/mp`` for MSVC. + + ``pybind11::opt_size`` + ``/Os`` for MSVC, ``-Os`` for other compilers. Does nothing for debug builds. + +Two helper functions are also provided: + + ``pybind11_strip(target)`` + Strips a target (uses ``CMAKE_STRIP`` after the target is built) + + ``pybind11_extension(target)`` + Sets the correct extension (with SOABI) for a target. + +You can use these targets to build complex applications. For example, the +``add_python_module`` function is identical to: + +.. code-block:: cmake + + cmake_minimum_required(VERSION 3.4) + project(example LANGUAGES CXX) find_package(pybind11 REQUIRED) # or add_subdirectory(pybind11) add_library(example MODULE main.cpp) - target_link_libraries(example PRIVATE pybind11::module) - set_target_properties(example PROPERTIES PREFIX "${PYTHON_MODULE_PREFIX}" - SUFFIX "${PYTHON_MODULE_EXTENSION}") + + target_link_libraries(example PRIVATE pybind11::module pybind11::lto pybind11::windows_extras) + + pybind11_extension(example) + pybind11_strip(example) + + set_target_properties(example PROPERTIES CXX_VISIBILITY_PRESET "hidden" + CUDA_VISIBILITY_PRESET "hidden") + +Instead of setting properties, you can set ``CMAKE_*`` variables to initialize these correctly. .. warning:: Since pybind11 is a metatemplate library, it is crucial that certain compiler flags are provided to ensure high quality code generation. In contrast to the ``pybind11_add_module()`` command, the CMake interface - library only provides the *minimal* set of parameters to ensure that the - code using pybind11 compiles, but it does **not** pass these extra compiler - flags (i.e. this is up to you). + provides a *composable* set of targets to ensure that you retain flexibility. + It can be expecially important to provide or set these properties; the + :ref:`FAQ ` contains an explanation on why these are needed. + +.. versionadded:: 2.6 - These include Link Time Optimization (``-flto`` on GCC/Clang/ICPC, ``/GL`` - and ``/LTCG`` on Visual Studio) and .OBJ files with many sections on Visual - Studio (``/bigobj``). The :ref:`FAQ ` contains an - explanation on why these are needed. +.. _nopython-mode: + +Advanced: NOPYTHON mode +----------------------- + +If you want complete control, you can set ``PYBIND11_NOPYTHON`` to completely +disable Python integration (this also happens if you run ``FindPython2`` and +``FindPython3`` without running ``FindPython``). This gives you complete +freedom to integrate into an existing system (like `Scikit-Build's +`_ ``PythonExtensions``). +``pybind11_add_module`` and ``pybind11_extension`` will be unavailable, and the +targets will be missing any Python specific behavior. + +.. versionadded:: 2.6 Embedding the Python interpreter -------------------------------- @@ -201,8 +536,8 @@ information about usage in C++, see :doc:`/advanced/embedding`. .. code-block:: cmake - cmake_minimum_required(VERSION 3.0) - project(example) + cmake_minimum_required(VERSION 3.4...3.18) + project(example LANGUAGES CXX) find_package(pybind11 REQUIRED) # or add_subdirectory(pybind11) @@ -239,7 +574,7 @@ Besides, the ``--extension-suffix`` option may or may not be available, dependin on the distribution; in the latter case, the module extension can be manually set to ``.so``. -On Mac OS: the build command is almost the same but it also requires passing +On macOS: the build command is almost the same but it also requires passing the ``-undefined dynamic_lookup`` flag so as to ignore missing symbols when building the module: @@ -263,6 +598,13 @@ build system that works on all platforms including Windows. of possibly importing a second Python library into a process that already contains one (which will lead to a segfault). + +Building with Bazel +=================== + +You can build with the Bazel build system using the `pybind11_bazel +`_ repository. + Generating binding code automatically ===================================== @@ -271,3 +613,18 @@ code by introspecting existing C++ codebases using LLVM/Clang. See the [binder]_ documentation for details. .. [binder] http://cppbinder.readthedocs.io/en/latest/about.html + +[AutoWIG]_ is a Python library that wraps automatically compiled libraries into +high-level languages. It parses C++ code using LLVM/Clang technologies and +generates the wrappers using the Mako templating engine. The approach is automatic, +extensible, and applies to very complex C++ libraries, composed of thousands of +classes or incorporating modern meta-programming constructs. + +.. [AutoWIG] https://github.com/StatisKit/AutoWIG + +[robotpy-build]_ is a is a pure python, cross platform build tool that aims to +simplify creation of python wheels for pybind11 projects, and provide +cross-project dependency management. Additionally, it is able to autogenerate +customizable pybind11-based wrappers by parsing C++ header files. + +.. [robotpy-build] https://robotpy-build.readthedocs.io diff --git a/plugins/python/pybind11/docs/conf.py b/plugins/python/pybind11/docs/conf.py index e328eb1..66db310 100644 --- a/plugins/python/pybind11/docs/conf.py +++ b/plugins/python/pybind11/docs/conf.py @@ -17,53 +17,65 @@ import os import shlex import subprocess +from pathlib import Path +import re + +DIR = Path(__file__).parent.resolve() # If extensions (or modules to document with autodoc) are in another directory, # add these directories to sys.path here. If the directory is relative to the # documentation root, use os.path.abspath to make it absolute, like shown here. -#sys.path.insert(0, os.path.abspath('.')) +# sys.path.insert(0, os.path.abspath('.')) # -- General configuration ------------------------------------------------ # If your documentation needs a minimal Sphinx version, state it here. -#needs_sphinx = '1.0' +# needs_sphinx = '1.0' # Add any Sphinx extension module names here, as strings. They can be # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom # ones. -extensions = ['breathe'] +extensions = [ + "breathe", + "sphinxcontrib.rsvgconverter", + "sphinxcontrib.moderncmakedomain", +] -breathe_projects = {'pybind11': '.build/doxygenxml/'} -breathe_default_project = 'pybind11' -breathe_domain_by_extension = {'h': 'cpp'} +breathe_projects = {"pybind11": ".build/doxygenxml/"} +breathe_default_project = "pybind11" +breathe_domain_by_extension = {"h": "cpp"} # Add any paths that contain templates here, relative to this directory. -templates_path = ['.templates'] +templates_path = [".templates"] # The suffix(es) of source filenames. # You can specify multiple suffix as a list of string: # source_suffix = ['.rst', '.md'] -source_suffix = '.rst' +source_suffix = ".rst" # The encoding of source files. -#source_encoding = 'utf-8-sig' +# source_encoding = 'utf-8-sig' # The master toctree document. -master_doc = 'index' +master_doc = "index" # General information about the project. -project = 'pybind11' -copyright = '2017, Wenzel Jakob' -author = 'Wenzel Jakob' +project = "pybind11" +copyright = "2017, Wenzel Jakob" +author = "Wenzel Jakob" # The version info for the project you're documenting, acts as replacement for # |version| and |release|, also used in various other places throughout the # built documents. -# -# The short X.Y version. -version = '2.2' + +# Read the listed version +with open("../pybind11/_version.py") as f: + code = compile(f.read(), "../pybind11/_version.py", "exec") +loc = {} +exec(code, loc) + # The full version, including alpha/beta/rc tags. -release = '2.2.3' +version = loc["__version__"] # The language for content autogenerated by Sphinx. Refer to documentation # for a list of supported languages. @@ -74,37 +86,37 @@ # There are two options for replacing |today|: either, you set today to some # non-false value, then it is used: -#today = '' +# today = '' # Else, today_fmt is used as the format for a strftime call. -#today_fmt = '%B %d, %Y' +# today_fmt = '%B %d, %Y' # List of patterns, relative to source directory, that match files and # directories to ignore when looking for source files. -exclude_patterns = ['.build', 'release.rst'] +exclude_patterns = [".build", "release.rst"] # The reST default role (used for this markup: `text`) to use for all # documents. -default_role = 'any' +default_role = "any" # If true, '()' will be appended to :func: etc. cross-reference text. -#add_function_parentheses = True +# add_function_parentheses = True # If true, the current module name will be prepended to all description # unit titles (such as .. function::). -#add_module_names = True +# add_module_names = True # If true, sectionauthor and moduleauthor directives will be shown in the # output. They are ignored by default. -#show_authors = False +# show_authors = False # The name of the Pygments (syntax highlighting) style to use. -#pygments_style = 'monokai' +# pygments_style = 'monokai' # A list of ignored prefixes for module index sorting. -#modindex_common_prefix = [] +# modindex_common_prefix = [] # If true, keep warnings as "system message" paragraphs in the built documents. -#keep_warnings = False +# keep_warnings = False # If true, `todo` and `todoList` produce output, else they produce nothing. todo_include_todos = False @@ -115,141 +127,148 @@ # The theme to use for HTML and HTML Help pages. See the documentation for # a list of builtin themes. -on_rtd = os.environ.get('READTHEDOCS', None) == 'True' +on_rtd = os.environ.get("READTHEDOCS", None) == "True" if not on_rtd: # only import and set the theme if we're building docs locally import sphinx_rtd_theme - html_theme = 'sphinx_rtd_theme' + + html_theme = "sphinx_rtd_theme" html_theme_path = [sphinx_rtd_theme.get_html_theme_path()] - html_context = { - 'css_files': [ - '_static/theme_overrides.css' - ] - } + html_context = {"css_files": ["_static/theme_overrides.css"]} else: html_context = { - 'css_files': [ - '//media.readthedocs.org/css/sphinx_rtd_theme.css', - '//media.readthedocs.org/css/readthedocs-doc-embed.css', - '_static/theme_overrides.css' + "css_files": [ + "//media.readthedocs.org/css/sphinx_rtd_theme.css", + "//media.readthedocs.org/css/readthedocs-doc-embed.css", + "_static/theme_overrides.css", ] } # Theme options are theme-specific and customize the look and feel of a theme # further. For a list of options available for each theme, see the # documentation. -#html_theme_options = {} +# html_theme_options = {} # Add any paths that contain custom themes here, relative to this directory. -#html_theme_path = [] +# html_theme_path = [] # The name for this set of Sphinx documents. If None, it defaults to -# " v documentation". -#html_title = None +# " v documentation". +# html_title = None # A shorter title for the navigation bar. Default is the same as html_title. -#html_short_title = None +# html_short_title = None # The name of an image file (relative to this directory) to place at the top # of the sidebar. -#html_logo = None +# html_logo = None # The name of an image file (within the static path) to use as favicon of the # docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32 # pixels large. -#html_favicon = None +# html_favicon = None # Add any paths that contain custom static files (such as style sheets) here, # relative to this directory. They are copied after the builtin static files, # so a file named "default.css" will overwrite the builtin "default.css". -html_static_path = ['_static'] +html_static_path = ["_static"] # Add any extra paths that contain custom files (such as robots.txt or # .htaccess) here, relative to this directory. These files are copied # directly to the root of the documentation. -#html_extra_path = [] +# html_extra_path = [] # If not '', a 'Last updated on:' timestamp is inserted at every page bottom, # using the given strftime format. -#html_last_updated_fmt = '%b %d, %Y' +# html_last_updated_fmt = '%b %d, %Y' # If true, SmartyPants will be used to convert quotes and dashes to # typographically correct entities. -#html_use_smartypants = True +# html_use_smartypants = True # Custom sidebar templates, maps document names to template names. -#html_sidebars = {} +# html_sidebars = {} # Additional templates that should be rendered to pages, maps page names to # template names. -#html_additional_pages = {} +# html_additional_pages = {} # If false, no module index is generated. -#html_domain_indices = True +# html_domain_indices = True # If false, no index is generated. -#html_use_index = True +# html_use_index = True # If true, the index is split into individual pages for each letter. -#html_split_index = False +# html_split_index = False # If true, links to the reST sources are added to the pages. -#html_show_sourcelink = True +# html_show_sourcelink = True # If true, "Created using Sphinx" is shown in the HTML footer. Default is True. -#html_show_sphinx = True +# html_show_sphinx = True # If true, "(C) Copyright ..." is shown in the HTML footer. Default is True. -#html_show_copyright = True +# html_show_copyright = True # If true, an OpenSearch description file will be output, and all pages will # contain a tag referring to it. The value of this option must be the # base URL from which the finished HTML is served. -#html_use_opensearch = '' +# html_use_opensearch = '' # This is the file name suffix for HTML files (e.g. ".xhtml"). -#html_file_suffix = None +# html_file_suffix = None # Language to be used for generating the HTML full-text search index. # Sphinx supports the following languages: # 'da', 'de', 'en', 'es', 'fi', 'fr', 'h', 'it', 'ja' # 'nl', 'no', 'pt', 'ro', 'r', 'sv', 'tr' -#html_search_language = 'en' +# html_search_language = 'en' # A dictionary with options for the search language support, empty by default. # Now only 'ja' uses this config value -#html_search_options = {'type': 'default'} +# html_search_options = {'type': 'default'} # The name of a javascript file (relative to the configuration directory) that # implements a search results scorer. If empty, the default will be used. -#html_search_scorer = 'scorer.js' +# html_search_scorer = 'scorer.js' # Output file base name for HTML help builder. -htmlhelp_basename = 'pybind11doc' +htmlhelp_basename = "pybind11doc" # -- Options for LaTeX output --------------------------------------------- latex_elements = { -# The paper size ('letterpaper' or 'a4paper'). -#'papersize': 'letterpaper', - -# The font size ('10pt', '11pt' or '12pt'). -#'pointsize': '10pt', - -# Additional stuff for the LaTeX preamble. -'preamble': '\DeclareUnicodeCharacter{00A0}{}', - -# Latex figure (float) alignment -#'figure_align': 'htbp', + # The paper size ('letterpaper' or 'a4paper'). + # 'papersize': 'letterpaper', + # + # The font size ('10pt', '11pt' or '12pt'). + # 'pointsize': '10pt', + # + # Additional stuff for the LaTeX preamble. + # remove blank pages (between the title page and the TOC, etc.) + "classoptions": ",openany,oneside", + "preamble": r""" +\usepackage{fontawesome} +\usepackage{textgreek} +\DeclareUnicodeCharacter{00A0}{} +\DeclareUnicodeCharacter{2194}{\faArrowsH} +\DeclareUnicodeCharacter{1F382}{\faBirthdayCake} +\DeclareUnicodeCharacter{1F355}{\faAdjust} +\DeclareUnicodeCharacter{0301}{'} +\DeclareUnicodeCharacter{03C0}{\textpi} + +""", + # Latex figure (float) alignment + # 'figure_align': 'htbp', } # Grouping the document tree into LaTeX files. List of tuples # (source start file, target name, title, # author, documentclass [howto, manual, or own class]). latex_documents = [ - (master_doc, 'pybind11.tex', 'pybind11 Documentation', - 'Wenzel Jakob', 'manual'), + (master_doc, "pybind11.tex", "pybind11 Documentation", "Wenzel Jakob", "manual"), ] # The name of an image file (relative to this directory) to place at the top of @@ -258,32 +277,29 @@ # For "manual" documents, if this is true, then toplevel headings are parts, # not chapters. -#latex_use_parts = False +# latex_use_parts = False # If true, show page references after internal links. -#latex_show_pagerefs = False +# latex_show_pagerefs = False # If true, show URL addresses after external links. -#latex_show_urls = False +# latex_show_urls = False # Documents to append as an appendix to all manuals. -#latex_appendices = [] +# latex_appendices = [] # If false, no module index is generated. -#latex_domain_indices = True +# latex_domain_indices = True # -- Options for manual page output --------------------------------------- # One entry per manual page. List of tuples # (source start file, name, description, authors, manual section). -man_pages = [ - (master_doc, 'pybind11', 'pybind11 Documentation', - [author], 1) -] +man_pages = [(master_doc, "pybind11", "pybind11 Documentation", [author], 1)] # If true, show URL addresses after external links. -#man_show_urls = False +# man_show_urls = False # -- Options for Texinfo output ------------------------------------------- @@ -292,41 +308,70 @@ # (source start file, target name, title, author, # dir menu entry, description, category) texinfo_documents = [ - (master_doc, 'pybind11', 'pybind11 Documentation', - author, 'pybind11', 'One line description of project.', - 'Miscellaneous'), + ( + master_doc, + "pybind11", + "pybind11 Documentation", + author, + "pybind11", + "One line description of project.", + "Miscellaneous", + ), ] # Documents to append as an appendix to all manuals. -#texinfo_appendices = [] +# texinfo_appendices = [] # If false, no module index is generated. -#texinfo_domain_indices = True +# texinfo_domain_indices = True # How to display URL addresses: 'footnote', 'no', or 'inline'. -#texinfo_show_urls = 'footnote' +# texinfo_show_urls = 'footnote' # If true, do not generate a @detailmenu in the "Top" node's menu. -#texinfo_no_detailmenu = False +# texinfo_no_detailmenu = False -primary_domain = 'cpp' -highlight_language = 'cpp' +primary_domain = "cpp" +highlight_language = "cpp" def generate_doxygen_xml(app): - build_dir = os.path.join(app.confdir, '.build') + build_dir = os.path.join(app.confdir, ".build") if not os.path.exists(build_dir): os.mkdir(build_dir) try: - subprocess.call(['doxygen', '--version']) - retcode = subprocess.call(['doxygen'], cwd=app.confdir) + subprocess.call(["doxygen", "--version"]) + retcode = subprocess.call(["doxygen"], cwd=app.confdir) if retcode < 0: sys.stderr.write("doxygen error code: {}\n".format(-retcode)) except OSError as e: sys.stderr.write("doxygen execution failed: {}\n".format(e)) +def prepare(app): + with open(DIR.parent / "README.rst") as f: + contents = f.read() + + # Filter out section titles for index.rst for LaTeX + if app.builder.name == "latex": + contents = re.sub(r"^(.*)\n[-~]{3,}$", r"**\1**", contents, flags=re.MULTILINE) + + with open(DIR / "readme.rst", "w") as f: + f.write(contents) + + +def clean_up(app, exception): + (DIR / "readme.rst").unlink() + + def setup(app): - """Add hook for building doxygen xml when needed""" + + # Add hook for building doxygen xml when needed app.connect("builder-inited", generate_doxygen_xml) + + # Copy the readme in + app.connect("builder-inited", prepare) + + # Clean up the generated readme + app.connect("build-finished", clean_up) diff --git a/plugins/python/pybind11/docs/faq.rst b/plugins/python/pybind11/docs/faq.rst index 530f1ce..8bf05a4 100644 --- a/plugins/python/pybind11/docs/faq.rst +++ b/plugins/python/pybind11/docs/faq.rst @@ -4,9 +4,13 @@ Frequently asked questions "ImportError: dynamic module does not define init function" =========================================================== -You are likely using an incompatible version of Python (for instance, the -extension library was compiled against Python 2, while the interpreter is -running on top of some version of Python 3, or vice versa). +1. Make sure that the name specified in PYBIND11_MODULE is identical to the +filename of the extension library (without suffixes such as .so) + +2. If the above did not fix the issue, you are likely using an incompatible +version of Python (for instance, the extension library was compiled against +Python 2, while the interpreter is running on top of some version of Python +3, or vice versa). "Symbol not found: ``__Py_ZeroStruct`` / ``_PyInstanceMethod_Type``" ======================================================================== @@ -23,17 +27,7 @@ The Python interpreter immediately crashes when importing my module See the first answer. -CMake doesn't detect the right Python version -============================================= - -The CMake-based build system will try to automatically detect the installed -version of Python and link against that. When this fails, or when there are -multiple versions of Python and it finds the wrong one, delete -``CMakeCache.txt`` and then invoke CMake as follows: - -.. code-block:: bash - - cmake -DPYTHON_EXECUTABLE:FILEPATH= . +.. _faq_reference_arguments: Limitations involving reference arguments ========================================= @@ -94,8 +88,8 @@ following example: .. code-block:: cpp - void init_ex1(py::module &); - void init_ex2(py::module &); + void init_ex1(py::module_ &); + void init_ex2(py::module_ &); /* ... */ PYBIND11_MODULE(example, m) { @@ -108,7 +102,7 @@ following example: .. code-block:: cpp - void init_ex1(py::module &m) { + void init_ex1(py::module_ &m) { m.def("add", [](int a, int b) { return a + b; }); } @@ -116,7 +110,7 @@ following example: .. code-block:: cpp - void init_ex2(py::module &m) { + void init_ex2(py::module_ &m) { m.def("sub", [](int a, int b) { return a - b; }); } @@ -228,50 +222,111 @@ In addition to decreasing binary size, ``-fvisibility=hidden`` also avoids potential serious issues when loading multiple modules and is required for proper pybind operation. See the previous FAQ entry for more details. -Another aspect that can require a fair bit of code are function signature -descriptions. pybind11 automatically generates human-readable function -signatures for docstrings, e.g.: - -.. code-block:: none - - | __init__(...) - | __init__(*args, **kwargs) - | Overloaded function. - | - | 1. __init__(example.Example1) -> NoneType - | - | Docstring for overload #1 goes here - | - | 2. __init__(example.Example1, int) -> NoneType - | - | Docstring for overload #2 goes here - | - | 3. __init__(example.Example1, example.Example1) -> NoneType - | - | Docstring for overload #3 goes here - - -In C++11 mode, these are generated at run time using string concatenation, -which can amount to 10-20% of the size of the resulting binary. If you can, -enable C++14 language features (using ``-std=c++14`` for GCC/Clang), in which -case signatures are efficiently pre-generated at compile time. Unfortunately, -Visual Studio's C++14 support (``constexpr``) is not good enough as of April -2016, so it always uses the more expensive run-time approach. - -Working with ancient Visual Studio 2009 builds on Windows +Working with ancient Visual Studio 2008 builds on Windows ========================================================= The official Windows distributions of Python are compiled using truly ancient versions of Visual Studio that lack good C++11 support. Some users implicitly assume that it would be impossible to load a plugin built with Visual Studio 2015 into a Python distribution that was compiled using Visual -Studio 2009. However, no such issue exists: it's perfectly legitimate to +Studio 2008. However, no such issue exists: it's perfectly legitimate to interface DLLs that are built with different compilers and/or C libraries. Common gotchas to watch out for involve not ``free()``-ing memory region that that were ``malloc()``-ed in another shared library, using data structures with incompatible ABIs, and so on. pybind11 is very careful not to make these types of mistakes. +How can I properly handle Ctrl-C in long-running functions? +=========================================================== + +Ctrl-C is received by the Python interpreter, and holds it until the GIL +is released, so a long-running function won't be interrupted. + +To interrupt from inside your function, you can use the ``PyErr_CheckSignals()`` +function, that will tell if a signal has been raised on the Python side. This +function merely checks a flag, so its impact is negligible. When a signal has +been received, you must either explicitly interrupt execution by throwing +``py::error_already_set`` (which will propagate the existing +``KeyboardInterrupt``), or clear the error (which you usually will not want): + +.. code-block:: cpp + + PYBIND11_MODULE(example, m) + { + m.def("long running_func", []() + { + for (;;) { + if (PyErr_CheckSignals() != 0) + throw py::error_already_set(); + // Long running iteration + } + }); + } + +CMake doesn't detect the right Python version +============================================= + +The CMake-based build system will try to automatically detect the installed +version of Python and link against that. When this fails, or when there are +multiple versions of Python and it finds the wrong one, delete +``CMakeCache.txt`` and then add ``-DPYTHON_EXECUTABLE=$(which python)`` to your +CMake configure line. (Replace ``$(which python)`` with a path to python if +your prefer.) + +You can alternatively try ``-DPYBIND11_FINDPYTHON=ON``, which will activate the +new CMake FindPython support instead of pybind11's custom search. Requires +CMake 3.12+, and 3.15+ or 3.18.2+ are even better. You can set this in your +``CMakeLists.txt`` before adding or finding pybind11, as well. + +Inconsistent detection of Python version in CMake and pybind11 +============================================================== + +The functions ``find_package(PythonInterp)`` and ``find_package(PythonLibs)`` +provided by CMake for Python version detection are modified by pybind11 due to +unreliability and limitations that make them unsuitable for pybind11's needs. +Instead pybind11 provides its own, more reliable Python detection CMake code. +Conflicts can arise, however, when using pybind11 in a project that *also* uses +the CMake Python detection in a system with several Python versions installed. + +This difference may cause inconsistencies and errors if *both* mechanisms are +used in the same project. Consider the following CMake code executed in a +system with Python 2.7 and 3.x installed: + +.. code-block:: cmake + + find_package(PythonInterp) + find_package(PythonLibs) + find_package(pybind11) + +It will detect Python 2.7 and pybind11 will pick it as well. + +In contrast this code: + +.. code-block:: cmake + + find_package(pybind11) + find_package(PythonInterp) + find_package(PythonLibs) + +will detect Python 3.x for pybind11 and may crash on +``find_package(PythonLibs)`` afterwards. + +There are three possible solutions: + +1. Avoid using ``find_package(PythonInterp)`` and ``find_package(PythonLibs)`` + from CMake and rely on pybind11 in detecting Python version. If this is not + possible, the CMake machinery should be called *before* including pybind11. +2. Set ``PYBIND11_FINDPYTHON`` to ``True`` or use ``find_package(Python + COMPONENTS Interpreter Development)`` on modern CMake (3.12+, 3.15+ better, + 3.18.2+ best). Pybind11 in these cases uses the new CMake FindPython instead + of the old, deprecated search tools, and these modules are much better at + finding the correct Python. +3. Set ``PYBIND11_NOPYTHON`` to ``TRUE``. Pybind11 will not search for Python. + However, you will have to use the target-based system, and do more setup + yourself, because it does not know about or include things that depend on + Python, like ``pybind11_add_module``. This might be ideal for integrating + into an existing system, like scikit-build's Python helpers. + How to cite this project? ========================= @@ -286,4 +341,3 @@ discourse: note = {https://github.com/pybind/pybind11}, title = {pybind11 -- Seamless operability between C++11 and Python} } - diff --git a/plugins/python/pybind11/docs/index.rst b/plugins/python/pybind11/docs/index.rst index d236611..4e2e8ca 100644 --- a/plugins/python/pybind11/docs/index.rst +++ b/plugins/python/pybind11/docs/index.rst @@ -1,18 +1,17 @@ -.. only: not latex +.. only:: latex - .. image:: pybind11-logo.png + Intro + ===== -pybind11 --- Seamless operability between C++11 and Python -========================================================== +.. include:: readme.rst -.. only: not latex +.. only:: not latex Contents: .. toctree:: :maxdepth: 1 - intro changelog upgrade @@ -20,6 +19,7 @@ pybind11 --- Seamless operability between C++11 and Python :caption: The Basics :maxdepth: 2 + installing basics classes compiling @@ -45,3 +45,4 @@ pybind11 --- Seamless operability between C++11 and Python benchmark limitations reference + cmake/index diff --git a/plugins/python/pybind11/docs/installing.rst b/plugins/python/pybind11/docs/installing.rst new file mode 100644 index 0000000..2597285 --- /dev/null +++ b/plugins/python/pybind11/docs/installing.rst @@ -0,0 +1,103 @@ +.. _installing: + +Installing the library +###################### + +There are several ways to get the pybind11 source, which lives at +`pybind/pybind11 on GitHub `_. The pybind11 +developers recommend one of the first three ways listed here, submodule, PyPI, +or conda-forge, for obtaining pybind11. + +Include as a submodule +====================== + +When you are working on a project in Git, you can use the pybind11 repository +as a submodule. From your git repository, use: + +.. code-block:: bash + + git submodule add ../../pybind/pybind11 extern/pybind11 -b stable + git submodule update --init + +This assumes you are placing your dependencies in ``extern/``, and that you are +using GitHub; if you are not using GitHub, use the full https or ssh URL +instead of the relative URL ``../../pybind/pybind11`` above. Some other servers +also require the ``.git`` extension (GitHub does not). + +From here, you can now include ``extern/pybind11/include``, or you can use +the various integration tools (see :ref:`compiling`) pybind11 provides directly +from the local folder. + +Include with PyPI +================= + +You can download the sources and CMake files as a Python package from PyPI +using Pip. Just use: + +.. code-block:: bash + + pip install pybind11 + +This will provide pybind11 in a standard Python package format. If you want +pybind11 available directly in your environment root, you can use: + +.. code-block:: bash + + pip install "pybind11[global]" + +This is not recommended if you are installing with your system Python, as it +will add files to ``/usr/local/include/pybind11`` and +``/usr/local/share/cmake/pybind11``, so unless that is what you want, it is +recommended only for use in virtual environments or your ``pyproject.toml`` +file (see :ref:`compiling`). + +Include with conda-forge +======================== + +You can use pybind11 with conda packaging via `conda-forge +`_: + +.. code-block:: bash + + conda install -c conda-forge pybind11 + + +Include with vcpkg +================== +You can download and install pybind11 using the Microsoft `vcpkg +`_ dependency manager: + +.. code-block:: bash + + git clone https://github.com/Microsoft/vcpkg.git + cd vcpkg + ./bootstrap-vcpkg.sh + ./vcpkg integrate install + vcpkg install pybind11 + +The pybind11 port in vcpkg is kept up to date by Microsoft team members and +community contributors. If the version is out of date, please `create an issue +or pull request `_ on the vcpkg +repository. + +Global install with brew +======================== + +The brew package manager (Homebrew on macOS, or Linuxbrew on Linux) has a +`pybind11 package +`_. +To install: + +.. code-block:: bash + + brew install pybind11 + +.. We should list Conan, and possibly a few other C++ package managers (hunter, +.. perhaps). Conan has a very clean CMake integration that would be good to show. + +Other options +============= + +Other locations you can find pybind11 are `listed here +`_; these are maintained +by various packagers and the community. diff --git a/plugins/python/pybind11/docs/intro.rst b/plugins/python/pybind11/docs/intro.rst deleted file mode 100644 index ea03ef9..0000000 --- a/plugins/python/pybind11/docs/intro.rst +++ /dev/null @@ -1,95 +0,0 @@ -.. image:: pybind11-logo.png - -About this project -================== -**pybind11** is a lightweight header-only library that exposes C++ types in Python -and vice versa, mainly to create Python bindings of existing C++ code. Its -goals and syntax are similar to the excellent `Boost.Python`_ library by David -Abrahams: to minimize boilerplate code in traditional extension modules by -inferring type information using compile-time introspection. - -.. _Boost.Python: http://www.boost.org/doc/libs/release/libs/python/doc/index.html - -The main issue with Boost.Python—and the reason for creating such a similar -project—is Boost. Boost is an enormously large and complex suite of utility -libraries that works with almost every C++ compiler in existence. This -compatibility has its cost: arcane template tricks and workarounds are -necessary to support the oldest and buggiest of compiler specimens. Now that -C++11-compatible compilers are widely available, this heavy machinery has -become an excessively large and unnecessary dependency. -Think of this library as a tiny self-contained version of Boost.Python with -everything stripped away that isn't relevant for binding generation. Without -comments, the core header files only require ~4K lines of code and depend on -Python (2.7 or 3.x, or PyPy2.7 >= 5.7) and the C++ standard library. This -compact implementation was possible thanks to some of the new C++11 language -features (specifically: tuples, lambda functions and variadic templates). Since -its creation, this library has grown beyond Boost.Python in many ways, leading -to dramatically simpler binding code in many common situations. - -Core features -************* -The following core C++ features can be mapped to Python - -- Functions accepting and returning custom data structures per value, reference, or pointer -- Instance methods and static methods -- Overloaded functions -- Instance attributes and static attributes -- Arbitrary exception types -- Enumerations -- Callbacks -- Iterators and ranges -- Custom operators -- Single and multiple inheritance -- STL data structures -- Iterators and ranges -- Smart pointers with reference counting like ``std::shared_ptr`` -- Internal references with correct reference counting -- C++ classes with virtual (and pure virtual) methods can be extended in Python - -Goodies -******* -In addition to the core functionality, pybind11 provides some extra goodies: - -- Python 2.7, 3.x, and PyPy (PyPy2.7 >= 5.7) are supported with an - implementation-agnostic interface. - -- It is possible to bind C++11 lambda functions with captured variables. The - lambda capture data is stored inside the resulting Python function object. - -- pybind11 uses C++11 move constructors and move assignment operators whenever - possible to efficiently transfer custom data types. - -- It's easy to expose the internal storage of custom data types through - Pythons' buffer protocols. This is handy e.g. for fast conversion between - C++ matrix classes like Eigen and NumPy without expensive copy operations. - -- pybind11 can automatically vectorize functions so that they are transparently - applied to all entries of one or more NumPy array arguments. - -- Python's slice-based access and assignment operations can be supported with - just a few lines of code. - -- Everything is contained in just a few header files; there is no need to link - against any additional libraries. - -- Binaries are generally smaller by a factor of at least 2 compared to - equivalent bindings generated by Boost.Python. A recent pybind11 conversion - of `PyRosetta`_, an enormous Boost.Python binding project, reported a binary - size reduction of **5.4x** and compile time reduction by **5.8x**. - -- When supported by the compiler, two new C++14 features (relaxed constexpr and - return value deduction) are used to precompute function signatures at compile - time, leading to smaller binaries. - -- With little extra effort, C++ types can be pickled and unpickled similar to - regular Python objects. - -.. _PyRosetta: http://graylab.jhu.edu/RosettaCon2016/PyRosetta-4.pdf - -Supported compilers -******************* - -1. Clang/LLVM (any non-ancient version with C++11 support) -2. GCC 4.8 or newer -3. Microsoft Visual Studio 2015 or newer -4. Intel C++ compiler v17 or newer (v16 with pybind11 v2.0 and v15 with pybind11 v2.0 and a `workaround `_ ) diff --git a/plugins/python/pybind11/docs/limitations.rst b/plugins/python/pybind11/docs/limitations.rst index a1a4f1a..be7300c 100644 --- a/plugins/python/pybind11/docs/limitations.rst +++ b/plugins/python/pybind11/docs/limitations.rst @@ -1,6 +1,9 @@ Limitations ########### +Design choices +^^^^^^^^^^^^^^ + pybind11 strives to be a general solution to binding generation, but it also has certain limitations: @@ -11,10 +14,59 @@ certain limitations: - The NumPy interface ``pybind11::array`` greatly simplifies accessing numerical data from C++ (and vice versa), but it's not a full-blown array - class like ``Eigen::Array`` or ``boost.multi_array``. + class like ``Eigen::Array`` or ``boost.multi_array``. ``Eigen`` objects are + directly supported, however, with ``pybind11/eigen.h``. + +Large but useful features could be implemented in pybind11 but would lead to a +significant increase in complexity. Pybind11 strives to be simple and compact. +Users who require large new features are encouraged to write an extension to +pybind11; see `pybind11_json `_ for an +example. + + +Known bugs +^^^^^^^^^^ + +These are issues that hopefully will one day be fixed, but currently are +unsolved. If you know how to help with one of these issues, contributions +are welcome! + +- Intel 20.2 is currently having an issue with the test suite. + `#2573 `_ + +- Debug mode Python does not support 1-5 tests in the test suite currently. + `#2422 `_ + +- PyPy3 7.3.1 and 7.3.2 have issues with several tests on 32-bit Windows. + +Known limitations +^^^^^^^^^^^^^^^^^ + +These are issues that are probably solvable, but have not been fixed yet. A +clean, well written patch would likely be accepted to solve them. + +- Type casters are not kept alive recursively. + `#2527 `_ + One consequence is that containers of ``char *`` are currently not supported. + `#2245 `_ + +- The ``cpptest`` does not run on Windows with Python 3.8 or newer, due to DLL + loader changes. User code that is correctly installed should not be affected. + `#2560 `_ + +Python 3.9.0 warning +^^^^^^^^^^^^^^^^^^^^ -These features could be implemented but would lead to a significant increase in -complexity. I've decided to draw the line here to keep this project simple and -compact. Users who absolutely require these features are encouraged to fork -pybind11. +Combining older versions of pybind11 (< 2.6.0) with Python on 3.9.0 will +trigger undefined behavior that typically manifests as crashes during +interpreter shutdown (but could also destroy your data. **You have been +warned**). +This issue has been +`fixed in Python `_. As a +mitigation until 3.9.1 is released and commonly used, pybind11 (2.6.0 or newer) +includes a temporary workaround specifically when Python 3.9.0 is detected at +runtime, leaking about 50 bytes of memory when a callback function is garbage +collected. For reference; the pybind11 test suite has about 2,000 such +callbacks, but only 49 are garbage collected before the end-of-process. Wheels +built with Python 3.9.0 will correctly avoid the leak when run in Python 3.9.1. diff --git a/plugins/python/pybind11/docs/reference.rst b/plugins/python/pybind11/docs/reference.rst index 3f74849..e3a61af 100644 --- a/plugins/python/pybind11/docs/reference.rst +++ b/plugins/python/pybind11/docs/reference.rst @@ -46,7 +46,7 @@ With reference counting Convenience classes for specific Python types ============================================= -.. doxygenclass:: module +.. doxygenclass:: module_ :members: .. doxygengroup:: pytypes @@ -86,6 +86,21 @@ Python built-in functions .. doxygengroup:: python_builtins :members: +Inheritance +=========== + +See :doc:`/classes` and :doc:`/advanced/classes` for more detail. + +.. doxygendefine:: PYBIND11_OVERRIDE + +.. doxygendefine:: PYBIND11_OVERRIDE_PURE + +.. doxygendefine:: PYBIND11_OVERRIDE_NAME + +.. doxygendefine:: PYBIND11_OVERRIDE_PURE_NAME + +.. doxygenfunction:: get_override + Exceptions ========== diff --git a/plugins/python/pybind11/docs/release.rst b/plugins/python/pybind11/docs/release.rst index b31bbe9..43f502a 100644 --- a/plugins/python/pybind11/docs/release.rst +++ b/plugins/python/pybind11/docs/release.rst @@ -1,25 +1,77 @@ +On version numbers +^^^^^^^^^^^^^^^^^^ + +The two version numbers (C++ and Python) must match when combined (checked when +you build the PyPI package), and must be a valid `PEP 440 +`_ version when combined. + +For example: + +.. code-block:: C++ + + #define PYBIND11_VERSION_MAJOR X + #define PYBIND11_VERSION_MINOR Y + #define PYBIND11_VERSION_PATCH Z.dev1 + +For beta, ``PYBIND11_VERSION_PATCH`` should be ``Z.b1``. RC's can be ``Z.rc1``. +Always include the dot (even though PEP 440 allows it to be dropped). For a +final release, this must be a simple integer. + + To release a new version of pybind11: +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -- Update the version number and push to pypi - - Update ``pybind11/_version.py`` (set release version, remove 'dev'). - - Update ``PYBIND11_VERSION_MAJOR`` etc. in ``include/pybind11/detail/common.h``. - - Ensure that all the information in ``setup.py`` is up-to-date. - - Update version in ``docs/conf.py``. - - Tag release date in ``docs/changelog.rst``. - - ``git add`` and ``git commit``. - - if new minor version: ``git checkout -b vX.Y``, ``git push -u origin vX.Y`` - - ``git tag -a vX.Y.Z -m 'vX.Y.Z release'``. +- Update the version number + - Update ``PYBIND11_VERSION_MAJOR`` etc. in + ``include/pybind11/detail/common.h``. PATCH should be a simple integer. + - Update ``pybind11/_version.py`` (match above) + - Ensure that all the information in ``setup.py`` is up-to-date. + - Add release date in ``docs/changelog.rst``. + - ``git add`` and ``git commit``, ``git push``. **Ensure CI passes**. (If it + fails due to a known flake issue, either ignore or restart CI.) +- Add a release branch if this is a new minor version + - ``git checkout -b vX.Y``, ``git push -u origin vX.Y`` +- Update tags (optional; if you skip this, the GitHub release makes a + non-annotated tag for you) + - ``git tag -a vX.Y.Z -m 'vX.Y.Z release'``. + - ``git push --tags``. +- Update stable + - ``git checkout stable`` + - ``git merge master`` - ``git push`` - - ``git push --tags``. - - ``python setup.py sdist upload``. - - ``python setup.py bdist_wheel upload``. -- Update conda-forge (https://github.com/conda-forge/pybind11-feedstock) via PR - - download release package from Github: ``wget https://github.com/pybind/pybind11/archive/vX.Y.Z.tar.gz`` - - compute checksum: ``shasum -a 256 vX.Y.Z.tar.gz`` - - change version number and checksum in ``recipe/meta.yml`` +- Make a GitHub release (this shows up in the UI, sends new release + notifications to users watching releases, and also uploads PyPI packages). + (Note: if you do not use an existing tag, this creates a new lightweight tag + for you, so you could skip the above step). + - GUI method: click "Create a new release" on the far right, fill in the tag + name (if you didn't tag above, it will be made here), fill in a release + name like "Version X.Y.Z", and optionally copy-and-paste the changelog into + the description (processed as markdown by Pandoc). Check "pre-release" if + this is a beta/RC. + - CLI method: with ``gh`` installed, run ``gh release create vX.Y.Z -t "Version X.Y.Z"`` + If this is a pre-release, add ``-p``. + - Get back to work - - Update ``_version.py`` (add 'dev' and increment minor). - - Update version in ``docs/conf.py`` - - Update version macros in ``include/pybind11/common.h`` - - ``git add`` and ``git commit``. - ``git push`` + - Make sure you are on master, not somewhere else: ``git checkout master`` + - Update version macros in ``include/pybind11/detail/common.h`` (set PATCH to + ``0.dev1`` and increment MINOR). + - Update ``_version.py`` to match + - Add a plot for in-development updates in ``docs/changelog.rst``. + - ``git add``, ``git commit``, ``git push`` + +If a version branch is updated, remember to set PATCH to ``1.dev1``. + + +Manual packaging +^^^^^^^^^^^^^^^^ + +If you need to manually upload releases, you can download the releases from the job artifacts and upload them with twine. You can also make the files locally (not recommended in general, as your local directory is more likely to be "dirty" and SDists love picking up random unrelated/hidden files); this is the procedure: + +.. code-block:: bash + + python3 -m pip install build + python3 -m build + PYBIND11_SDIST_GLOBAL=1 python3 -m build + twine upload dist/* + +This makes SDists and wheels, and the final line uploads them. diff --git a/plugins/python/pybind11/docs/requirements.txt b/plugins/python/pybind11/docs/requirements.txt index 3818fe8..35366e3 100644 --- a/plugins/python/pybind11/docs/requirements.txt +++ b/plugins/python/pybind11/docs/requirements.txt @@ -1 +1,7 @@ -breathe == 4.5.0 +breathe==4.20.0 +commonmark==0.9.1 +recommonmark==0.6.0 +sphinx==3.2.1 +sphinx_rtd_theme==0.5.0 +sphinxcontrib-moderncmakedomain==3.13 +sphinxcontrib-svg2pdfconverter==1.1.0 diff --git a/plugins/python/pybind11/docs/upgrade.rst b/plugins/python/pybind11/docs/upgrade.rst index 3f56973..87bcebe 100644 --- a/plugins/python/pybind11/docs/upgrade.rst +++ b/plugins/python/pybind11/docs/upgrade.rst @@ -8,6 +8,114 @@ to a new version. But it goes into more detail. This includes things like deprecated APIs and their replacements, build system changes, general code modernization and other useful information. +.. _upgrade-guide-2.6: + +v2.6 +==== + +Usage of the ``PYBIND11_OVERLOAD*`` macros and ``get_overload`` function should +be replaced by ``PYBIND11_OVERRIDE*`` and ``get_override``. In the future, the +old macros may be deprecated and removed. + +``py::module`` has been renamed ``py::module_``, but a backward compatible +typedef has been included. This change was to avoid a language change in C++20 +that requires unqualified ``module`` not be placed at the start of a logical +line. Qualified usage is unaffected and the typedef will remain unless the +C++ language rules change again. + +The public constructors of ``py::module_`` have been deprecated. Use +``PYBIND11_MODULE`` or ``module_::create_extension_module`` instead. + +An error is now thrown when ``__init__`` is forgotten on subclasses. This was +incorrect before, but was not checked. Add a call to ``__init__`` if it is +missing. + +A ``py::type_error`` is now thrown when casting to a subclass (like +``py::bytes`` from ``py::object``) if the conversion is not valid. Make a valid +conversion instead. + +The undocumented ``h.get_type()`` method has been deprecated and replaced by +``py::type::of(h)``. + +Enums now have a ``__str__`` method pre-defined; if you want to override it, +the simplest fix is to add the new ``py::prepend()`` tag when defining +``"__str__"``. + +If ``__eq__`` defined but not ``__hash__``, ``__hash__`` is now set to +``None``, as in normal CPython. You should add ``__hash__`` if you intended the +class to be hashable, possibly using the new ``py::hash`` shortcut. + +The constructors for ``py::array`` now always take signed integers for size, +for consistency. This may lead to compiler warnings on some systems. Cast to +``py::ssize_t`` instead of ``std::size_t``. + +The ``tools/clang`` submodule and ``tools/mkdoc.py`` have been moved to a +standalone package, `pybind11-mkdoc`_. If you were using those tools, please +use them via a pip install from the new location. + +The ``pybind11`` package on PyPI no longer fills the wheel "headers" slot - if +you were using the headers from this slot, they are available by requesting the +``global`` extra, that is, ``pip install "pybind11[global]"``. (Most users will +be unaffected, as the ``pybind11/include`` location is reported by ``python -m +pybind11 --includes`` and ``pybind11.get_include()`` is still correct and has +not changed since 2.5). + +.. _pybind11-mkdoc: https://github.com/pybind/pybind11-mkdoc + +CMake support: +-------------- + +The minimum required version of CMake is now 3.4. Several details of the CMake +support have been deprecated; warnings will be shown if you need to change +something. The changes are: + +* ``PYBIND11_CPP_STANDARD=`` is deprecated, please use + ``CMAKE_CXX_STANDARD=`` instead, or any other valid CMake CXX or CUDA + standard selection method, like ``target_compile_features``. + +* If you do not request a standard, pybind11 targets will compile with the + compiler default, but not less than C++11, instead of forcing C++14 always. + If you depend on the old behavior, please use ``set(CMAKE_CXX_STANDARD 14 CACHE STRING "")`` + instead. + +* Direct ``pybind11::module`` usage should always be accompanied by at least + ``set(CMAKE_CXX_VISIBILITY_PRESET hidden)`` or similar - it used to try to + manually force this compiler flag (but not correctly on all compilers or with + CUDA). + +* ``pybind11_add_module``'s ``SYSTEM`` argument is deprecated and does nothing; + linking now behaves like other imported libraries consistently in both + config and submodule mode, and behaves like a ``SYSTEM`` library by + default. + +* If ``PYTHON_EXECUTABLE`` is not set, virtual environments (``venv``, + ``virtualenv``, and ``conda``) are prioritized over the standard search + (similar to the new FindPython mode). + +In addition, the following changes may be of interest: + +* ``CMAKE_INTERPROCEDURAL_OPTIMIZATION`` will be respected by + ``pybind11_add_module`` if set instead of linking to ``pybind11::lto`` or + ``pybind11::thin_lto``. + +* Using ``find_package(Python COMPONENTS Interpreter Development)`` before + pybind11 will cause pybind11 to use the new Python mechanisms instead of its + own custom search, based on a patched version of classic ``FindPythonInterp`` + / ``FindPythonLibs``. In the future, this may become the default. A recent + (3.15+ or 3.18.2+) version of CMake is recommended. + + + +v2.5 +==== + +The Python package now includes the headers as data in the package itself, as +well as in the "headers" wheel slot. ``pybind11 --includes`` and +``pybind11.get_include()`` report the new location, which is always correct +regardless of how pybind11 was installed, making the old ``user=`` argument +meaningless. If you are not using the function to get the location already, you +are encouraged to switch to the package location. + v2.2 ==== diff --git a/plugins/python/pybind11/include/pybind11/attr.h b/plugins/python/pybind11/include/pybind11/attr.h index dce875a..0c41670 100644 --- a/plugins/python/pybind11/include/pybind11/attr.h +++ b/plugins/python/pybind11/include/pybind11/attr.h @@ -12,7 +12,7 @@ #include "cast.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) /// \addtogroup annotations /// @{ @@ -23,6 +23,9 @@ struct is_method { handle class_; is_method(const handle &c) : class_(c) { } }; /// Annotation for operators struct is_operator { }; +/// Annotation for classes that cannot be subclassed +struct is_final { }; + /// Annotation for parent scope struct scope { handle value; scope(const handle &s) : value(s) { } }; @@ -37,8 +40,9 @@ struct sibling { handle value; sibling(const handle &value) : value(value.ptr()) /// Annotation indicating that a class derives from another given type template struct base { + PYBIND11_DEPRECATED("base() was deprecated in favor of specifying 'T' as a template argument to class_") - base() { } + base() { } // NOLINT(modernize-use-equals-default): breaks MSVC 2015 when adding an attribute }; /// Keep patient alive while nurse lives @@ -58,7 +62,7 @@ struct metaclass { handle value; PYBIND11_DEPRECATED("py::metaclass() is no longer required. It's turned on by default now.") - metaclass() {} + metaclass() { } // NOLINT(modernize-use-equals-default): breaks MSVC 2015 when adding an attribute /// Override pybind11's default metaclass explicit metaclass(handle value) : value(value) { } @@ -70,6 +74,9 @@ struct module_local { const bool value; constexpr module_local(bool v = true) : /// Annotation to mark enums as an arithmetic type struct arithmetic { }; +/// Mark a function for addition at the beginning of the existing overload chain instead of the end +struct prepend { }; + /** \rst A call policy which places one or more guard variables (``Ts...``) around the function call. @@ -110,7 +117,7 @@ struct call_guard { /// @} annotations -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) /* Forward declarations */ enum op_id : int; enum op_type : int; @@ -134,7 +141,8 @@ struct argument_record { struct function_record { function_record() : is_constructor(false), is_new_style_constructor(false), is_stateless(false), - is_operator(false), has_args(false), has_kwargs(false), is_method(false) { } + is_operator(false), is_method(false), has_args(false), + has_kwargs(false), has_kw_only_args(false), prepend(false) { } /// Function name char *name = nullptr; /* why no C++ strings? They generate heavier code.. */ @@ -172,18 +180,30 @@ struct function_record { /// True if this is an operator (__add__), etc. bool is_operator : 1; + /// True if this is a method + bool is_method : 1; + /// True if the function has a '*args' argument bool has_args : 1; /// True if the function has a '**kwargs' argument bool has_kwargs : 1; - /// True if this is a method - bool is_method : 1; + /// True once a 'py::kw_only' is encountered (any following args are keyword-only) + bool has_kw_only_args : 1; + + /// True if this function is to be inserted at the beginning of the overload resolution chain + bool prepend : 1; /// Number of arguments (including py::args and/or py::kwargs, if present) std::uint16_t nargs; + /// Number of trailing arguments (counted in `nargs`) that are keyword-only + std::uint16_t nargs_kw_only = 0; + + /// Number of leading arguments (counted in `nargs`) that are positional-only + std::uint16_t nargs_pos_only = 0; + /// Python method object PyMethodDef *def = nullptr; @@ -200,7 +220,8 @@ struct function_record { /// Special data structure which (temporarily) holds metadata about a bound class struct type_record { PYBIND11_NOINLINE type_record() - : multiple_inheritance(false), dynamic_attr(false), buffer_protocol(false), module_local(false) { } + : multiple_inheritance(false), dynamic_attr(false), buffer_protocol(false), + default_holder(true), module_local(false), is_final(false) { } /// Handle to the parent scope handle scope; @@ -214,11 +235,14 @@ struct type_record { /// How large is the underlying C++ type? size_t type_size = 0; + /// What is the alignment of the underlying C++ type? + size_t type_align = 0; + /// How large is the type's holder? size_t holder_size = 0; /// The global operator new can be overridden with a class-specific variant - void *(*operator_new)(size_t) = ::operator new; + void *(*operator_new)(size_t) = nullptr; /// Function pointer to class_<..>::init_instance void (*init_instance)(instance *, const void *) = nullptr; @@ -250,6 +274,9 @@ struct type_record { /// Is the class definition local to the module shared object? bool module_local : 1; + /// Is the class inheritable from python classes? + bool is_final : 1; + PYBIND11_NOINLINE void add_base(const std::type_info &base, void *(*caster)(void *)) { auto base_info = detail::get_type_info(base, false); if (!base_info) { @@ -278,7 +305,7 @@ struct type_record { } }; -inline function_call::function_call(function_record &f, handle p) : +inline function_call::function_call(const function_record &f, handle p) : func(f), parent(p) { args.reserve(f.nargs); args_convert.reserve(f.nargs); @@ -349,12 +376,20 @@ template <> struct process_attribute : process_attribu static void init(const is_new_style_constructor &, function_record *r) { r->is_new_style_constructor = true; } }; +inline void process_kw_only_arg(const arg &a, function_record *r) { + if (!a.name || strlen(a.name) == 0) + pybind11_fail("arg(): cannot specify an unnamed argument after an kw_only() annotation"); + ++r->nargs_kw_only; +} + /// Process a keyword argument attribute (*without* a default value) template <> struct process_attribute : process_attribute_default { static void init(const arg &a, function_record *r) { if (r->is_method && r->args.empty()) r->args.emplace_back("self", nullptr, handle(), true /*convert*/, false /*none not allowed*/); r->args.emplace_back(a.name, nullptr, handle(), !a.flag_noconvert, a.flag_none); + + if (r->has_kw_only_args) process_kw_only_arg(a, r); } }; @@ -386,6 +421,22 @@ template <> struct process_attribute : process_attribute_default { #endif } r->args.emplace_back(a.name, a.descr, a.value.inc_ref(), !a.flag_noconvert, a.flag_none); + + if (r->has_kw_only_args) process_kw_only_arg(a, r); + } +}; + +/// Process a keyword-only-arguments-follow pseudo argument +template <> struct process_attribute : process_attribute_default { + static void init(const kw_only &, function_record *r) { + r->has_kw_only_args = true; + } +}; + +/// Process a positional-only-argument maker +template <> struct process_attribute : process_attribute_default { + static void init(const pos_only &, function_record *r) { + r->nargs_pos_only = static_cast(r->args.size()); } }; @@ -412,6 +463,11 @@ struct process_attribute : process_attribute_default static void init(const dynamic_attr &, type_record *r) { r->dynamic_attr = true; } }; +template <> +struct process_attribute : process_attribute_default { + static void init(const is_final &, type_record *r) { r->is_final = true; } +}; + template <> struct process_attribute : process_attribute_default { static void init(const buffer_protocol &, type_record *r) { r->buffer_protocol = true; } @@ -427,6 +483,12 @@ struct process_attribute : process_attribute_default static void init(const module_local &l, type_record *r) { r->module_local = l.value; } }; +/// Process a 'prepend' attribute, putting this at the beginning of the overload chain +template <> +struct process_attribute : process_attribute_default { + static void init(const prepend &, function_record *r) { r->prepend = true; } +}; + /// Process an 'arithmetic' attribute for enums (does nothing here) template <> struct process_attribute : process_attribute_default {}; @@ -485,5 +547,5 @@ constexpr bool expected_num_args(size_t nargs, bool has_args, bool has_kwargs) { return named == 0 || (self + named + has_args + has_kwargs) == nargs; } -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/buffer_info.h b/plugins/python/pybind11/include/pybind11/buffer_info.h index 9f072fa..d803004 100644 --- a/plugins/python/pybind11/include/pybind11/buffer_info.h +++ b/plugins/python/pybind11/include/pybind11/buffer_info.h @@ -11,7 +11,30 @@ #include "detail/common.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) + +PYBIND11_NAMESPACE_BEGIN(detail) + +// Default, C-style strides +inline std::vector c_strides(const std::vector &shape, ssize_t itemsize) { + auto ndim = shape.size(); + std::vector strides(ndim, itemsize); + if (ndim > 0) + for (size_t i = ndim - 1; i > 0; --i) + strides[i - 1] = strides[i] * shape[i]; + return strides; +} + +// F-style strides; default when constructing an array_t with `ExtraFlags & f_style` +inline std::vector f_strides(const std::vector &shape, ssize_t itemsize) { + auto ndim = shape.size(); + std::vector strides(ndim, itemsize); + for (size_t i = 1; i < ndim; ++i) + strides[i] = strides[i - 1] * shape[i - 1]; + return strides; +} + +PYBIND11_NAMESPACE_END(detail) /// Information record describing a Python buffer object struct buffer_info { @@ -21,14 +44,15 @@ struct buffer_info { std::string format; // For homogeneous buffers, this should be set to format_descriptor::format() ssize_t ndim = 0; // Number of dimensions std::vector shape; // Shape of the tensor (1 entry per dimension) - std::vector strides; // Number of entries between adjacent entries (for each per dimension) + std::vector strides; // Number of bytes between adjacent entries (for each per dimension) + bool readonly = false; // flag to indicate if the underlying storage may be written to - buffer_info() { } + buffer_info() = default; buffer_info(void *ptr, ssize_t itemsize, const std::string &format, ssize_t ndim, - detail::any_container shape_in, detail::any_container strides_in) + detail::any_container shape_in, detail::any_container strides_in, bool readonly=false) : ptr(ptr), itemsize(itemsize), size(1), format(format), ndim(ndim), - shape(std::move(shape_in)), strides(std::move(strides_in)) { + shape(std::move(shape_in)), strides(std::move(strides_in)), readonly(readonly) { if (ndim != (ssize_t) shape.size() || ndim != (ssize_t) strides.size()) pybind11_fail("buffer_info: ndim doesn't match shape and/or strides length"); for (size_t i = 0; i < (size_t) ndim; ++i) @@ -36,20 +60,31 @@ struct buffer_info { } template - buffer_info(T *ptr, detail::any_container shape_in, detail::any_container strides_in) - : buffer_info(private_ctr_tag(), ptr, sizeof(T), format_descriptor::format(), static_cast(shape_in->size()), std::move(shape_in), std::move(strides_in)) { } + buffer_info(T *ptr, detail::any_container shape_in, detail::any_container strides_in, bool readonly=false) + : buffer_info(private_ctr_tag(), ptr, sizeof(T), format_descriptor::format(), static_cast(shape_in->size()), std::move(shape_in), std::move(strides_in), readonly) { } - buffer_info(void *ptr, ssize_t itemsize, const std::string &format, ssize_t size) - : buffer_info(ptr, itemsize, format, 1, {size}, {itemsize}) { } + buffer_info(void *ptr, ssize_t itemsize, const std::string &format, ssize_t size, bool readonly=false) + : buffer_info(ptr, itemsize, format, 1, {size}, {itemsize}, readonly) { } template - buffer_info(T *ptr, ssize_t size) - : buffer_info(ptr, sizeof(T), format_descriptor::format(), size) { } + buffer_info(T *ptr, ssize_t size, bool readonly=false) + : buffer_info(ptr, sizeof(T), format_descriptor::format(), size, readonly) { } + + template + buffer_info(const T *ptr, ssize_t size, bool readonly=true) + : buffer_info(const_cast(ptr), sizeof(T), format_descriptor::format(), size, readonly) { } explicit buffer_info(Py_buffer *view, bool ownview = true) : buffer_info(view->buf, view->itemsize, view->format, view->ndim, - {view->shape, view->shape + view->ndim}, {view->strides, view->strides + view->ndim}) { - this->view = view; + {view->shape, view->shape + view->ndim}, + /* Though buffer::request() requests PyBUF_STRIDES, ctypes objects + * ignore this flag and return a view with NULL strides. + * When strides are NULL, build them manually. */ + view->strides + ? std::vector(view->strides, view->strides + view->ndim) + : detail::c_strides({view->shape, view->shape + view->ndim}, view->itemsize), + view->readonly) { + this->m_view = view; this->ownview = ownview; } @@ -68,27 +103,30 @@ struct buffer_info { ndim = rhs.ndim; shape = std::move(rhs.shape); strides = std::move(rhs.strides); - std::swap(view, rhs.view); + std::swap(m_view, rhs.m_view); std::swap(ownview, rhs.ownview); + readonly = rhs.readonly; return *this; } ~buffer_info() { - if (view && ownview) { PyBuffer_Release(view); delete view; } + if (m_view && ownview) { PyBuffer_Release(m_view); delete m_view; } } + Py_buffer *view() const { return m_view; } + Py_buffer *&view() { return m_view; } private: struct private_ctr_tag { }; buffer_info(private_ctr_tag, void *ptr, ssize_t itemsize, const std::string &format, ssize_t ndim, - detail::any_container &&shape_in, detail::any_container &&strides_in) - : buffer_info(ptr, itemsize, format, ndim, std::move(shape_in), std::move(strides_in)) { } + detail::any_container &&shape_in, detail::any_container &&strides_in, bool readonly) + : buffer_info(ptr, itemsize, format, ndim, std::move(shape_in), std::move(strides_in), readonly) { } - Py_buffer *view = nullptr; + Py_buffer *m_view = nullptr; bool ownview = false; }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) template struct compare_buffer_info { static bool compare(const buffer_info& b) { @@ -104,5 +142,5 @@ template struct compare_buffer_info #include #include +#include #if defined(PYBIND11_CPP17) # if defined(__has_include) @@ -31,8 +32,12 @@ #include #endif -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +#if defined(__cpp_lib_char8_t) && __cpp_lib_char8_t >= 201811L +# define PYBIND11_HAS_U8STRING +#endif + +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) /// A life support system for temporary objects created by `type_caster::load()`. /// Adding a patient will keep it alive up until the enclosing function returns. @@ -54,7 +59,7 @@ class loader_life_support { Py_CLEAR(ptr); // A heuristic to reduce the stack's capacity (e.g. after long recursive calls) - if (stack.capacity() > 16 && stack.size() != 0 && stack.capacity() / stack.size() > 2) + if (stack.capacity() > 16 && !stack.empty() && stack.capacity() / stack.size() > 2) stack.shrink_to_fit(); } @@ -158,7 +163,7 @@ inline const std::vector &all_type_info(PyTypeObject *type) */ PYBIND11_NOINLINE inline detail::type_info* get_type_info(PyTypeObject *type) { auto &bases = all_type_info(type); - if (bases.size() == 0) + if (bases.empty()) return nullptr; if (bases.size() > 1) pybind11_fail("pybind11::detail::get_type_info: type has multiple pybind11-registered bases"); @@ -203,10 +208,10 @@ PYBIND11_NOINLINE inline handle get_type_handle(const std::type_info &tp, bool t } struct value_and_holder { - instance *inst; - size_t index; - const detail::type_info *type; - void **vh; + instance *inst = nullptr; + size_t index = 0u; + const detail::type_info *type = nullptr; + void **vh = nullptr; // Main constructor for a found value/holder: value_and_holder(instance *i, const detail::type_info *type, size_t vpos, size_t index) : @@ -215,7 +220,7 @@ struct value_and_holder { {} // Default constructor (used to signal a value-and-holder not found by get_value_and_holder()) - value_and_holder() : inst{nullptr} {} + value_and_holder() = default; // Used for past-the-end iterator value_and_holder(size_t index) : index{index} {} @@ -269,8 +274,8 @@ struct values_and_holders { struct iterator { private: - instance *inst; - const type_vec *types; + instance *inst = nullptr; + const type_vec *types = nullptr; value_and_holder curr; friend struct values_and_holders; iterator(instance *inst, const type_vec *tinfo) @@ -283,8 +288,8 @@ struct values_and_holders { // Past-the-end iterator: iterator(size_t end) : curr(end) {} public: - bool operator==(const iterator &other) { return curr.index == other.curr.index; } - bool operator!=(const iterator &other) { return curr.index != other.curr.index; } + bool operator==(const iterator &other) const { return curr.index == other.curr.index; } + bool operator!=(const iterator &other) const { return curr.index != other.curr.index; } iterator &operator++() { if (!inst->simple_layout) curr.vh += 1 + (*types)[curr.index]->holder_size_in_ptrs; @@ -337,8 +342,8 @@ PYBIND11_NOINLINE inline value_and_holder instance::get_value_and_holder(const t "(compile in debug mode for type details)"); #else pybind11_fail("pybind11::detail::instance::get_value_and_holder: `" + - std::string(find_type->type->tp_name) + "' is not a pybind11 base of the given `" + - std::string(Py_TYPE(this)->tp_name) + "' instance"); + get_fully_qualified_tp_name(find_type->type) + "' is not a pybind11 base of the given `" + + get_fully_qualified_tp_name(Py_TYPE(this)) + "' instance"); #endif } @@ -427,7 +432,7 @@ PYBIND11_NOINLINE inline std::string error_string() { #if !defined(PYPY_VERSION) if (scope.trace) { - PyTracebackObject *trace = (PyTracebackObject *) scope.trace; + auto *trace = (PyTracebackObject *) scope.trace; /* Get the deepest trace possible */ while (trace->tb_next) @@ -453,7 +458,7 @@ PYBIND11_NOINLINE inline handle get_object_handle(const void *ptr, const detail: auto &instances = get_internals().registered_instances; auto range = instances.equal_range(ptr); for (auto it = range.first; it != range.second; ++it) { - for (auto vh : values_and_holders(it->second)) { + for (const auto &vh : values_and_holders(it->second)) { if (vh.type == type) return handle((PyObject *) it->second); } @@ -532,9 +537,17 @@ class type_caster_generic { case return_value_policy::copy: if (copy_constructor) valueptr = copy_constructor(src); - else - throw cast_error("return_value_policy = copy, but the " - "object is non-copyable!"); + else { +#if defined(NDEBUG) + throw cast_error("return_value_policy = copy, but type is " + "non-copyable! (compile in debug mode for details)"); +#else + std::string type_name(tinfo->cpptype->name()); + detail::clean_type_id(type_name); + throw cast_error("return_value_policy = copy, but type " + + type_name + " is non-copyable!"); +#endif + } wrapper->owned = true; break; @@ -543,9 +556,18 @@ class type_caster_generic { valueptr = move_constructor(src); else if (copy_constructor) valueptr = copy_constructor(src); - else - throw cast_error("return_value_policy = move, but the " - "object is neither movable nor copyable!"); + else { +#if defined(NDEBUG) + throw cast_error("return_value_policy = move, but type is neither " + "movable nor copyable! " + "(compile in debug mode for details)"); +#else + std::string type_name(tinfo->cpptype->name()); + detail::clean_type_id(type_name); + throw cast_error("return_value_policy = move, but type " + + type_name + " is neither movable nor copyable!"); +#endif + } wrapper->owned = true; break; @@ -570,7 +592,17 @@ class type_caster_generic { // Lazy allocation for unallocated values: if (vptr == nullptr) { auto *type = v_h.type ? v_h.type : typeinfo; - vptr = type->operator_new(type->type_size); + if (type->operator_new) { + vptr = type->operator_new(type->type_size); + } else { + #if defined(__cpp_aligned_new) && (!defined(_MSC_VER) || _MSC_VER >= 1912) + if (type->type_align > __STDCPP_DEFAULT_NEW_ALIGNMENT__) + vptr = ::operator new(type->type_size, + std::align_val_t(type->type_align)); + else + #endif + vptr = ::operator new(type->type_size); + } } value = vptr; } @@ -604,7 +636,7 @@ class type_caster_generic { /// native typeinfo, or when the native one wasn't able to produce a value. PYBIND11_NOINLINE bool try_load_foreign_module_local(handle src) { constexpr auto *local_key = PYBIND11_MODULE_LOCAL_ID; - const auto pytype = src.get_type(); + const auto pytype = type::handle_of(src); if (!hasattr(pytype, local_key)) return false; @@ -764,21 +796,73 @@ template struct is_copy_constructible : std // so, copy constructability depends on whether the value_type is copy constructible. template struct is_copy_constructible, - std::is_same + std::is_same, + // Avoid infinite recursion + negation> >::value>> : is_copy_constructible {}; -#if !defined(PYBIND11_CPP17) -// Likewise for std::pair before C++17 (which mandates that the copy constructor not exist when the -// two types aren't themselves copy constructible). +// Likewise for std::pair +// (after C++17 it is mandatory that the copy constructor not exist when the two types aren't themselves +// copy constructible, but this can not be relied upon when T1 or T2 are themselves containers). template struct is_copy_constructible> : all_of, is_copy_constructible> {}; -#endif + +// The same problems arise with std::is_copy_assignable, so we use the same workaround. +template struct is_copy_assignable : std::is_copy_assignable {}; +template struct is_copy_assignable, + std::is_same + >::value>> : is_copy_assignable {}; +template struct is_copy_assignable> + : all_of, is_copy_assignable> {}; + +PYBIND11_NAMESPACE_END(detail) + +// polymorphic_type_hook::get(src, tinfo) determines whether the object pointed +// to by `src` actually is an instance of some class derived from `itype`. +// If so, it sets `tinfo` to point to the std::type_info representing that derived +// type, and returns a pointer to the start of the most-derived object of that type +// (in which `src` is a subobject; this will be the same address as `src` in most +// single inheritance cases). If not, or if `src` is nullptr, it simply returns `src` +// and leaves `tinfo` at its default value of nullptr. +// +// The default polymorphic_type_hook just returns src. A specialization for polymorphic +// types determines the runtime type of the passed object and adjusts the this-pointer +// appropriately via dynamic_cast. This is what enables a C++ Animal* to appear +// to Python as a Dog (if Dog inherits from Animal, Animal is polymorphic, Dog is +// registered with pybind11, and this Animal is in fact a Dog). +// +// You may specialize polymorphic_type_hook yourself for types that want to appear +// polymorphic to Python but do not use C++ RTTI. (This is a not uncommon pattern +// in performance-sensitive applications, used most notably in LLVM.) +// +// polymorphic_type_hook_base allows users to specialize polymorphic_type_hook with +// std::enable_if. User provided specializations will always have higher priority than +// the default implementation and specialization provided in polymorphic_type_hook_base. +template +struct polymorphic_type_hook_base +{ + static const void *get(const itype *src, const std::type_info*&) { return src; } +}; +template +struct polymorphic_type_hook_base::value>> +{ + static const void *get(const itype *src, const std::type_info*& type) { + type = src ? &typeid(*src) : nullptr; + return dynamic_cast(src); + } +}; +template +struct polymorphic_type_hook : public polymorphic_type_hook_base {}; + +PYBIND11_NAMESPACE_BEGIN(detail) /// Generic type caster for objects stored on the heap template class type_caster_base : public type_caster_generic { using itype = intrinsic_t; + public: - static PYBIND11_DESCR name() { return type_descr(_()); } + static constexpr auto name = _(); type_caster_base() : type_caster_base(typeid(type)) { } explicit type_caster_base(const std::type_info &info) : type_caster_generic(info) { } @@ -793,32 +877,28 @@ template class type_caster_base : public type_caster_generic { return cast(&src, return_value_policy::move, parent); } - // Returns a (pointer, type_info) pair taking care of necessary RTTI type lookup for a - // polymorphic type. If the instance isn't derived, returns the non-RTTI base version. - template ::value, int> = 0> + // Returns a (pointer, type_info) pair taking care of necessary type lookup for a + // polymorphic type (using RTTI by default, but can be overridden by specializing + // polymorphic_type_hook). If the instance isn't derived, returns the base version. static std::pair src_and_type(const itype *src) { - const void *vsrc = src; auto &cast_type = typeid(itype); const std::type_info *instance_type = nullptr; - if (vsrc) { - instance_type = &typeid(*src); - if (!same_type(cast_type, *instance_type)) { - // This is a base pointer to a derived type; if it is a pybind11-registered type, we - // can get the correct derived pointer (which may be != base pointer) by a - // dynamic_cast to most derived type: - if (auto *tpi = get_type_info(*instance_type)) - return {dynamic_cast(src), const_cast(tpi)}; - } + const void *vsrc = polymorphic_type_hook::get(src, instance_type); + if (instance_type && !same_type(cast_type, *instance_type)) { + // This is a base pointer to a derived type. If the derived type is registered + // with pybind11, we want to make the full derived object available. + // In the typical case where itype is polymorphic, we get the correct + // derived pointer (which may be != base pointer) by a dynamic_cast to + // most derived type. If itype is not polymorphic, we won't get here + // except via a user-provided specialization of polymorphic_type_hook, + // and the user has promised that no this-pointer adjustment is + // required in that case, so it's OK to use static_cast. + if (const auto *tpi = get_type_info(*instance_type)) + return {vsrc, tpi}; } // Otherwise we have either a nullptr, an `itype` pointer, or an unknown derived pointer, so // don't do a cast - return type_caster_generic::src_and_type(vsrc, cast_type, instance_type); - } - - // Non-polymorphic type, so no dynamic casting; just call the generic version directly - template ::value, int> = 0> - static std::pair src_and_type(const itype *src) { - return type_caster_generic::src_and_type(src, typeid(itype)); + return type_caster_generic::src_and_type(src, cast_type, instance_type); } static handle cast(const itype *src, return_value_policy policy, handle parent) { @@ -835,7 +915,7 @@ template class type_caster_base : public type_caster_generic { nullptr, nullptr, holder); } - template using cast_op_type = cast_op_type; + template using cast_op_type = detail::cast_op_type; operator itype*() { return (type *) value; } operator itype&() { if (!value) throw reference_cast_error(); return *((itype *) value); } @@ -885,7 +965,7 @@ template class type_caster> { "std::reference_wrapper caster requires T to have a caster with an `T &` operator"); public: bool load(handle src, bool convert) { return subcaster.load(src, convert); } - static PYBIND11_DESCR name() { return caster_t::name(); } + static constexpr auto name = caster_t::name; static handle cast(const std::reference_wrapper &src, return_value_policy policy, handle parent) { // It is definitely wrong to take ownership of this pointer, so mask that rvp if (policy == return_value_policy::take_ownership || policy == return_value_policy::automatic) @@ -900,7 +980,7 @@ template class type_caster> { protected: \ type value; \ public: \ - static PYBIND11_DESCR name() { return type_descr(py_name); } \ + static constexpr auto name = py_name; \ template >::value, int> = 0> \ static handle cast(T_ *src, return_value_policy policy, handle parent) { \ if (!src) return none().release(); \ @@ -918,11 +998,15 @@ template class type_caster> { template using is_std_char_type = any_of< std::is_same, /* std::string */ +#if defined(PYBIND11_HAS_U8STRING) + std::is_same, /* std::u8string */ +#endif std::is_same, /* std::u16string */ std::is_same, /* std::u32string */ std::is_same /* std::wstring */ >; + template struct type_caster::value && !is_std_char_type::value>> { using _py_type_0 = conditional_t; @@ -951,10 +1035,12 @@ struct type_caster::value && !is_std_char_t : (py_type) PYBIND11_LONG_AS_LONGLONG(src.ptr()); } + // Python API reported an error bool py_err = py_value == (py_type) -1 && PyErr_Occurred(); - if (py_err || (std::is_integral::value && sizeof(py_type) != sizeof(T) && - (py_value < (py_type) std::numeric_limits::min() || - py_value > (py_type) std::numeric_limits::max()))) { + + // Check to see if the conversion is valid (integers should match exactly) + // Signed/unsigned checks happen elsewhere + if (py_err || (std::is_integral::value && sizeof(py_type) != sizeof(T) && py_value != (py_type) (T) py_value)) { bool type_error = py_err && PyErr_ExceptionMatches( #if PY_VERSION_HEX < 0x03000000 && !defined(PYPY_VERSION) PyExc_SystemError @@ -977,20 +1063,34 @@ struct type_caster::value && !is_std_char_t return true; } - static handle cast(T src, return_value_policy /* policy */, handle /* parent */) { - if (std::is_floating_point::value) { - return PyFloat_FromDouble((double) src); - } else if (sizeof(T) <= sizeof(long)) { - if (std::is_signed::value) - return PyLong_FromLong((long) src); - else - return PyLong_FromUnsignedLong((unsigned long) src); - } else { - if (std::is_signed::value) - return PyLong_FromLongLong((long long) src); - else - return PyLong_FromUnsignedLongLong((unsigned long long) src); - } + template + static typename std::enable_if::value, handle>::type + cast(U src, return_value_policy /* policy */, handle /* parent */) { + return PyFloat_FromDouble((double) src); + } + + template + static typename std::enable_if::value && std::is_signed::value && (sizeof(U) <= sizeof(long)), handle>::type + cast(U src, return_value_policy /* policy */, handle /* parent */) { + return PYBIND11_LONG_FROM_SIGNED((long) src); + } + + template + static typename std::enable_if::value && std::is_unsigned::value && (sizeof(U) <= sizeof(unsigned long)), handle>::type + cast(U src, return_value_policy /* policy */, handle /* parent */) { + return PYBIND11_LONG_FROM_UNSIGNED((unsigned long) src); + } + + template + static typename std::enable_if::value && std::is_signed::value && (sizeof(U) > sizeof(long)), handle>::type + cast(U src, return_value_policy /* policy */, handle /* parent */) { + return PyLong_FromLongLong((long long) src); + } + + template + static typename std::enable_if::value && std::is_unsigned::value && (sizeof(U) > sizeof(unsigned long)), handle>::type + cast(U src, return_value_policy /* policy */, handle /* parent */) { + return PyLong_FromUnsignedLongLong((unsigned long long) src); } PYBIND11_TYPE_CASTER(T, _::value>("int", "float")); @@ -1030,7 +1130,7 @@ template <> class type_caster : public type_caster { } /* Check if this is a C++ type */ - auto &bases = all_type_info((PyTypeObject *) h.get_type().ptr()); + auto &bases = all_type_info((PyTypeObject *) type::handle_of(h).ptr()); if (bases.size() == 1) { // Only allowing loading from a single-value type value = values_and_holders(reinterpret_cast(h.ptr())).begin()->value_ptr(); return true; @@ -1049,7 +1149,7 @@ template <> class type_caster : public type_caster { template using cast_op_type = void*&; operator void *&() { return value; } - static PYBIND11_DESCR name() { return type_descr(_("capsule")); } + static constexpr auto name = _("capsule"); private: void *value = nullptr; }; @@ -1086,6 +1186,8 @@ template <> class type_caster { if (res == 0 || res == 1) { value = (bool) res; return true; + } else { + PyErr_Clear(); } } return false; @@ -1103,6 +1205,9 @@ template struct string_caster { // Simplify life by being able to assume standard char sizes (the standard only guarantees // minimums, but Python requires exact sizes) static_assert(!std::is_same::value || sizeof(CharT) == 1, "Unsupported char size != 1"); +#if defined(PYBIND11_HAS_U8STRING) + static_assert(!std::is_same::value || sizeof(CharT) == 1, "Unsupported char8_t size != 1"); +#endif static_assert(!std::is_same::value || sizeof(CharT) == 2, "Unsupported char16_t size != 2"); static_assert(!std::is_same::value || sizeof(CharT) == 4, "Unsupported char32_t size != 4"); // wchar_t can be either 16 bits (Windows) or 32 (everywhere else) @@ -1121,7 +1226,7 @@ template struct string_caster { #if PY_MAJOR_VERSION >= 3 return load_bytes(load_src); #else - if (sizeof(CharT) == 1) { + if (std::is_same::value) { return load_bytes(load_src); } @@ -1135,11 +1240,11 @@ template struct string_caster { #endif } - object utfNbytes = reinterpret_steal(PyUnicode_AsEncodedString( + auto utfNbytes = reinterpret_steal(PyUnicode_AsEncodedString( load_src.ptr(), UTF_N == 8 ? "utf-8" : UTF_N == 16 ? "utf-16" : "utf-32", nullptr)); if (!utfNbytes) { PyErr_Clear(); return false; } - const CharT *buffer = reinterpret_cast(PYBIND11_BYTES_AS_STRING(utfNbytes.ptr())); + const auto *buffer = reinterpret_cast(PYBIND11_BYTES_AS_STRING(utfNbytes.ptr())); size_t length = (size_t) PYBIND11_BYTES_SIZE(utfNbytes.ptr()) / sizeof(CharT); if (UTF_N > 8) { buffer++; length--; } // Skip BOM for UTF-16/32 value = StringType(buffer, length); @@ -1153,7 +1258,7 @@ template struct string_caster { static handle cast(const StringType &src, return_value_policy /* policy */, handle /* parent */) { const char *buffer = reinterpret_cast(src.data()); - ssize_t nbytes = ssize_t(src.size() * sizeof(CharT)); + auto nbytes = ssize_t(src.size() * sizeof(CharT)); handle s = decode_utfN(buffer, nbytes); if (!s) throw error_already_set(); return s; @@ -1169,10 +1274,8 @@ template struct string_caster { UTF_N == 16 ? PyUnicode_DecodeUTF16(buffer, nbytes, nullptr, nullptr) : PyUnicode_DecodeUTF32(buffer, nbytes, nullptr, nullptr); #else - // PyPy seems to have multiple problems related to PyUnicode_UTF*: the UTF8 version - // sometimes segfaults for unknown reasons, while the UTF16 and 32 versions require a - // non-const char * arguments, which is also a nuisance, so bypass the whole thing by just - // passing the encoding as a string value, which works properly: + // PyPy segfaults when on PyUnicode_DecodeUTF16 (and possibly on PyUnicode_DecodeUTF32 as well), + // so bypass the whole thing by just passing the encoding as a string value, which works properly: return PyUnicode_Decode(buffer, nbytes, UTF_N == 8 ? "utf-8" : UTF_N == 16 ? "utf-16" : "utf-32", nullptr); #endif } @@ -1181,7 +1284,7 @@ template struct string_caster { // without any encoding/decoding attempt). For other C++ char sizes this is a no-op. // which supports loading a unicode from a str, doesn't take this path. template - bool load_bytes(enable_if_t src) { + bool load_bytes(enable_if_t::value, handle> src) { if (PYBIND11_BYTES_CHECK(src.ptr())) { // We were passed a Python 3 raw bytes; accept it into a std::string or char* // without any encoding attempt. @@ -1196,7 +1299,7 @@ template struct string_caster { } template - bool load_bytes(enable_if_t) { return false; } + bool load_bytes(enable_if_t::value, handle>) { return false; } }; template @@ -1259,7 +1362,7 @@ template struct type_caster 1 && str_len <= 4) { - unsigned char v0 = static_cast(value[0]); + auto v0 = static_cast(value[0]); size_t char0_bytes = !(v0 & 0x80) ? 1 : // low bits only: 0-127 (v0 & 0xE0) == 0xC0 ? 2 : // 0b110xxxxx - start of 2-byte sequence (v0 & 0xF0) == 0xE0 ? 3 : // 0b1110xxxx - start of 3-byte sequence @@ -1292,7 +1395,7 @@ template struct type_caster using cast_op_type = pybind11::detail::cast_op_type<_T>; }; @@ -1317,10 +1420,19 @@ template class Tuple, typename... Ts> class tuple_caster return cast_impl(std::forward(src), policy, parent, indices{}); } - static PYBIND11_DESCR name() { - return type_descr(_("Tuple[") + detail::concat(make_caster::name()...) + _("]")); + // copied from the PYBIND11_TYPE_CASTER macro + template + static handle cast(T *src, return_value_policy policy, handle parent) { + if (!src) return none().release(); + if (policy == return_value_policy::take_ownership) { + auto h = cast(std::move(*src), policy, parent); delete src; return h; + } else { + return cast(*src, policy, parent); + } } + static constexpr auto name = _("Tuple[") + concat(make_caster::name...) + _("]"); + template using cast_op_type = type; operator type() & { return implicit_cast(indices{}); } @@ -1336,9 +1448,14 @@ template class Tuple, typename... Ts> class tuple_caster template bool load_impl(const sequence &seq, bool convert, index_sequence) { +#ifdef __cpp_fold_expressions + if ((... || !std::get(subcasters).load(seq[Is], convert))) + return false; +#else for (bool r : {std::get(subcasters).load(seq[Is], convert)...}) if (!r) return false; +#endif return true; } @@ -1391,16 +1508,11 @@ struct copyable_holder_caster : public type_caster_base { } explicit operator type*() { return this->value; } - explicit operator type&() { return *(this->value); } + // static_cast works around compiler error with MSVC 17 and CUDA 10.2 + // see issue #2180 + explicit operator type&() { return *(static_cast(this->value)); } explicit operator holder_type*() { return std::addressof(holder); } - - // Workaround for Intel compiler bug - // see pybind11 issue 94 - #if defined(__ICC) || defined(__INTEL_COMPILER) - operator holder_type&() { return holder; } - #else explicit operator holder_type&() { return holder; } - #endif static handle cast(const holder_type &src, return_value_policy, handle) { const auto *ptr = holder_helper::get(src); @@ -1464,7 +1576,7 @@ struct move_only_holder_caster { auto *ptr = holder_helper::get(src); return type_caster_base::cast_holder(ptr, std::addressof(src)); } - static PYBIND11_DESCR name() { return type_caster_base::name(); } + static constexpr auto name = type_caster_base::name; }; template @@ -1495,10 +1607,14 @@ template struct is_holder_type : template struct is_holder_type> : std::true_type {}; -template struct handle_type_name { static PYBIND11_DESCR name() { return _(); } }; -template <> struct handle_type_name { static PYBIND11_DESCR name() { return _(PYBIND11_BYTES_NAME); } }; -template <> struct handle_type_name { static PYBIND11_DESCR name() { return _("*args"); } }; -template <> struct handle_type_name { static PYBIND11_DESCR name() { return _("**kwargs"); } }; +template struct handle_type_name { static constexpr auto name = _(); }; +template <> struct handle_type_name { static constexpr auto name = _(PYBIND11_BYTES_NAME); }; +template <> struct handle_type_name { static constexpr auto name = _("int"); }; +template <> struct handle_type_name { static constexpr auto name = _("Iterable"); }; +template <> struct handle_type_name { static constexpr auto name = _("Iterator"); }; +template <> struct handle_type_name { static constexpr auto name = _("None"); }; +template <> struct handle_type_name { static constexpr auto name = _("*args"); }; +template <> struct handle_type_name { static constexpr auto name = _("**kwargs"); }; template struct pyobject_caster { @@ -1516,7 +1632,7 @@ struct pyobject_caster { static handle cast(const handle &src, return_value_policy /* policy */, handle /* parent */) { return src.inc_ref(); } - PYBIND11_TYPE_CASTER(type, handle_type_name::name()); + PYBIND11_TYPE_CASTER(type, handle_type_name::name); }; template @@ -1556,7 +1672,8 @@ template using move_never = none_of, move_if_unrefer // everything else returns a reference/pointer to a local variable. template using cast_is_temporary_value_reference = bool_constant< (std::is_reference::value || std::is_pointer::value) && - !std::is_base_of>::value + !std::is_base_of>::value && + !std::is_same, void>::value >; // When a value returned from a C++ function is being cast back to Python, we almost always want to @@ -1569,8 +1686,9 @@ template struct return_value_policy_ov template struct return_value_policy_override>::value, void>> { static return_value_policy policy(return_value_policy p) { - return !std::is_lvalue_reference::value && !std::is_pointer::value - ? return_value_policy::move : p; + return !std::is_lvalue_reference::value && + !std::is_pointer::value + ? return_value_policy::move : p; } }; @@ -1581,7 +1699,7 @@ template type_caster &load_type(type_ca throw cast_error("Unable to cast Python instance to C++ type (compile in debug mode for details)"); #else throw cast_error("Unable to cast Python instance of type " + - (std::string) str(handle.get_type()) + " to C++ type '" + type_id() + "'"); + (std::string) str(type::handle_of(handle)) + " to C++ type '" + type_id() + "'"); #endif } return conv; @@ -1593,7 +1711,7 @@ template make_caster load_type(const handle &handle) { return conv; } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) // pytype -> C++ type template ::value, int> = 0> @@ -1610,13 +1728,16 @@ T cast(const handle &handle) { return T(reinterpret_borrow(handle)); } // C++ type -> py::object template ::value, int> = 0> -object cast(const T &value, return_value_policy policy = return_value_policy::automatic_reference, +object cast(T &&value, return_value_policy policy = return_value_policy::automatic_reference, handle parent = handle()) { + using no_ref_T = typename std::remove_reference::type; if (policy == return_value_policy::automatic) - policy = std::is_pointer::value ? return_value_policy::take_ownership : return_value_policy::copy; + policy = std::is_pointer::value ? return_value_policy::take_ownership : + std::is_lvalue_reference::value ? return_value_policy::copy : return_value_policy::move; else if (policy == return_value_policy::automatic_reference) - policy = std::is_pointer::value ? return_value_policy::reference : return_value_policy::copy; - return reinterpret_steal(detail::make_caster::cast(value, policy, parent)); + policy = std::is_pointer::value ? return_value_policy::reference : + std::is_lvalue_reference::value ? return_value_policy::copy : return_value_policy::move; + return reinterpret_steal(detail::make_caster::cast(std::forward(value), policy, parent)); } template T handle::cast() const { return pybind11::cast(*this); } @@ -1629,7 +1750,7 @@ detail::enable_if_t::value, T> move(object &&obj) { throw cast_error("Unable to cast Python instance to C++ rvalue: instance has multiple references" " (compile in debug mode for details)"); #else - throw cast_error("Unable to move from Python " + (std::string) str(obj.get_type()) + + throw cast_error("Unable to move from Python " + (std::string) str(type::handle_of(obj)) + " instance to C++ " + type_id() + " instance: instance has multiple references"); #endif @@ -1638,7 +1759,7 @@ detail::enable_if_t::value, T> move(object &&obj) { return ret; } -// Calling cast() on an rvalue calls pybind::cast with the object rvalue, which does: +// Calling cast() on an rvalue calls pybind11::cast with the object rvalue, which does: // - If we have to move (because T has no copy constructor), do it. This will fail if the moved // object has multiple references, but trying to copy will fail to compile. // - If both movable and copyable, check ref count: if 1, move; otherwise copy @@ -1661,22 +1782,22 @@ template T object::cast() && { return pybind11::cast(std::move(* template <> inline void object::cast() const & { return; } template <> inline void object::cast() && { return; } -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) // Declared in pytypes.h: template ::value, int>> object object_or_cast(T &&o) { return pybind11::cast(std::forward(o)); } -struct overload_unused {}; // Placeholder type for the unneeded (and dead code) static variable in the OVERLOAD_INT macro -template using overload_caster_t = conditional_t< - cast_is_temporary_value_reference::value, make_caster, overload_unused>; +struct override_unused {}; // Placeholder type for the unneeded (and dead code) static variable in the PYBIND11_OVERRIDE_OVERRIDE macro +template using override_caster_t = conditional_t< + cast_is_temporary_value_reference::value, make_caster, override_unused>; // Trampoline use: for reference/pointer types to value-converted values, we do a value cast, then // store the result in the given variable. For other types, this is a no-op. template enable_if_t::value, T> cast_ref(object &&o, make_caster &caster) { return cast_op(load_type(caster, o)); } -template enable_if_t::value, T> cast_ref(object &&, overload_unused &) { +template enable_if_t::value, T> cast_ref(object &&, override_unused &) { pybind11_fail("Internal error: cast_ref fallback invoked"); } // Trampoline use: Having a pybind11::cast with an invalid reference type is going to static_assert, even @@ -1688,7 +1809,7 @@ template enable_if_t::value, T pybind11_fail("Internal error: cast_safe fallback invoked"); } template <> inline void cast_safe(object &&) {} -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) template tuple make_tuple() { return tuple(0); } @@ -1778,6 +1899,16 @@ struct arg_v : arg { #endif }; +/// \ingroup annotations +/// Annotation indicating that all following arguments are keyword-only; the is the equivalent of an +/// unnamed '*' argument (in Python 3) +struct kw_only {}; + +/// \ingroup annotations +/// Annotation indicating that all previous arguments are positional-only; the is the equivalent of an +/// unnamed '/' argument (in Python 3.8) +struct pos_only {}; + template arg_v arg::operator=(T &&value) const { return {std::move(*this), std::forward(value)}; } @@ -1789,16 +1920,16 @@ inline namespace literals { String literal version of `arg` \endrst */ constexpr arg operator"" _a(const char *name, size_t) { return arg(name); } -} +} // namespace literals -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) // forward declaration (definition in attr.h) struct function_record; /// Internal data associated with a single function call struct function_call { - function_call(function_record &f, handle p); // Implementation in attr.h + function_call(const function_record &f, handle p); // Implementation in attr.h /// The function data: const function_record &func; @@ -1840,7 +1971,7 @@ class argument_loader { static constexpr bool has_kwargs = kwargs_pos < 0; static constexpr bool has_args = args_pos < 0; - static PYBIND11_DESCR arg_names() { return detail::concat(make_caster::name()...); } + static constexpr auto arg_names = concat(type_descr(make_caster::name)...); bool load_args(function_call &call) { return load_impl_sequence(call, indices{}); @@ -1863,14 +1994,19 @@ class argument_loader { template bool load_impl_sequence(function_call &call, index_sequence) { +#ifdef __cpp_fold_expressions + if ((... || !std::get(argcasters).load(call.args[Is], call.args_convert[Is]))) + return false; +#else for (bool r : {std::get(argcasters).load(call.args[Is], call.args_convert[Is])...}) if (!r) return false; +#endif return true; } template - Return call_impl(Func &&f, index_sequence, Guard &&) { + Return call_impl(Func &&f, index_sequence, Guard &&) && { return std::forward(f)(cast_op(std::move(std::get(argcasters)))...); } @@ -1947,7 +2083,7 @@ class unpacking_collector { } void process(list &args_list, detail::args_proxy ap) { - for (const auto &a : ap) + for (auto a : ap) args_list.append(a); } @@ -1979,7 +2115,7 @@ class unpacking_collector { void process(list &/*args_list*/, detail::kwargs_proxy kp) { if (!kp) return; - for (const auto &k : reinterpret_borrow(kp)) { + for (auto k : reinterpret_borrow(kp)) { if (m_kwargs.contains(k.first)) { #if defined(NDEBUG) multiple_values_error(); @@ -2057,11 +2193,27 @@ object object_api::call(Args &&...args) const { return operator()(std::forward(args)...); } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) + + +template +handle type::handle_of() { + static_assert( + std::is_base_of>::value, + "py::type::of only supports the case where T is a registered C++ types." + ); + + return detail::get_type_handle(typeid(T), true); +} + -#define PYBIND11_MAKE_OPAQUE(Type) \ +#define PYBIND11_MAKE_OPAQUE(...) \ namespace pybind11 { namespace detail { \ - template<> class type_caster : public type_caster_base { }; \ + template<> class type_caster<__VA_ARGS__> : public type_caster_base<__VA_ARGS__> { }; \ }} -NAMESPACE_END(PYBIND11_NAMESPACE) +/// Lets you pass a type containing a `,` through a macro parameter without needing a separate +/// typedef, e.g.: `PYBIND11_OVERRIDE(PYBIND11_TYPE(ReturnType), PYBIND11_TYPE(Parent), f, arg)` +#define PYBIND11_TYPE(...) __VA_ARGS__ + +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/chrono.h b/plugins/python/pybind11/include/pybind11/chrono.h index 95ada76..c368110 100644 --- a/plugins/python/pybind11/include/pybind11/chrono.h +++ b/plugins/python/pybind11/include/pybind11/chrono.h @@ -27,15 +27,15 @@ #define PyDateTime_DELTA_GET_MICROSECONDS(o) (((PyDateTime_Delta*)o)->microseconds) #endif -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) template class duration_caster { public: - typedef typename type::rep rep; - typedef typename type::period period; + using rep = typename type::rep; + using period = typename type::period; - typedef std::chrono::duration> days; + using days = std::chrono::duration>; bool load(handle src, bool) { using namespace std::chrono; @@ -98,7 +98,7 @@ template class duration_caster { // This is for casting times on the system clock into datetime.datetime instances template class type_caster> { public: - typedef std::chrono::time_point type; + using type = std::chrono::time_point; bool load(handle src, bool) { using namespace std::chrono; @@ -106,8 +106,11 @@ template class type_caster class type_caster(system_clock::from_time_t(std::mktime(&cal)) + msecs); + return true; } static handle cast(const std::chrono::time_point &src, return_value_policy /* policy */, handle /* parent */) { @@ -128,21 +150,28 @@ template class type_caster; + auto us = duration_cast(src.time_since_epoch() % seconds(1)); + if (us.count() < 0) + us += seconds(1); + + // Subtract microseconds BEFORE `system_clock::to_time_t`, because: + // > If std::time_t has lower precision, it is implementation-defined whether the value is rounded or truncated. + // (https://en.cppreference.com/w/cpp/chrono/system_clock/to_time_t) + std::time_t tt = system_clock::to_time_t(time_point_cast(src - us)); // this function uses static memory so it's best to copy it out asap just in case // otherwise other code that is using localtime may break this (not just python code) std::tm localtime = *std::localtime(&tt); - // Declare these special duration types so the conversions happen with the correct primitive types (int) - using us_t = duration; - return PyDateTime_FromDateAndTime(localtime.tm_year + 1900, localtime.tm_mon + 1, localtime.tm_mday, localtime.tm_hour, localtime.tm_min, localtime.tm_sec, - (duration_cast(src.time_since_epoch() % seconds(1))).count()); + us.count()); } PYBIND11_TYPE_CASTER(type, _("datetime.datetime")); }; @@ -158,5 +187,5 @@ template class type_caster> { }; -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/complex.h b/plugins/python/pybind11/include/pybind11/complex.h index 5dac27c..f8327eb 100644 --- a/plugins/python/pybind11/include/pybind11/complex.h +++ b/plugins/python/pybind11/include/pybind11/complex.h @@ -17,7 +17,7 @@ # undef I #endif -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) template struct format_descriptor, detail::enable_if_t::value>> { static constexpr const char c = format_descriptor::c; @@ -25,10 +25,14 @@ template struct format_descriptor, detail::enable_i static std::string format() { return std::string(value); } }; +#ifndef PYBIND11_CPP17 + template constexpr const char format_descriptor< std::complex, detail::enable_if_t::value>>::value[3]; -NAMESPACE_BEGIN(detail) +#endif + +PYBIND11_NAMESPACE_BEGIN(detail) template struct is_fmt_numeric, detail::enable_if_t::value>> { static constexpr bool value = true; @@ -57,5 +61,5 @@ template class type_caster> { PYBIND11_TYPE_CASTER(std::complex, _("complex")); }; -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/detail/class.h b/plugins/python/pybind11/include/pybind11/detail/class.h index ff06370..65dad5a 100644 --- a/plugins/python/pybind11/include/pybind11/detail/class.h +++ b/plugins/python/pybind11/include/pybind11/detail/class.h @@ -10,11 +10,12 @@ #pragma once #include "../attr.h" +#include "../options.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) -#if PY_VERSION_HEX >= 0x03030000 +#if PY_VERSION_HEX >= 0x03030000 && !defined(PYPY_VERSION) # define PYBIND11_BUILTIN_QUALNAME # define PYBIND11_SET_OLDPY_QUALNAME(obj, nameobj) #else @@ -23,6 +24,18 @@ NAMESPACE_BEGIN(detail) # define PYBIND11_SET_OLDPY_QUALNAME(obj, nameobj) setattr((PyObject *) obj, "__qualname__", nameobj) #endif +inline std::string get_fully_qualified_tp_name(PyTypeObject *type) { +#if !defined(PYPY_VERSION) + return type->tp_name; +#else + auto module_name = handle((PyObject *) type).attr("__module__").cast(); + if (module_name == PYBIND11_BUILTINS_MODULE) + return type->tp_name; + else + return std::move(module_name) + "." + type->tp_name; +#endif +} + inline PyTypeObject *type_incref(PyTypeObject *type) { Py_INCREF(type); return type; @@ -116,7 +129,7 @@ extern "C" inline int pybind11_meta_setattro(PyObject* obj, PyObject* name, PyOb // 2. `Type.static_prop = other_static_prop` --> setattro: replace existing `static_prop` // 3. `Type.regular_attribute = value` --> setattro: regular attribute assignment const auto static_prop = (PyObject *) get_internals().static_property_type; - const auto call_descr_set = descr && PyObject_IsInstance(descr, static_prop) + const auto call_descr_set = descr && value && PyObject_IsInstance(descr, static_prop) && !PyObject_IsInstance(value, static_prop); if (call_descr_set) { // Call `static_property.__set__()` instead of replacing the `static_property`. @@ -155,6 +168,69 @@ extern "C" inline PyObject *pybind11_meta_getattro(PyObject *obj, PyObject *name } #endif +/// metaclass `__call__` function that is used to create all pybind11 objects. +extern "C" inline PyObject *pybind11_meta_call(PyObject *type, PyObject *args, PyObject *kwargs) { + + // use the default metaclass call to create/initialize the object + PyObject *self = PyType_Type.tp_call(type, args, kwargs); + if (self == nullptr) { + return nullptr; + } + + // This must be a pybind11 instance + auto instance = reinterpret_cast(self); + + // Ensure that the base __init__ function(s) were called + for (const auto &vh : values_and_holders(instance)) { + if (!vh.holder_constructed()) { + PyErr_Format(PyExc_TypeError, "%.200s.__init__() must be called when overriding __init__", + get_fully_qualified_tp_name(vh.type->type).c_str()); + Py_DECREF(self); + return nullptr; + } + } + + return self; +} + +/// Cleanup the type-info for a pybind11-registered type. +extern "C" inline void pybind11_meta_dealloc(PyObject *obj) { + auto *type = (PyTypeObject *) obj; + auto &internals = get_internals(); + + // A pybind11-registered type will: + // 1) be found in internals.registered_types_py + // 2) have exactly one associated `detail::type_info` + auto found_type = internals.registered_types_py.find(type); + if (found_type != internals.registered_types_py.end() && + found_type->second.size() == 1 && + found_type->second[0]->type == type) { + + auto *tinfo = found_type->second[0]; + auto tindex = std::type_index(*tinfo->cpptype); + internals.direct_conversions.erase(tindex); + + if (tinfo->module_local) + registered_local_types_cpp().erase(tindex); + else + internals.registered_types_cpp.erase(tindex); + internals.registered_types_py.erase(tinfo->type); + + // Actually just `std::erase_if`, but that's only available in C++20 + auto &cache = internals.inactive_override_cache; + for (auto it = cache.begin(), last = cache.end(); it != last; ) { + if (it->first == (PyObject *) tinfo->type) + it = cache.erase(it); + else + ++it; + } + + delete tinfo; + } + + PyType_Type.tp_dealloc(obj); +} + /** This metaclass is assigned by default to all pybind11 types and is required in order for static properties to function correctly. Users may override this using `py::metaclass`. Return value: New reference. */ @@ -180,11 +256,15 @@ inline PyTypeObject* make_default_metaclass() { type->tp_base = type_incref(&PyType_Type); type->tp_flags = Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HEAPTYPE; + type->tp_call = pybind11_meta_call; + type->tp_setattro = pybind11_meta_setattro; #if PY_MAJOR_VERSION >= 3 type->tp_getattro = pybind11_meta_getattro; #endif + type->tp_dealloc = pybind11_meta_dealloc; + if (PyType_Ready(type) < 0) pybind11_fail("make_default_metaclass(): failure in PyType_Ready()!"); @@ -222,7 +302,7 @@ inline bool deregister_instance_impl(void *ptr, instance *self) { auto ®istered_instances = get_internals().registered_instances; auto range = registered_instances.equal_range(ptr); for (auto it = range.first; it != range.second; ++it) { - if (Py_TYPE(self) == Py_TYPE(it->second)) { + if (self == it->second) { registered_instances.erase(it); return true; } @@ -276,12 +356,7 @@ extern "C" inline PyObject *pybind11_object_new(PyTypeObject *type, PyObject *, /// following default function will be used which simply throws an exception. extern "C" inline int pybind11_object_init(PyObject *self, PyObject *, PyObject *) { PyTypeObject *type = Py_TYPE(self); - std::string msg; -#if defined(PYPY_VERSION) - msg += handle((PyObject *) type).attr("__module__").cast() + "."; -#endif - msg += type->tp_name; - msg += ": No constructor defined!"; + std::string msg = get_fully_qualified_tp_name(type) + ": No constructor defined!"; PyErr_SetString(PyExc_TypeError, msg.c_str()); return -1; } @@ -289,13 +364,9 @@ extern "C" inline int pybind11_object_init(PyObject *self, PyObject *, PyObject inline void add_patient(PyObject *nurse, PyObject *patient) { auto &internals = get_internals(); auto instance = reinterpret_cast(nurse); - auto ¤t_patients = internals.patients[nurse]; instance->has_patients = true; - for (auto &p : current_patients) - if (p == patient) - return; Py_INCREF(patient); - current_patients.push_back(patient); + internals.patients[nurse].push_back(patient); } inline void clear_patients(PyObject *self) { @@ -353,6 +424,7 @@ extern "C" inline void pybind11_object_dealloc(PyObject *self) { auto type = Py_TYPE(self); type->tp_free(self); +#if PY_VERSION_HEX < 0x03080000 // `type->tp_dealloc != pybind11_object_dealloc` means that we're being called // as part of a derived type's dealloc, in which case we're not allowed to decref // the type here. For cross-module compatibility, we shouldn't compare directly @@ -360,6 +432,11 @@ extern "C" inline void pybind11_object_dealloc(PyObject *self) { auto pybind11_object_type = (PyTypeObject *) get_internals().instance_base; if (type->tp_dealloc == pybind11_object_type->tp_dealloc) Py_DECREF(type); +#else + // This was not needed before Python 3.8 (Python issue 35810) + // https://github.com/pybind/pybind11/issues/1946 + Py_DECREF(type); +#endif } /** Create the type which can be used as a common base for all classes. This is @@ -418,7 +495,7 @@ extern "C" inline PyObject *pybind11_get_dict(PyObject *self, void *) { extern "C" inline int pybind11_set_dict(PyObject *self, PyObject *new_dict, void *) { if (!PyDict_Check(new_dict)) { PyErr_Format(PyExc_TypeError, "__dict__ must be set to a dictionary, not a '%.200s'", - Py_TYPE(new_dict)->tp_name); + get_fully_qualified_tp_name(Py_TYPE(new_dict)).c_str()); return -1; } PyObject *&dict = *_PyObject_GetDictPtr(self); @@ -445,11 +522,6 @@ extern "C" inline int pybind11_clear(PyObject *self) { /// Give instances of this type a `__dict__` and opt into garbage collection. inline void enable_dynamic_attributes(PyHeapTypeObject *heap_type) { auto type = &heap_type->ht_type; -#if defined(PYPY_VERSION) - pybind11_fail(std::string(type->tp_name) + ": dynamic attributes are " - "currently not supported in " - "conjunction with PyPy!"); -#endif type->tp_flags |= Py_TPFLAGS_HAVE_GC; type->tp_dictoffset = type->tp_basicsize; // place dict at the end type->tp_basicsize += (ssize_t)sizeof(PyObject *); // and allocate enough space for it @@ -472,7 +544,7 @@ extern "C" inline int pybind11_getbuffer(PyObject *obj, Py_buffer *view, int fla if (tinfo && tinfo->get_buffer) break; } - if (view == nullptr || obj == nullptr || !tinfo || !tinfo->get_buffer) { + if (view == nullptr || !tinfo || !tinfo->get_buffer) { if (view) view->obj = nullptr; PyErr_SetString(PyExc_BufferError, "pybind11_getbuffer(): Internal error"); @@ -488,6 +560,13 @@ extern "C" inline int pybind11_getbuffer(PyObject *obj, Py_buffer *view, int fla view->len = view->itemsize; for (auto s : info->shape) view->len *= s; + view->readonly = info->readonly; + if ((flags & PyBUF_WRITABLE) == PyBUF_WRITABLE && info->readonly) { + if (view) + view->obj = nullptr; + PyErr_SetString(PyExc_BufferError, "Writable buffer requested for readonly storage"); + return -1; + } if ((flags & PyBUF_FORMAT) == PyBUF_FORMAT) view->format = const_cast(info->format.c_str()); if ((flags & PyBUF_STRIDES) == PyBUF_STRIDES) { @@ -530,17 +609,17 @@ inline PyObject* make_new_python_type(const type_record &rec) { #endif } - object module; + object module_; if (rec.scope) { if (hasattr(rec.scope, "__module__")) - module = rec.scope.attr("__module__"); + module_ = rec.scope.attr("__module__"); else if (hasattr(rec.scope, "__name__")) - module = rec.scope.attr("__name__"); + module_ = rec.scope.attr("__name__"); } auto full_name = c_str( #if !defined(PYPY_VERSION) - module ? str(module).cast() + "." + rec.name : + module_ ? str(module_).cast() + "." + rec.name : #endif rec.name); @@ -555,7 +634,7 @@ inline PyObject* make_new_python_type(const type_record &rec) { auto &internals = get_internals(); auto bases = tuple(rec.bases); - auto base = (bases.size() == 0) ? internals.instance_base + auto base = (bases.empty()) ? internals.instance_base : bases[0].ptr(); /* Danger zone: from now (and until PyType_Ready), make sure to @@ -579,7 +658,7 @@ inline PyObject* make_new_python_type(const type_record &rec) { type->tp_doc = tp_doc; type->tp_base = type_incref((PyTypeObject *)base); type->tp_basicsize = static_cast(sizeof(instance)); - if (bases.size() > 0) + if (!bases.empty()) type->tp_bases = bases.release().ptr(); /* Don't inherit base __init__ */ @@ -589,12 +668,17 @@ inline PyObject* make_new_python_type(const type_record &rec) { type->tp_as_number = &heap_type->as_number; type->tp_as_sequence = &heap_type->as_sequence; type->tp_as_mapping = &heap_type->as_mapping; +#if PY_VERSION_HEX >= 0x03050000 + type->tp_as_async = &heap_type->as_async; +#endif /* Flags */ - type->tp_flags |= Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HEAPTYPE; + type->tp_flags |= Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HEAPTYPE; #if PY_MAJOR_VERSION < 3 type->tp_flags |= Py_TPFLAGS_CHECKTYPES; #endif + if (!rec.is_final) + type->tp_flags |= Py_TPFLAGS_BASETYPE; if (rec.dynamic_attr) enable_dynamic_attributes(heap_type); @@ -614,13 +698,13 @@ inline PyObject* make_new_python_type(const type_record &rec) { else Py_INCREF(type); // Keep it alive forever (reference leak) - if (module) // Needed by pydoc - setattr((PyObject *) type, "__module__", module); + if (module_) // Needed by pydoc + setattr((PyObject *) type, "__module__", module_); PYBIND11_SET_OLDPY_QUALNAME(type, qualname); return (PyObject *) type; } -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/detail/common.h b/plugins/python/pybind11/include/pybind11/detail/common.h index 892de0f..751141a 100644 --- a/plugins/python/pybind11/include/pybind11/detail/common.h +++ b/plugins/python/pybind11/include/pybind11/detail/common.h @@ -9,12 +9,12 @@ #pragma once -#if !defined(NAMESPACE_BEGIN) -# define NAMESPACE_BEGIN(name) namespace name { -#endif -#if !defined(NAMESPACE_END) -# define NAMESPACE_END(name) } -#endif +#define PYBIND11_VERSION_MAJOR 2 +#define PYBIND11_VERSION_MINOR 6 +#define PYBIND11_VERSION_PATCH 1 + +#define PYBIND11_NAMESPACE_BEGIN(name) namespace name { +#define PYBIND11_NAMESPACE_END(name) } // Robust support for some features and loading modules compiled against different pybind versions // requires forcing hidden visibility on pybind code, so we enforce this by setting the attribute on @@ -47,8 +47,8 @@ // Compiler version assertions #if defined(__INTEL_COMPILER) -# if __INTEL_COMPILER < 1700 -# error pybind11 requires Intel C++ compiler v17 or newer +# if __INTEL_COMPILER < 1800 +# error pybind11 requires Intel C++ compiler v18 or newer # endif #elif defined(__clang__) && !defined(__apple_build_version__) # if __clang_major__ < 3 || (__clang_major__ == 3 && __clang_minor__ < 3) @@ -92,9 +92,19 @@ # define PYBIND11_DEPRECATED(reason) __attribute__((deprecated(reason))) #endif -#define PYBIND11_VERSION_MAJOR 2 -#define PYBIND11_VERSION_MINOR 2 -#define PYBIND11_VERSION_PATCH 4 +#if defined(PYBIND11_CPP17) +# define PYBIND11_MAYBE_UNUSED [[maybe_unused]] +#elif defined(_MSC_VER) && !defined(__clang__) +# define PYBIND11_MAYBE_UNUSED +#else +# define PYBIND11_MAYBE_UNUSED __attribute__ ((__unused__)) +#endif + +/* Don't let Python.h #define (v)snprintf as macro because they are implemented + properly in Visual Studio since 2015. */ +#if defined(_MSC_VER) && _MSC_VER >= 1900 +# define HAVE_SNPRINTF 1 +#endif /// Include Python header, disable linking to pythonX_d.lib on Windows in debug mode #if defined(_MSC_VER) @@ -103,7 +113,7 @@ # endif # pragma warning(push) # pragma warning(disable: 4510 4610 4512 4005) -# if defined(_DEBUG) +# if defined(_DEBUG) && !defined(Py_DEBUG) # define PYBIND11_DEBUG_MARKER # undef _DEBUG # endif @@ -113,10 +123,9 @@ #include #include -#if defined(_WIN32) && (defined(min) || defined(max)) -# error Macro clash with min and max -- define NOMINMAX when compiling your program on Windows -#endif - +/* Python #defines overrides on all sorts of core functions, which + tends to weak havok in C++ codebases that expect these to work + like regular functions (potentially with several overloads) */ #if defined(isalnum) # undef isalnum # undef isalpha @@ -127,6 +136,10 @@ # undef toupper #endif +#if defined(copysign) +# undef copysign +#endif + #if defined(_MSC_VER) # if defined(PYBIND11_DEBUG_MARKER) # define _DEBUG @@ -141,6 +154,7 @@ #include #include #include +#include #include #include #include @@ -159,6 +173,8 @@ #define PYBIND11_BYTES_SIZE PyBytes_Size #define PYBIND11_LONG_CHECK(o) PyLong_Check(o) #define PYBIND11_LONG_AS_LONGLONG(o) PyLong_AsLongLong(o) +#define PYBIND11_LONG_FROM_SIGNED(o) PyLong_FromSsize_t((ssize_t) o) +#define PYBIND11_LONG_FROM_UNSIGNED(o) PyLong_FromSize_t((size_t) o) #define PYBIND11_BYTES_NAME "bytes" #define PYBIND11_STRING_NAME "str" #define PYBIND11_SLICE_OBJECT PyObject @@ -166,7 +182,11 @@ #define PYBIND11_STR_TYPE ::pybind11::str #define PYBIND11_BOOL_ATTR "__bool__" #define PYBIND11_NB_BOOL(ptr) ((ptr)->nb_bool) +#define PYBIND11_BUILTINS_MODULE "builtins" +// Providing a separate declaration to make Clang's -Wmissing-prototypes happy. +// See comment for PYBIND11_MODULE below for why this is marked "maybe unused". #define PYBIND11_PLUGIN_IMPL(name) \ + extern "C" PYBIND11_MAYBE_UNUSED PYBIND11_EXPORT PyObject *PyInit_##name(); \ extern "C" PYBIND11_EXPORT PyObject *PyInit_##name() #else @@ -181,6 +201,8 @@ #define PYBIND11_BYTES_SIZE PyString_Size #define PYBIND11_LONG_CHECK(o) (PyInt_Check(o) || PyLong_Check(o)) #define PYBIND11_LONG_AS_LONGLONG(o) (PyInt_Check(o) ? (long long) PyLong_AsLong(o) : PyLong_AsLongLong(o)) +#define PYBIND11_LONG_FROM_SIGNED(o) PyInt_FromSsize_t((ssize_t) o) // Returns long if needed. +#define PYBIND11_LONG_FROM_UNSIGNED(o) PyInt_FromSize_t((size_t) o) // Returns long if needed. #define PYBIND11_BYTES_NAME "str" #define PYBIND11_STRING_NAME "unicode" #define PYBIND11_SLICE_OBJECT PySliceObject @@ -188,11 +210,15 @@ #define PYBIND11_STR_TYPE ::pybind11::bytes #define PYBIND11_BOOL_ATTR "__nonzero__" #define PYBIND11_NB_BOOL(ptr) ((ptr)->nb_nonzero) +#define PYBIND11_BUILTINS_MODULE "__builtin__" +// Providing a separate PyInit decl to make Clang's -Wmissing-prototypes happy. +// See comment for PYBIND11_MODULE below for why this is marked "maybe unused". #define PYBIND11_PLUGIN_IMPL(name) \ - static PyObject *pybind11_init_wrapper(); \ - extern "C" PYBIND11_EXPORT void init##name() { \ - (void)pybind11_init_wrapper(); \ - } \ + static PyObject *pybind11_init_wrapper(); \ + extern "C" PYBIND11_MAYBE_UNUSED PYBIND11_EXPORT void init##name(); \ + extern "C" PYBIND11_EXPORT void init##name() { \ + (void)pybind11_init_wrapper(); \ + } \ PyObject *pybind11_init_wrapper() #endif @@ -207,18 +233,45 @@ extern "C" { #define PYBIND11_STRINGIFY(x) #x #define PYBIND11_TOSTRING(x) PYBIND11_STRINGIFY(x) #define PYBIND11_CONCAT(first, second) first##second +#define PYBIND11_ENSURE_INTERNALS_READY \ + pybind11::detail::get_internals(); + +#define PYBIND11_CHECK_PYTHON_VERSION \ + { \ + const char *compiled_ver = PYBIND11_TOSTRING(PY_MAJOR_VERSION) \ + "." PYBIND11_TOSTRING(PY_MINOR_VERSION); \ + const char *runtime_ver = Py_GetVersion(); \ + size_t len = std::strlen(compiled_ver); \ + if (std::strncmp(runtime_ver, compiled_ver, len) != 0 \ + || (runtime_ver[len] >= '0' && runtime_ver[len] <= '9')) { \ + PyErr_Format(PyExc_ImportError, \ + "Python version mismatch: module was compiled for Python %s, " \ + "but the interpreter version is incompatible: %s.", \ + compiled_ver, runtime_ver); \ + return nullptr; \ + } \ + } + +#define PYBIND11_CATCH_INIT_EXCEPTIONS \ + catch (pybind11::error_already_set &e) { \ + PyErr_SetString(PyExc_ImportError, e.what()); \ + return nullptr; \ + } catch (const std::exception &e) { \ + PyErr_SetString(PyExc_ImportError, e.what()); \ + return nullptr; \ + } \ /** \rst ***Deprecated in favor of PYBIND11_MODULE*** This macro creates the entry point that will be invoked when the Python interpreter - imports a plugin library. Please create a `module` in the function body and return + imports a plugin library. Please create a `module_` in the function body and return the pointer to its underlying Python object at the end. .. code-block:: cpp PYBIND11_PLUGIN(example) { - pybind11::module m("example", "pybind11 example plugin"); + pybind11::module_ m("example", "pybind11 example plugin"); /// Set up bindings here return m.ptr(); } @@ -227,27 +280,11 @@ extern "C" { PYBIND11_DEPRECATED("PYBIND11_PLUGIN is deprecated, use PYBIND11_MODULE") \ static PyObject *pybind11_init(); \ PYBIND11_PLUGIN_IMPL(name) { \ - int major, minor; \ - if (sscanf(Py_GetVersion(), "%i.%i", &major, &minor) != 2) { \ - PyErr_SetString(PyExc_ImportError, "Can't parse Python version."); \ - return nullptr; \ - } else if (major != PY_MAJOR_VERSION || minor != PY_MINOR_VERSION) { \ - PyErr_Format(PyExc_ImportError, \ - "Python version mismatch: module was compiled for " \ - "version %i.%i, while the interpreter is running " \ - "version %i.%i.", PY_MAJOR_VERSION, PY_MINOR_VERSION, \ - major, minor); \ - return nullptr; \ - } \ + PYBIND11_CHECK_PYTHON_VERSION \ + PYBIND11_ENSURE_INTERNALS_READY \ try { \ return pybind11_init(); \ - } catch (pybind11::error_already_set &e) { \ - PyErr_SetString(PyExc_ImportError, e.what()); \ - return nullptr; \ - } catch (const std::exception &e) { \ - PyErr_SetString(PyExc_ImportError, e.what()); \ - return nullptr; \ - } \ + } PYBIND11_CATCH_INIT_EXCEPTIONS \ } \ PyObject *pybind11_init() @@ -255,7 +292,11 @@ extern "C" { This macro creates the entry point that will be invoked when the Python interpreter imports an extension module. The module name is given as the fist argument and it should not be in quotes. The second macro argument defines a variable of type - `py::module` which can be used to initialize the module. + `py::module_` which can be used to initialize the module. + + The entry point is marked as "maybe unused" to aid dead-code detection analysis: + since the entry point is typically only looked up at runtime and not referenced + during translation, it would otherwise appear as unused ("dead") code. .. code-block:: cpp @@ -269,36 +310,25 @@ extern "C" { } \endrst */ #define PYBIND11_MODULE(name, variable) \ - static void PYBIND11_CONCAT(pybind11_init_, name)(pybind11::module &); \ + static ::pybind11::module_::module_def \ + PYBIND11_CONCAT(pybind11_module_def_, name) PYBIND11_MAYBE_UNUSED; \ + PYBIND11_MAYBE_UNUSED \ + static void PYBIND11_CONCAT(pybind11_init_, name)(::pybind11::module_ &); \ PYBIND11_PLUGIN_IMPL(name) { \ - int major, minor; \ - if (sscanf(Py_GetVersion(), "%i.%i", &major, &minor) != 2) { \ - PyErr_SetString(PyExc_ImportError, "Can't parse Python version."); \ - return nullptr; \ - } else if (major != PY_MAJOR_VERSION || minor != PY_MINOR_VERSION) { \ - PyErr_Format(PyExc_ImportError, \ - "Python version mismatch: module was compiled for " \ - "version %i.%i, while the interpreter is running " \ - "version %i.%i.", PY_MAJOR_VERSION, PY_MINOR_VERSION, \ - major, minor); \ - return nullptr; \ - } \ - auto m = pybind11::module(PYBIND11_TOSTRING(name)); \ + PYBIND11_CHECK_PYTHON_VERSION \ + PYBIND11_ENSURE_INTERNALS_READY \ + auto m = ::pybind11::module_::create_extension_module( \ + PYBIND11_TOSTRING(name), nullptr, \ + &PYBIND11_CONCAT(pybind11_module_def_, name)); \ try { \ PYBIND11_CONCAT(pybind11_init_, name)(m); \ return m.ptr(); \ - } catch (pybind11::error_already_set &e) { \ - PyErr_SetString(PyExc_ImportError, e.what()); \ - return nullptr; \ - } catch (const std::exception &e) { \ - PyErr_SetString(PyExc_ImportError, e.what()); \ - return nullptr; \ - } \ + } PYBIND11_CATCH_INIT_EXCEPTIONS \ } \ - void PYBIND11_CONCAT(pybind11_init_, name)(pybind11::module &variable) + void PYBIND11_CONCAT(pybind11_init_, name)(::pybind11::module_ &variable) -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) using ssize_t = Py_ssize_t; using size_t = std::size_t; @@ -355,7 +385,7 @@ enum class return_value_policy : uint8_t { reference_internal }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) inline static constexpr int log2(size_t n, int k = 0) { return (n <= 1) ? k : log2(n >> 1, k + 1); } @@ -391,7 +421,7 @@ struct instance { void *simple_value_holder[1 + instance_simple_holder_in_ptrs()]; nonsimple_values_and_holders nonsimple; }; - /// Weak references (needed for keep alive): + /// Weak references PyObject *weakrefs; /// If true, the pointer is owned which means we're free to manage it with a holder. bool owned : 1; @@ -408,10 +438,10 @@ struct instance { * (which is typically the size of two pointers), or when multiple inheritance is used on the * python side. Non-simple layout allocates the required amount of memory to have multiple * bound C++ classes as parents. Under this layout, `nonsimple.values_and_holders` is set to a - * pointer to allocated space of the required space to hold a a sequence of value pointers and + * pointer to allocated space of the required space to hold a sequence of value pointers and * holders followed `status`, a set of bit flags (1 byte each), i.e. * [val1*][holder1][val2*][holder2]...[bb...] where each [block] is rounded up to a multiple of - * `sizeof(void *)`. `nonsimple.holder_constructed` is, for convenience, a pointer to the + * `sizeof(void *)`. `nonsimple.status` is, for convenience, a pointer to the * beginning of the [bb...] block (but not independently allocated). * * Status bits indicate whether the associated holder is constructed (& @@ -464,7 +494,7 @@ using std::make_index_sequence; #else template struct index_sequence { }; template struct make_index_sequence_impl : make_index_sequence_impl { }; -template struct make_index_sequence_impl <0, S...> { typedef index_sequence type; }; +template struct make_index_sequence_impl <0, S...> { using type = index_sequence; }; template using make_index_sequence = typename make_index_sequence_impl::type; #endif @@ -478,8 +508,16 @@ template using select_indices = typename select_indices_impl using bool_constant = std::integral_constant; template struct negation : bool_constant { }; +// PGI/Intel cannot detect operator delete with the "compatible" void_t impl, so +// using the new one (C++14 defect, so generally works on newer compilers, even +// if not in C++17 mode) +#if defined(__PGIC__) || defined(__INTEL_COMPILER) +template using void_t = void; +#else template struct void_t_impl { using type = void; }; template using void_t = typename void_t_impl::type; +#endif + /// Compile-time all/any/none of that check the boolean value of all template types #if defined(__cpp_fold_expressions) && !(defined(_MSC_VER) && (_MSC_VER < 1916)) @@ -505,17 +543,17 @@ template class... Predicates> using satisfies_none_of /// Strip the class from a method type template struct remove_class { }; -template struct remove_class { typedef R type(A...); }; -template struct remove_class { typedef R type(A...); }; +template struct remove_class { using type = R (A...); }; +template struct remove_class { using type = R (A...); }; /// Helper template to strip away type modifiers -template struct intrinsic_type { typedef T type; }; -template struct intrinsic_type { typedef typename intrinsic_type::type type; }; -template struct intrinsic_type { typedef typename intrinsic_type::type type; }; -template struct intrinsic_type { typedef typename intrinsic_type::type type; }; -template struct intrinsic_type { typedef typename intrinsic_type::type type; }; -template struct intrinsic_type { typedef typename intrinsic_type::type type; }; -template struct intrinsic_type { typedef typename intrinsic_type::type type; }; +template struct intrinsic_type { using type = T; }; +template struct intrinsic_type { using type = typename intrinsic_type::type; }; +template struct intrinsic_type { using type = typename intrinsic_type::type; }; +template struct intrinsic_type { using type = typename intrinsic_type::type; }; +template struct intrinsic_type { using type = typename intrinsic_type::type; }; +template struct intrinsic_type { using type = typename intrinsic_type::type; }; +template struct intrinsic_type { using type = typename intrinsic_type::type; }; template using intrinsic_t = typename intrinsic_type::type; /// Helper type to replace 'void' in some expressions @@ -533,7 +571,7 @@ template constexpr size_t constexpr_sum(T n, Ts... ns) { return size_t{n} + constexpr_sum(ns...); } #endif -NAMESPACE_BEGIN(constexpr_impl) +PYBIND11_NAMESPACE_BEGIN(constexpr_impl) /// Implementation details for constexpr functions constexpr int first(int i) { return i; } template @@ -542,7 +580,7 @@ constexpr int first(int i, T v, Ts... vs) { return v ? i : first(i + 1, vs...); constexpr int last(int /*i*/, int result) { return result; } template constexpr int last(int i, int result, T v, Ts... vs) { return last(i + 1, v ? i : result, vs...); } -NAMESPACE_END(constexpr_impl) +PYBIND11_NAMESPACE_END(constexpr_impl) /// Return the index of the first type in Ts which satisfies Predicate. Returns sizeof...(Ts) if /// none match. @@ -584,6 +622,12 @@ template using deferred_t = typename deferred_type< template using is_strict_base_of = bool_constant< std::is_base_of::value && !std::is_same::value>; +/// Like is_base_of, but also requires that the base type is accessible (i.e. that a Derived pointer +/// can be converted to a Base pointer) +/// For unions, `is_base_of::value` is False, so we need to check `is_same` as well. +template using is_accessible_base_of = bool_constant< + (std::is_same::value || std::is_base_of::value) && std::is_convertible::value>; + template class Base> struct is_template_base_of_impl { template static std::true_type check(Base *); @@ -648,10 +692,10 @@ inline void ignore_unused(const int *) { } #define PYBIND11_EXPAND_SIDE_EFFECTS(PATTERN) (((PATTERN), void()), ...) #else using expand_side_effects = bool[]; -#define PYBIND11_EXPAND_SIDE_EFFECTS(PATTERN) pybind11::detail::expand_side_effects{ ((PATTERN), void(), false)..., false } +#define PYBIND11_EXPAND_SIDE_EFFECTS(PATTERN) (void)pybind11::detail::expand_side_effects{ ((PATTERN), void(), false)..., false } #endif -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /// C++ bindings of builtin Python exceptions class builtin_exception : public std::runtime_error { @@ -673,6 +717,8 @@ PYBIND11_RUNTIME_EXCEPTION(index_error, PyExc_IndexError) PYBIND11_RUNTIME_EXCEPTION(key_error, PyExc_KeyError) PYBIND11_RUNTIME_EXCEPTION(value_error, PyExc_ValueError) PYBIND11_RUNTIME_EXCEPTION(type_error, PyExc_TypeError) +PYBIND11_RUNTIME_EXCEPTION(buffer_error, PyExc_BufferError) +PYBIND11_RUNTIME_EXCEPTION(import_error, PyExc_ImportError) PYBIND11_RUNTIME_EXCEPTION(cast_error, PyExc_RuntimeError) /// Thrown when pybind11::cast or handle::call fail due to a type casting error PYBIND11_RUNTIME_EXCEPTION(reference_cast_error, PyExc_RuntimeError) /// Used internally @@ -681,7 +727,7 @@ PYBIND11_RUNTIME_EXCEPTION(reference_cast_error, PyExc_RuntimeError) /// Used in template struct format_descriptor { }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) // Returns the index of the given type in the type char array below, and in the list in numpy.h // The order here is: bool; 8 ints ((signed,unsigned)x(8,16,32,64)bits); float,double,long double; // complex float,double,long double. Note that the long double types only participate when long @@ -694,7 +740,7 @@ template struct is_fmt_numeric std::is_integral::value ? detail::log2(sizeof(T))*2 + std::is_unsigned::value : 8 + ( std::is_same::value ? 1 : std::is_same::value ? 2 : 0)); }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) template struct format_descriptor::value>> { static constexpr const char c = "?bBhHiIqQfdg"[detail::is_fmt_numeric::index]; @@ -702,9 +748,13 @@ template struct format_descriptor constexpr const char format_descriptor< T, detail::enable_if_t::value>>::value[2]; +#endif + /// RAII wrapper that temporarily clears any Python error state struct error_scope { PyObject *type, *value, *trace; @@ -715,14 +765,10 @@ struct error_scope { /// Dummy destructor wrapper that can be used to expose classes with a private destructor struct nodelete { template void operator()(T*) { } }; -// overload_cast requires variable templates: C++14 -#if defined(PYBIND11_CPP14) -#define PYBIND11_OVERLOAD_CAST 1 - -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) template struct overload_cast_impl { - constexpr overload_cast_impl() {} // MSVC 2015 needs this + constexpr overload_cast_impl() {}; // NOLINT(modernize-use-equals-default): MSVC 2015 needs this template constexpr auto operator()(Return (*pf)(Args...)) const noexcept @@ -736,28 +782,32 @@ struct overload_cast_impl { constexpr auto operator()(Return (Class::*pmf)(Args...) const, std::true_type) const noexcept -> decltype(pmf) { return pmf; } }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) +// overload_cast requires variable templates: C++14 +#if defined(PYBIND11_CPP14) +#define PYBIND11_OVERLOAD_CAST 1 /// Syntax sugar for resolving overloaded function pointers: /// - regular: static_cast(&Class::func) /// - sweet: overload_cast(&Class::func) template static constexpr detail::overload_cast_impl overload_cast = {}; // MSVC 2015 only accepts this particular initialization syntax for this variable template. +#endif /// Const member function selector for overload_cast /// - regular: static_cast(&Class::func) /// - sweet: overload_cast(&Class::func, const_) static constexpr auto const_ = std::true_type{}; -#else // no overload_cast: providing something that static_assert-fails: +#if !defined(PYBIND11_CPP14) // no overload_cast: providing something that static_assert-fails: template struct overload_cast { static_assert(detail::deferred_t::value, "pybind11::overload_cast<...> requires compiling in C++14 mode"); }; #endif // overload_cast -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) // Adaptor for converting arbitrary container arguments into a vector; implicitly convertible from // any standard container (or C-style array) supporting std::begin/std::end, any singleton @@ -796,8 +846,8 @@ class any_container { const std::vector *operator->() const { return &v; } }; -NAMESPACE_END(detail) - - +// Forward-declaration; see detail/class.h +std::string get_fully_qualified_tp_name(PyTypeObject*); -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/detail/descr.h b/plugins/python/pybind11/include/pybind11/detail/descr.h index e3bf2ba..92720cd 100644 --- a/plugins/python/pybind11/include/pybind11/detail/descr.h +++ b/plugins/python/pybind11/include/pybind11/detail/descr.h @@ -1,6 +1,5 @@ /* - pybind11/detail/descr.h: Helper type for concatenating type signatures - either at runtime (C++11) or compile time (C++14) + pybind11/detail/descr.h: Helper type for concatenating type signatures at compile time Copyright (c) 2016 Wenzel Jakob @@ -12,174 +11,90 @@ #include "common.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) - -/* Concatenate type signatures at compile time using C++14 */ -#if defined(PYBIND11_CPP14) && !defined(_MSC_VER) -#define PYBIND11_CONSTEXPR_DESCR - -template class descr { - template friend class descr; -public: - constexpr descr(char const (&text) [Size1+1], const std::type_info * const (&types)[Size2+1]) - : descr(text, types, - make_index_sequence(), - make_index_sequence()) { } - - constexpr const char *text() const { return m_text; } - constexpr const std::type_info * const * types() const { return m_types; } - - template - constexpr descr operator+(const descr &other) const { - return concat(other, - make_index_sequence(), - make_index_sequence(), - make_index_sequence(), - make_index_sequence()); - } +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) -protected: - template - constexpr descr( - char const (&text) [Size1+1], - const std::type_info * const (&types) [Size2+1], - index_sequence, index_sequence) - : m_text{text[Indices1]..., '\0'}, - m_types{types[Indices2]..., nullptr } {} - - template - constexpr descr - concat(const descr &other, - index_sequence, index_sequence, - index_sequence, index_sequence) const { - return descr( - { m_text[Indices1]..., other.m_text[OtherIndices1]..., '\0' }, - { m_types[Indices2]..., other.m_types[OtherIndices2]..., nullptr } - ); - } +#if !defined(_MSC_VER) +# define PYBIND11_DESCR_CONSTEXPR static constexpr +#else +# define PYBIND11_DESCR_CONSTEXPR const +#endif + +/* Concatenate type signatures at compile time */ +template +struct descr { + char text[N + 1]; + + constexpr descr() : text{'\0'} { } + constexpr descr(char const (&s)[N+1]) : descr(s, make_index_sequence()) { } -protected: - char m_text[Size1 + 1]; - const std::type_info * m_types[Size2 + 1]; + template + constexpr descr(char const (&s)[N+1], index_sequence) : text{s[Is]..., '\0'} { } + + template + constexpr descr(char c, Chars... cs) : text{c, static_cast(cs)..., '\0'} { } + + static constexpr std::array types() { + return {{&typeid(Ts)..., nullptr}}; + } }; -template constexpr descr _(char const(&text)[Size]) { - return descr(text, { nullptr }); +template +constexpr descr plus_impl(const descr &a, const descr &b, + index_sequence, index_sequence) { + return {a.text[Is1]..., b.text[Is2]...}; +} + +template +constexpr descr operator+(const descr &a, const descr &b) { + return plus_impl(a, b, make_index_sequence(), make_index_sequence()); } +template +constexpr descr _(char const(&text)[N]) { return descr(text); } +constexpr descr<0> _(char const(&)[1]) { return {}; } + template struct int_to_str : int_to_str { }; template struct int_to_str<0, Digits...> { - static constexpr auto digits = descr({ ('0' + Digits)..., '\0' }, { nullptr }); + static constexpr auto digits = descr(('0' + Digits)...); }; // Ternary description (like std::conditional) -template -constexpr enable_if_t> _(char const(&text1)[Size1], char const(&)[Size2]) { +template +constexpr enable_if_t> _(char const(&text1)[N1], char const(&)[N2]) { return _(text1); } -template -constexpr enable_if_t> _(char const(&)[Size1], char const(&text2)[Size2]) { +template +constexpr enable_if_t> _(char const(&)[N1], char const(&text2)[N2]) { return _(text2); } -template -constexpr enable_if_t> _(descr d, descr) { return d; } -template -constexpr enable_if_t> _(descr, descr d) { return d; } + +template +constexpr enable_if_t _(const T1 &d, const T2 &) { return d; } +template +constexpr enable_if_t _(const T1 &, const T2 &d) { return d; } template auto constexpr _() -> decltype(int_to_str::digits) { return int_to_str::digits; } -template constexpr descr<1, 1> _() { - return descr<1, 1>({ '%', '\0' }, { &typeid(Type), nullptr }); -} - -inline constexpr descr<0, 0> concat() { return _(""); } -template auto constexpr concat(descr descr) { return descr; } -template auto constexpr concat(descr descr, Args&&... args) { return descr + _(", ") + concat(args...); } -template auto constexpr type_descr(descr descr) { return _("{") + descr + _("}"); } - -#define PYBIND11_DESCR constexpr auto - -#else /* Simpler C++11 implementation based on run-time memory allocation and copying */ - -class descr { -public: - PYBIND11_NOINLINE descr(const char *text, const std::type_info * const * types) { - size_t nChars = len(text), nTypes = len(types); - m_text = new char[nChars]; - m_types = new const std::type_info *[nTypes]; - memcpy(m_text, text, nChars * sizeof(char)); - memcpy(m_types, types, nTypes * sizeof(const std::type_info *)); - } +template constexpr descr<1, Type> _() { return {'%'}; } - PYBIND11_NOINLINE descr operator+(descr &&d2) && { - descr r; +constexpr descr<0> concat() { return {}; } - size_t nChars1 = len(m_text), nTypes1 = len(m_types); - size_t nChars2 = len(d2.m_text), nTypes2 = len(d2.m_types); +template +constexpr descr concat(const descr &descr) { return descr; } - r.m_text = new char[nChars1 + nChars2 - 1]; - r.m_types = new const std::type_info *[nTypes1 + nTypes2 - 1]; - memcpy(r.m_text, m_text, (nChars1-1) * sizeof(char)); - memcpy(r.m_text + nChars1 - 1, d2.m_text, nChars2 * sizeof(char)); - memcpy(r.m_types, m_types, (nTypes1-1) * sizeof(std::type_info *)); - memcpy(r.m_types + nTypes1 - 1, d2.m_types, nTypes2 * sizeof(std::type_info *)); - - delete[] m_text; delete[] m_types; - delete[] d2.m_text; delete[] d2.m_types; - - return r; - } - - char *text() { return m_text; } - const std::type_info * * types() { return m_types; } - -protected: - PYBIND11_NOINLINE descr() { } - - template static size_t len(const T *ptr) { // return length including null termination - const T *it = ptr; - while (*it++ != (T) 0) - ; - return static_cast(it - ptr); - } - - const std::type_info **m_types = nullptr; - char *m_text = nullptr; -}; - -/* The 'PYBIND11_NOINLINE inline' combinations below are intentional to get the desired linkage while producing as little object code as possible */ - -PYBIND11_NOINLINE inline descr _(const char *text) { - const std::type_info *types[1] = { nullptr }; - return descr(text, types); -} - -template PYBIND11_NOINLINE enable_if_t _(const char *text1, const char *) { return _(text1); } -template PYBIND11_NOINLINE enable_if_t _(char const *, const char *text2) { return _(text2); } -template PYBIND11_NOINLINE enable_if_t _(descr d, descr) { return d; } -template PYBIND11_NOINLINE enable_if_t _(descr, descr d) { return d; } - -template PYBIND11_NOINLINE descr _() { - const std::type_info *types[2] = { &typeid(Type), nullptr }; - return descr("%", types); +template +constexpr auto concat(const descr &d, const Args &...args) + -> decltype(std::declval>() + concat(args...)) { + return d + _(", ") + concat(args...); } -template PYBIND11_NOINLINE descr _() { - const std::type_info *types[1] = { nullptr }; - return descr(std::to_string(Size).c_str(), types); +template +constexpr descr type_descr(const descr &descr) { + return _("{") + descr + _("}"); } -PYBIND11_NOINLINE inline descr concat() { return _(""); } -PYBIND11_NOINLINE inline descr concat(descr &&d) { return d; } -template PYBIND11_NOINLINE descr concat(descr &&d, Args&&... args) { return std::move(d) + _(", ") + concat(std::forward(args)...); } -PYBIND11_NOINLINE inline descr type_descr(descr&& d) { return _("{") + std::move(d) + _("}"); } - -#define PYBIND11_DESCR ::pybind11::detail::descr -#endif - -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/detail/init.h b/plugins/python/pybind11/include/pybind11/detail/init.h index 82f7407..3ef78c1 100644 --- a/plugins/python/pybind11/include/pybind11/detail/init.h +++ b/plugins/python/pybind11/include/pybind11/detail/init.h @@ -11,8 +11,8 @@ #include "class.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) template <> class type_caster { @@ -24,13 +24,13 @@ class type_caster { template using cast_op_type = value_and_holder &; operator value_and_holder &() { return *value; } - static PYBIND11_DESCR name() { return type_descr(_()); } + static constexpr auto name = _(); private: value_and_holder *value = nullptr; }; -NAMESPACE_BEGIN(initimpl) +PYBIND11_NAMESPACE_BEGIN(initimpl) inline void no_nullptr(void *ptr) { if (!ptr) throw type_error("pybind11::init(): factory function returned nullptr"); @@ -132,6 +132,7 @@ void construct(value_and_holder &v_h, Alias *alias_ptr, bool) { template void construct(value_and_holder &v_h, Holder holder, bool need_alias) { auto *ptr = holder_helper>::get(holder); + no_nullptr(ptr); // If we need an alias, check that the held pointer is actually an alias instance if (Class::has_alias && need_alias && !is_alias(ptr)) throw type_error("pybind11::init(): construction failed: returned holder-wrapped instance " @@ -330,6 +331,6 @@ struct pickle_factory { } }; -NAMESPACE_END(initimpl) -NAMESPACE_END(detail) -NAMESPACE_END(pybind11) +PYBIND11_NAMESPACE_END(initimpl) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(pybind11) diff --git a/plugins/python/pybind11/include/pybind11/detail/internals.h b/plugins/python/pybind11/include/pybind11/detail/internals.h index 78d4afe..a455715 100644 --- a/plugins/python/pybind11/include/pybind11/detail/internals.h +++ b/plugins/python/pybind11/include/pybind11/detail/internals.h @@ -11,8 +11,8 @@ #include "../pytypes.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) // Forward declarations inline PyTypeObject *make_static_property_type(); inline PyTypeObject *make_default_metaclass(); @@ -23,8 +23,9 @@ inline PyObject *make_object_base_type(PyTypeObject *metaclass); #if PY_VERSION_HEX >= 0x03070000 # define PYBIND11_TLS_KEY_INIT(var) Py_tss_t *var = nullptr # define PYBIND11_TLS_GET_VALUE(key) PyThread_tss_get((key)) -# define PYBIND11_TLS_REPLACE_VALUE(key, value) PyThread_tss_set((key), (tstate)) +# define PYBIND11_TLS_REPLACE_VALUE(key, value) PyThread_tss_set((key), (value)) # define PYBIND11_TLS_DELETE_VALUE(key) PyThread_tss_set((key), nullptr) +# define PYBIND11_TLS_FREE(key) PyThread_tss_free(key) #else // Usually an int but a long on Cygwin64 with Python 3.x # define PYBIND11_TLS_KEY_INIT(var) decltype(PyThread_create_key()) var = 0 @@ -43,6 +44,7 @@ inline PyObject *make_object_base_type(PyTypeObject *metaclass); # define PYBIND11_TLS_REPLACE_VALUE(key, value) \ PyThread_set_key_value((key), (value)) # endif +# define PYBIND11_TLS_FREE(key) (void)key #endif // Python loads modules by default with dlopen with the RTLD_LOCAL flag; under libc++ and possibly @@ -80,10 +82,10 @@ struct type_equal_to { template using type_map = std::unordered_map; -struct overload_hash { +struct override_hash { inline size_t operator()(const std::pair& v) const { size_t value = std::hash()(v.first); - value ^= std::hash()(v.second) + 0x9e3779b9 + (value<<6) + (value>>2); + value ^= std::hash()(v.second) + 0x9e3779b9 + (value<<6) + (value>>2); return value; } }; @@ -95,7 +97,7 @@ struct internals { type_map registered_types_cpp; // std::type_index -> pybind11's type information std::unordered_map> registered_types_py; // PyTypeObject* -> base type_info(s) std::unordered_multimap registered_instances; // void * -> instance* - std::unordered_set, overload_hash> inactive_overload_cache; + std::unordered_set, override_hash> inactive_override_cache; type_map> direct_conversions; std::unordered_map> patients; std::forward_list registered_exception_translators; @@ -108,6 +110,16 @@ struct internals { #if defined(WITH_THREAD) PYBIND11_TLS_KEY_INIT(tstate); PyInterpreterState *istate = nullptr; + ~internals() { + // This destructor is called *after* Py_Finalize() in finalize_interpreter(). + // That *SHOULD BE* fine. The following details what happens whe PyThread_tss_free is called. + // PYBIND11_TLS_FREE is PyThread_tss_free on python 3.7+. On older python, it does nothing. + // PyThread_tss_free calls PyThread_tss_delete and PyMem_RawFree. + // PyThread_tss_delete just calls TlsFree (on Windows) or pthread_key_delete (on *NIX). Neither + // of those have anything to do with CPython internals. + // PyMem_RawFree *requires* that the `tstate` be allocated with the CPython allocator. + PYBIND11_TLS_FREE(tstate); + } #endif }; @@ -116,7 +128,7 @@ struct internals { struct type_info { PyTypeObject *type; const std::type_info *cpptype; - size_t type_size, holder_size_in_ptrs; + size_t type_size, type_align, holder_size_in_ptrs; void *(*operator_new)(size_t); void (*init_instance)(instance *, const void *); void (*dealloc)(value_and_holder &v_h); @@ -138,19 +150,71 @@ struct type_info { }; /// Tracks the `internals` and `type_info` ABI version independent of the main library version -#define PYBIND11_INTERNALS_VERSION 2 +#define PYBIND11_INTERNALS_VERSION 4 -#if defined(WITH_THREAD) -# define PYBIND11_INTERNALS_KIND "" +/// On MSVC, debug and release builds are not ABI-compatible! +#if defined(_MSC_VER) && defined(_DEBUG) +# define PYBIND11_BUILD_TYPE "_debug" #else -# define PYBIND11_INTERNALS_KIND "_without_thread" +# define PYBIND11_BUILD_TYPE "" +#endif + +/// Let's assume that different compilers are ABI-incompatible. +/// A user can manually set this string if they know their +/// compiler is compatible. +#ifndef PYBIND11_COMPILER_TYPE +# if defined(_MSC_VER) +# define PYBIND11_COMPILER_TYPE "_msvc" +# elif defined(__INTEL_COMPILER) +# define PYBIND11_COMPILER_TYPE "_icc" +# elif defined(__clang__) +# define PYBIND11_COMPILER_TYPE "_clang" +# elif defined(__PGI) +# define PYBIND11_COMPILER_TYPE "_pgi" +# elif defined(__MINGW32__) +# define PYBIND11_COMPILER_TYPE "_mingw" +# elif defined(__CYGWIN__) +# define PYBIND11_COMPILER_TYPE "_gcc_cygwin" +# elif defined(__GNUC__) +# define PYBIND11_COMPILER_TYPE "_gcc" +# else +# define PYBIND11_COMPILER_TYPE "_unknown" +# endif +#endif + +/// Also standard libs +#ifndef PYBIND11_STDLIB +# if defined(_LIBCPP_VERSION) +# define PYBIND11_STDLIB "_libcpp" +# elif defined(__GLIBCXX__) || defined(__GLIBCPP__) +# define PYBIND11_STDLIB "_libstdcpp" +# else +# define PYBIND11_STDLIB "" +# endif +#endif + +/// On Linux/OSX, changes in __GXX_ABI_VERSION__ indicate ABI incompatibility. +#ifndef PYBIND11_BUILD_ABI +# if defined(__GXX_ABI_VERSION) +# define PYBIND11_BUILD_ABI "_cxxabi" PYBIND11_TOSTRING(__GXX_ABI_VERSION) +# else +# define PYBIND11_BUILD_ABI "" +# endif +#endif + +#ifndef PYBIND11_INTERNALS_KIND +# if defined(WITH_THREAD) +# define PYBIND11_INTERNALS_KIND "" +# else +# define PYBIND11_INTERNALS_KIND "_without_thread" +# endif #endif #define PYBIND11_INTERNALS_ID "__pybind11_internals_v" \ - PYBIND11_TOSTRING(PYBIND11_INTERNALS_VERSION) PYBIND11_INTERNALS_KIND "__" + PYBIND11_TOSTRING(PYBIND11_INTERNALS_VERSION) PYBIND11_INTERNALS_KIND PYBIND11_COMPILER_TYPE PYBIND11_STDLIB PYBIND11_BUILD_ABI PYBIND11_BUILD_TYPE "__" #define PYBIND11_MODULE_LOCAL_ID "__pybind11_module_local_v" \ - PYBIND11_TOSTRING(PYBIND11_INTERNALS_VERSION) PYBIND11_INTERNALS_KIND "__" + PYBIND11_TOSTRING(PYBIND11_INTERNALS_VERSION) PYBIND11_INTERNALS_KIND PYBIND11_COMPILER_TYPE PYBIND11_STDLIB PYBIND11_BUILD_ABI PYBIND11_BUILD_TYPE "__" /// Each module locally stores a pointer to the `internals` data. The data /// itself is shared among modules with the same `PYBIND11_INTERNALS_ID`. @@ -159,12 +223,49 @@ inline internals **&get_internals_pp() { return internals_pp; } +inline void translate_exception(std::exception_ptr p) { + try { + if (p) std::rethrow_exception(p); + } catch (error_already_set &e) { e.restore(); return; + } catch (const builtin_exception &e) { e.set_error(); return; + } catch (const std::bad_alloc &e) { PyErr_SetString(PyExc_MemoryError, e.what()); return; + } catch (const std::domain_error &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; + } catch (const std::invalid_argument &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; + } catch (const std::length_error &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; + } catch (const std::out_of_range &e) { PyErr_SetString(PyExc_IndexError, e.what()); return; + } catch (const std::range_error &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; + } catch (const std::overflow_error &e) { PyErr_SetString(PyExc_OverflowError, e.what()); return; + } catch (const std::exception &e) { PyErr_SetString(PyExc_RuntimeError, e.what()); return; + } catch (...) { + PyErr_SetString(PyExc_RuntimeError, "Caught an unknown exception!"); + return; + } +} + +#if !defined(__GLIBCXX__) +inline void translate_local_exception(std::exception_ptr p) { + try { + if (p) std::rethrow_exception(p); + } catch (error_already_set &e) { e.restore(); return; + } catch (const builtin_exception &e) { e.set_error(); return; + } +} +#endif + /// Return a reference to the current `internals` data PYBIND11_NOINLINE inline internals &get_internals() { auto **&internals_pp = get_internals_pp(); if (internals_pp && *internals_pp) return **internals_pp; + // Ensure that the GIL is held since we will need to make Python calls. + // Cannot use py::gil_scoped_acquire here since that constructor calls get_internals. + struct gil_scoped_acquire_local { + gil_scoped_acquire_local() : state (PyGILState_Ensure()) {} + ~gil_scoped_acquire_local() { PyGILState_Release(state); } + const PyGILState_STATE state; + } gil; + constexpr auto *id = PYBIND11_INTERNALS_ID; auto builtins = handle(PyEval_GetBuiltins()); if (builtins.contains(id) && isinstance(builtins[id])) { @@ -176,22 +277,17 @@ PYBIND11_NOINLINE inline internals &get_internals() { // // libstdc++ doesn't require this (types there are identified only by name) #if !defined(__GLIBCXX__) - (*internals_pp)->registered_exception_translators.push_front( - [](std::exception_ptr p) -> void { - try { - if (p) std::rethrow_exception(p); - } catch (error_already_set &e) { e.restore(); return; - } catch (const builtin_exception &e) { e.set_error(); return; - } - } - ); + (*internals_pp)->registered_exception_translators.push_front(&translate_local_exception); #endif } else { if (!internals_pp) internals_pp = new internals*(); auto *&internals_ptr = *internals_pp; internals_ptr = new internals(); #if defined(WITH_THREAD) - PyEval_InitThreads(); + + #if PY_VERSION_HEX < 0x03090000 + PyEval_InitThreads(); + #endif PyThreadState *tstate = PyThreadState_Get(); #if PY_VERSION_HEX >= 0x03070000 internals_ptr->tstate = PyThread_tss_alloc(); @@ -207,25 +303,7 @@ PYBIND11_NOINLINE inline internals &get_internals() { internals_ptr->istate = tstate->interp; #endif builtins[id] = capsule(internals_pp); - internals_ptr->registered_exception_translators.push_front( - [](std::exception_ptr p) -> void { - try { - if (p) std::rethrow_exception(p); - } catch (error_already_set &e) { e.restore(); return; - } catch (const builtin_exception &e) { e.set_error(); return; - } catch (const std::bad_alloc &e) { PyErr_SetString(PyExc_MemoryError, e.what()); return; - } catch (const std::domain_error &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; - } catch (const std::invalid_argument &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; - } catch (const std::length_error &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; - } catch (const std::out_of_range &e) { PyErr_SetString(PyExc_IndexError, e.what()); return; - } catch (const std::range_error &e) { PyErr_SetString(PyExc_ValueError, e.what()); return; - } catch (const std::exception &e) { PyErr_SetString(PyExc_RuntimeError, e.what()); return; - } catch (...) { - PyErr_SetString(PyExc_RuntimeError, "Caught an unknown exception!"); - return; - } - } - ); + internals_ptr->registered_exception_translators.push_front(&translate_exception); internals_ptr->static_property_type = make_static_property_type(); internals_ptr->default_metaclass = make_default_metaclass(); internals_ptr->instance_base = make_object_base_type(internals_ptr->default_metaclass); @@ -250,7 +328,7 @@ const char *c_str(Args &&...args) { return strings.front().c_str(); } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /// Returns a named pointer that is shared among all extension modules (using the same /// pybind11 version) running in the current interpreter. Names starting with underscores @@ -282,4 +360,4 @@ T &get_or_create_shared_data(const std::string &name) { return *ptr; } -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/detail/typeid.h b/plugins/python/pybind11/include/pybind11/detail/typeid.h index 6f36aab..148889f 100644 --- a/plugins/python/pybind11/include/pybind11/detail/typeid.h +++ b/plugins/python/pybind11/include/pybind11/detail/typeid.h @@ -16,8 +16,10 @@ #include #endif -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +#include "common.h" + +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) /// Erase all occurrences of a substring inline void erase_all(std::string &string, const std::string &search) { for (size_t pos = 0;;) { @@ -41,7 +43,7 @@ PYBIND11_NOINLINE inline void clean_type_id(std::string &name) { #endif detail::erase_all(name, "pybind11::"); } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /// Return a string representation of a C++ type template static std::string type_id() { @@ -50,4 +52,4 @@ template static std::string type_id() { return name; } -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/eigen.h b/plugins/python/pybind11/include/pybind11/eigen.h index 0899ec7..e8c6f63 100644 --- a/plugins/python/pybind11/include/pybind11/eigen.h +++ b/plugins/python/pybind11/include/pybind11/eigen.h @@ -17,6 +17,11 @@ # pragma GCC diagnostic push # pragma GCC diagnostic ignored "-Wconversion" # pragma GCC diagnostic ignored "-Wdeprecated-declarations" +# ifdef __clang__ +// Eigen generates a bunch of implicit-copy-constructor-is-deprecated warnings with -Wdeprecated +// under Clang, so disable that warning here: +# pragma GCC diagnostic ignored "-Wdeprecated" +# endif # if __GNUC__ >= 7 # pragma GCC diagnostic ignored "-Wint-in-bool-context" # endif @@ -36,14 +41,14 @@ // of matrices seems highly undesirable. static_assert(EIGEN_VERSION_AT_LEAST(3,2,7), "Eigen support in pybind11 requires Eigen >= 3.2.7"); -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) // Provide a convenience alias for easier pass-by-ref usage with fully dynamic strides: using EigenDStride = Eigen::Stride; template using EigenDRef = Eigen::Ref; template using EigenDMap = Eigen::Map; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) #if EIGEN_VERSION_AT_LEAST(3,3,0) using EigenIndex = Eigen::Index; @@ -181,28 +186,26 @@ template struct EigenProps { } } - static PYBIND11_DESCR descriptor() { - constexpr bool show_writeable = is_eigen_dense_map::value && is_eigen_mutable_map::value; - constexpr bool show_order = is_eigen_dense_map::value; - constexpr bool show_c_contiguous = show_order && requires_row_major; - constexpr bool show_f_contiguous = !show_c_contiguous && show_order && requires_col_major; - - return type_descr(_("numpy.ndarray[") + npy_format_descriptor::name() + - _("[") + _(_<(size_t) rows>(), _("m")) + - _(", ") + _(_<(size_t) cols>(), _("n")) + - _("]") + - // For a reference type (e.g. Ref) we have other constraints that might need to be - // satisfied: writeable=True (for a mutable reference), and, depending on the map's stride - // options, possibly f_contiguous or c_contiguous. We include them in the descriptor output - // to provide some hint as to why a TypeError is occurring (otherwise it can be confusing to - // see that a function accepts a 'numpy.ndarray[float64[3,2]]' and an error message that you - // *gave* a numpy.ndarray of the right type and dimensions. - _(", flags.writeable", "") + - _(", flags.c_contiguous", "") + - _(", flags.f_contiguous", "") + - _("]") - ); - } + static constexpr bool show_writeable = is_eigen_dense_map::value && is_eigen_mutable_map::value; + static constexpr bool show_order = is_eigen_dense_map::value; + static constexpr bool show_c_contiguous = show_order && requires_row_major; + static constexpr bool show_f_contiguous = !show_c_contiguous && show_order && requires_col_major; + + static constexpr auto descriptor = + _("numpy.ndarray[") + npy_format_descriptor::name + + _("[") + _(_<(size_t) rows>(), _("m")) + + _(", ") + _(_<(size_t) cols>(), _("n")) + + _("]") + + // For a reference type (e.g. Ref) we have other constraints that might need to be + // satisfied: writeable=True (for a mutable reference), and, depending on the map's stride + // options, possibly f_contiguous or c_contiguous. We include them in the descriptor output + // to provide some hint as to why a TypeError is occurring (otherwise it can be confusing to + // see that a function accepts a 'numpy.ndarray[float64[3,2]]' and an error message that you + // *gave* a numpy.ndarray of the right type and dimensions. + _(", flags.writeable", "") + + _(", flags.c_contiguous", "") + + _(", flags.f_contiguous", "") + + _("]"); }; // Casts an Eigen type to numpy array. If given a base, the numpy array references the src data, @@ -339,7 +342,7 @@ struct type_caster::value>> { return cast_impl(src, policy, parent); } - static PYBIND11_DESCR name() { return props::descriptor(); } + static constexpr auto name = props::descriptor; operator Type*() { return &value; } operator Type&() { return value; } @@ -379,7 +382,7 @@ template struct eigen_map_caster { } } - static PYBIND11_DESCR name() { return props::descriptor(); } + static constexpr auto name = props::descriptor; // Explicitly delete these: support python -> C++ conversion on these (i.e. these can be return // types but not bound arguments). We still provide them (with an explicitly delete) so that @@ -429,7 +432,7 @@ struct type_caster< if (!need_copy) { // We don't need a converting copy, but we also need to check whether the strides are // compatible with the Ref's stride requirements - Array aref = reinterpret_borrow(src); + auto aref = reinterpret_borrow(src); if (aref && (!need_writeable || aref.writeable())) { fits = props::conformable(aref); @@ -524,7 +527,7 @@ struct type_caster::value>> { } static handle cast(const Type *src, return_value_policy policy, handle parent) { return cast(*src, policy, parent); } - static PYBIND11_DESCR name() { return props::descriptor(); } + static constexpr auto name = props::descriptor; // Explicitly delete these: support python -> C++ conversion on these (i.e. these can be return // types but not bound arguments). We still provide them (with an explicitly delete) so that @@ -536,9 +539,9 @@ struct type_caster::value>> { template struct type_caster::value>> { - typedef typename Type::Scalar Scalar; - typedef remove_reference_t().outerIndexPtr())> StorageIndex; - typedef typename Type::Index Index; + using Scalar = typename Type::Scalar; + using StorageIndex = remove_reference_t().outerIndexPtr())>; + using Index = typename Type::Index; static constexpr bool rowMajor = Type::IsRowMajor; bool load(handle src, bool) { @@ -546,11 +549,11 @@ struct type_caster::value>> { return false; auto obj = reinterpret_borrow(src); - object sparse_module = module::import("scipy.sparse"); + object sparse_module = module_::import("scipy.sparse"); object matrix_type = sparse_module.attr( rowMajor ? "csr_matrix" : "csc_matrix"); - if (!obj.get_type().is(matrix_type)) { + if (!type::handle_of(obj).is(matrix_type)) { try { obj = matrix_type(obj); } catch (const error_already_set &) { @@ -577,7 +580,7 @@ struct type_caster::value>> { static handle cast(const Type &src, return_value_policy /* policy */, handle /* parent */) { const_cast(src).makeCompressed(); - object matrix_type = module::import("scipy.sparse").attr( + object matrix_type = module_::import("scipy.sparse").attr( rowMajor ? "csr_matrix" : "csc_matrix"); array data(src.nonZeros(), src.valuePtr()); @@ -591,11 +594,11 @@ struct type_caster::value>> { } PYBIND11_TYPE_CASTER(Type, _<(Type::IsRowMajor) != 0>("scipy.sparse.csr_matrix[", "scipy.sparse.csc_matrix[") - + npy_format_descriptor::name() + _("]")); + + npy_format_descriptor::name + _("]")); }; -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) #if defined(__GNUG__) || defined(__clang__) # pragma GCC diagnostic pop diff --git a/plugins/python/pybind11/include/pybind11/embed.h b/plugins/python/pybind11/include/pybind11/embed.h index 9abc61c..204aaf9 100644 --- a/plugins/python/pybind11/include/pybind11/embed.h +++ b/plugins/python/pybind11/include/pybind11/embed.h @@ -18,11 +18,13 @@ #if PY_MAJOR_VERSION >= 3 # define PYBIND11_EMBEDDED_MODULE_IMPL(name) \ + extern "C" PyObject *pybind11_init_impl_##name(); \ extern "C" PyObject *pybind11_init_impl_##name() { \ return pybind11_init_wrapper_##name(); \ } #else # define PYBIND11_EMBEDDED_MODULE_IMPL(name) \ + extern "C" void pybind11_init_impl_##name(); \ extern "C" void pybind11_init_impl_##name() { \ pybind11_init_wrapper_##name(); \ } @@ -43,29 +45,28 @@ }); } \endrst */ -#define PYBIND11_EMBEDDED_MODULE(name, variable) \ - static void PYBIND11_CONCAT(pybind11_init_, name)(pybind11::module &); \ - static PyObject PYBIND11_CONCAT(*pybind11_init_wrapper_, name)() { \ - auto m = pybind11::module(PYBIND11_TOSTRING(name)); \ - try { \ - PYBIND11_CONCAT(pybind11_init_, name)(m); \ - return m.ptr(); \ - } catch (pybind11::error_already_set &e) { \ - PyErr_SetString(PyExc_ImportError, e.what()); \ - return nullptr; \ - } catch (const std::exception &e) { \ - PyErr_SetString(PyExc_ImportError, e.what()); \ - return nullptr; \ - } \ - } \ - PYBIND11_EMBEDDED_MODULE_IMPL(name) \ - pybind11::detail::embedded_module name(PYBIND11_TOSTRING(name), \ - PYBIND11_CONCAT(pybind11_init_impl_, name)); \ - void PYBIND11_CONCAT(pybind11_init_, name)(pybind11::module &variable) - - -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +#define PYBIND11_EMBEDDED_MODULE(name, variable) \ + static ::pybind11::module_::module_def \ + PYBIND11_CONCAT(pybind11_module_def_, name); \ + static void PYBIND11_CONCAT(pybind11_init_, name)(::pybind11::module_ &); \ + static PyObject PYBIND11_CONCAT(*pybind11_init_wrapper_, name)() { \ + auto m = ::pybind11::module_::create_extension_module( \ + PYBIND11_TOSTRING(name), nullptr, \ + &PYBIND11_CONCAT(pybind11_module_def_, name)); \ + try { \ + PYBIND11_CONCAT(pybind11_init_, name)(m); \ + return m.ptr(); \ + } PYBIND11_CATCH_INIT_EXCEPTIONS \ + } \ + PYBIND11_EMBEDDED_MODULE_IMPL(name) \ + ::pybind11::detail::embedded_module PYBIND11_CONCAT(pybind11_module_, name) \ + (PYBIND11_TOSTRING(name), \ + PYBIND11_CONCAT(pybind11_init_impl_, name)); \ + void PYBIND11_CONCAT(pybind11_init_, name)(::pybind11::module_ &variable) + + +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) /// Python 2.7/3.x compatible version of `PyImport_AppendInittab` and error checks. struct embedded_module { @@ -84,14 +85,20 @@ struct embedded_module { } }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /** \rst Initialize the Python interpreter. No other pybind11 or CPython API functions can be called before this is done; with the exception of `PYBIND11_EMBEDDED_MODULE`. The optional parameter can be used to skip the registration of signal handlers (see the - Python documentation for details). Calling this function again after the interpreter + `Python documentation`_ for details). Calling this function again after the interpreter has already been initialized is a fatal error. + + If initializing the Python interpreter fails, then the program is terminated. (This + is controlled by the CPython runtime and is an exception to pybind11's normal behavior + of throwing exceptions on errors.) + + .. _Python documentation: https://docs.python.org/3/c-api/init.html#c.Py_InitializeEx \endrst */ inline void initialize_interpreter(bool init_signal_handlers = true) { if (Py_IsInitialized()) @@ -100,7 +107,7 @@ inline void initialize_interpreter(bool init_signal_handlers = true) { Py_InitializeEx(init_signal_handlers ? 1 : 0); // Make .py files in the working directory available by default - module::import("sys").attr("path").cast().append("."); + module_::import("sys").attr("path").cast().append("."); } /** \rst @@ -191,4 +198,4 @@ class scoped_interpreter { bool is_valid = true; }; -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/eval.h b/plugins/python/pybind11/include/pybind11/eval.h index ea85ba1..fa6b8af 100644 --- a/plugins/python/pybind11/include/pybind11/eval.h +++ b/plugins/python/pybind11/include/pybind11/eval.h @@ -13,7 +13,23 @@ #include "pybind11.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) + +inline void ensure_builtins_in_globals(object &global) { + #if PY_VERSION_HEX < 0x03080000 + // Running exec and eval on Python 2 and 3 adds `builtins` module under + // `__builtins__` key to globals if not yet present. + // Python 3.8 made PyRun_String behave similarly. Let's also do that for + // older versions, for consistency. + if (!global.contains("__builtins__")) + global["__builtins__"] = module_::import(PYBIND11_BUILTINS_MODULE); + #else + (void) global; + #endif +} + +PYBIND11_NAMESPACE_END(detail) enum eval_mode { /// Evaluate a string containing an isolated expression @@ -31,6 +47,8 @@ object eval(str expr, object global = globals(), object local = object()) { if (!local) local = global; + detail::ensure_builtins_in_globals(global); + /* PyRun_String does not accept a PyObject / encoding specifier, this seems to be the only alternative */ std::string buffer = "# -*- coding: utf-8 -*-\n" + (std::string) expr; @@ -52,7 +70,7 @@ object eval(str expr, object global = globals(), object local = object()) { template object eval(const char (&s)[N], object global = globals(), object local = object()) { /* Support raw string literals by removing common leading whitespace */ - auto expr = (s[0] == '\n') ? str(module::import("textwrap").attr("dedent")(s)) + auto expr = (s[0] == '\n') ? str(module_::import("textwrap").attr("dedent")(s)) : str(s); return eval(expr, global, local); } @@ -66,11 +84,27 @@ void exec(const char (&s)[N], object global = globals(), object local = object() eval(s, global, local); } +#if defined(PYPY_VERSION) && PY_VERSION_HEX >= 0x03000000 +template +object eval_file(str, object, object) { + pybind11_fail("eval_file not supported in PyPy3. Use eval"); +} +template +object eval_file(str, object) { + pybind11_fail("eval_file not supported in PyPy3. Use eval"); +} +template +object eval_file(str) { + pybind11_fail("eval_file not supported in PyPy3. Use eval"); +} +#else template object eval_file(str fname, object global = globals(), object local = object()) { if (!local) local = global; + detail::ensure_builtins_in_globals(global); + int start; switch (mode) { case eval_expr: start = Py_eval_input; break; @@ -113,5 +147,6 @@ object eval_file(str fname, object global = globals(), object local = object()) throw error_already_set(); return reinterpret_steal(result); } +#endif -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/functional.h b/plugins/python/pybind11/include/pybind11/functional.h index eda14ba..92c17dc 100644 --- a/plugins/python/pybind11/include/pybind11/functional.h +++ b/plugins/python/pybind11/include/pybind11/functional.h @@ -12,8 +12,8 @@ #include "pybind11.h" #include -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) template struct type_caster> { @@ -54,12 +54,33 @@ struct type_caster> { } } - value = [func](Args... args) -> Return { - gil_scoped_acquire acq; - object retval(func(std::forward(args)...)); - /* Visual studio 2015 parser issue: need parentheses around this expression */ - return (retval.template cast()); + // ensure GIL is held during functor destruction + struct func_handle { + function f; + func_handle(function&& f_) : f(std::move(f_)) {} + func_handle(const func_handle& f_) { + gil_scoped_acquire acq; + f = f_.f; + } + ~func_handle() { + gil_scoped_acquire acq; + function kill_f(std::move(f)); + } + }; + + // to emulate 'move initialization capture' in C++11 + struct func_wrapper { + func_handle hfunc; + func_wrapper(func_handle&& hf): hfunc(std::move(hf)) {} + Return operator()(Args... args) const { + gil_scoped_acquire acq; + object retval(hfunc.f(std::forward(args)...)); + /* Visual studio 2015 parser issue: need parentheses around this expression */ + return (retval.template cast()); + } }; + + value = func_wrapper(func_handle(std::move(func))); return true; } @@ -75,11 +96,9 @@ struct type_caster> { return cpp_function(std::forward(f_), policy).release(); } - PYBIND11_TYPE_CASTER(type, _("Callable[[") + - argument_loader::arg_names() + _("], ") + - make_caster::name() + - _("]")); + PYBIND11_TYPE_CASTER(type, _("Callable[[") + concat(make_caster::name...) + _("], ") + + make_caster::name + _("]")); }; -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/iostream.h b/plugins/python/pybind11/include/pybind11/iostream.h index 3caf556..5e9a814 100644 --- a/plugins/python/pybind11/include/pybind11/iostream.h +++ b/plugins/python/pybind11/include/pybind11/iostream.h @@ -17,19 +17,20 @@ #include #include -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) // Buffer that writes to Python instead of C++ class pythonbuf : public std::streambuf { private: using traits_type = std::streambuf::traits_type; - char d_buffer[1024]; + const size_t buf_size; + std::unique_ptr d_buffer; object pywrite; object pyflush; - int overflow(int c) { + int overflow(int c) override { if (!traits_type::eq_int_type(c, traits_type::eof())) { *pptr() = traits_type::to_char_type(c); pbump(1); @@ -37,33 +38,48 @@ class pythonbuf : public std::streambuf { return sync() == 0 ? traits_type::not_eof(c) : traits_type::eof(); } - int sync() { + // This function must be non-virtual to be called in a destructor. If the + // rare MSVC test failure shows up with this version, then this should be + // simplified to a fully qualified call. + int _sync() { if (pbase() != pptr()) { // This subtraction cannot be negative, so dropping the sign str line(pbase(), static_cast(pptr() - pbase())); - pywrite(line); - pyflush(); + { + gil_scoped_acquire tmp; + pywrite(line); + pyflush(); + } setp(pbase(), epptr()); } return 0; } + int sync() override { + return _sync(); + } + public: - pythonbuf(object pyostream) - : pywrite(pyostream.attr("write")), + + pythonbuf(object pyostream, size_t buffer_size = 1024) + : buf_size(buffer_size), + d_buffer(new char[buf_size]), + pywrite(pyostream.attr("write")), pyflush(pyostream.attr("flush")) { - setp(d_buffer, d_buffer + sizeof(d_buffer) - 1); + setp(d_buffer.get(), d_buffer.get() + buf_size - 1); } + pythonbuf(pythonbuf&&) = default; + /// Sync before destroy - ~pythonbuf() { - sync(); + ~pythonbuf() override { + _sync(); } }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /** \rst @@ -86,7 +102,7 @@ NAMESPACE_END(detail) .. code-block:: cpp { - py::scoped_ostream_redirect output{std::cerr, py::module::import("sys").attr("stderr")}; + py::scoped_ostream_redirect output{std::cerr, py::module_::import("sys").attr("stderr")}; std::cerr << "Hello, World!"; } \endrst */ @@ -99,7 +115,7 @@ class scoped_ostream_redirect { public: scoped_ostream_redirect( std::ostream &costream = std::cout, - object pyostream = module::import("sys").attr("stdout")) + object pyostream = module_::import("sys").attr("stdout")) : costream(costream), buffer(pyostream) { old = costream.rdbuf(&buffer); } @@ -130,12 +146,12 @@ class scoped_estream_redirect : public scoped_ostream_redirect { public: scoped_estream_redirect( std::ostream &costream = std::cerr, - object pyostream = module::import("sys").attr("stderr")) + object pyostream = module_::import("sys").attr("stderr")) : scoped_ostream_redirect(costream,pyostream) {} }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) // Class to redirect output as a context manager. C++ backend. class OstreamRedirect { @@ -161,7 +177,7 @@ class OstreamRedirect { } }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /** \rst This is a helper function to add a C++ redirect context manager to Python @@ -190,11 +206,11 @@ NAMESPACE_END(detail) m.noisy_function_with_error_printing() \endrst */ -inline class_ add_ostream_redirect(module m, std::string name = "ostream_redirect") { +inline class_ add_ostream_redirect(module_ m, std::string name = "ostream_redirect") { return class_(m, name.c_str(), module_local()) .def(init(), arg("stdout")=true, arg("stderr")=true) .def("__enter__", &detail::OstreamRedirect::enter) - .def("__exit__", [](detail::OstreamRedirect &self, args) { self.exit(); }); + .def("__exit__", [](detail::OstreamRedirect &self_, args) { self_.exit(); }); } -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/numpy.h b/plugins/python/pybind11/include/pybind11/numpy.h index 9df4934..019f568 100644 --- a/plugins/python/pybind11/include/pybind11/numpy.h +++ b/plugins/python/pybind11/include/pybind11/numpy.h @@ -14,13 +14,15 @@ #include #include #include +#include #include #include #include #include -#include #include +#include #include +#include #include #if defined(_MSC_VER) @@ -32,13 +34,18 @@ whole npy_intp / ssize_t / Py_intptr_t business down to just ssize_t for all size and dimension types (e.g. shape, strides, indexing), instead of inflicting this upon the library user. */ -static_assert(sizeof(ssize_t) == sizeof(Py_intptr_t), "ssize_t != Py_intptr_t"); +static_assert(sizeof(::pybind11::ssize_t) == sizeof(Py_intptr_t), "ssize_t != Py_intptr_t"); +static_assert(std::is_signed::value, "Py_intptr_t must be signed"); +// We now can reinterpret_cast between py::ssize_t and Py_intptr_t (MSVC + PyPy cares) -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) class array; // Forward declaration -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) + +template <> struct handle_type_name { static constexpr auto name = _("numpy.ndarray"); }; + template struct npy_format_descriptor; struct PyArrayDescr_Proxy { @@ -108,6 +115,18 @@ inline numpy_internals& get_numpy_internals() { return *ptr; } +template struct same_size { + template using as = bool_constant; +}; + +template constexpr int platform_lookup() { return -1; } + +// Lookup a type according to its size, and return a value corresponding to the NumPy typenum. +template +constexpr int platform_lookup(int I, Ints... Is) { + return sizeof(Concrete) == sizeof(T) ? I : platform_lookup(Is...); +} + struct npy_api { enum constants { NPY_ARRAY_C_CONTIGUOUS_ = 0x0001, @@ -126,7 +145,23 @@ struct npy_api { NPY_FLOAT_, NPY_DOUBLE_, NPY_LONGDOUBLE_, NPY_CFLOAT_, NPY_CDOUBLE_, NPY_CLONGDOUBLE_, NPY_OBJECT_ = 17, - NPY_STRING_, NPY_UNICODE_, NPY_VOID_ + NPY_STRING_, NPY_UNICODE_, NPY_VOID_, + // Platform-dependent normalization + NPY_INT8_ = NPY_BYTE_, + NPY_UINT8_ = NPY_UBYTE_, + NPY_INT16_ = NPY_SHORT_, + NPY_UINT16_ = NPY_USHORT_, + // `npy_common.h` defines the integer aliases. In order, it checks: + // NPY_BITSOF_LONG, NPY_BITSOF_LONGLONG, NPY_BITSOF_INT, NPY_BITSOF_SHORT, NPY_BITSOF_CHAR + // and assigns the alias to the first matching size, so we should check in this order. + NPY_INT32_ = platform_lookup( + NPY_LONG_, NPY_INT_, NPY_SHORT_), + NPY_UINT32_ = platform_lookup( + NPY_ULONG_, NPY_UINT_, NPY_USHORT_), + NPY_INT64_ = platform_lookup( + NPY_LONG_, NPY_LONGLONG_, NPY_INT_), + NPY_UINT64_ = platform_lookup( + NPY_ULONG_, NPY_ULONGLONG_, NPY_UINT_), }; typedef struct { @@ -149,8 +184,9 @@ struct npy_api { unsigned int (*PyArray_GetNDArrayCFeatureVersion_)(); PyObject *(*PyArray_DescrFromType_)(int); PyObject *(*PyArray_NewFromDescr_) - (PyTypeObject *, PyObject *, int, Py_intptr_t *, - Py_intptr_t *, void *, int, PyObject *); + (PyTypeObject *, PyObject *, int, Py_intptr_t const *, + Py_intptr_t const *, void *, int, PyObject *); + // Unused. Not removed because that affects ABI of the class. PyObject *(*PyArray_DescrNewFromType_)(int); int (*PyArray_CopyInto_)(PyObject *, PyObject *); PyObject *(*PyArray_NewCopy_)(PyObject *, int); @@ -161,9 +197,10 @@ struct npy_api { PyObject *(*PyArray_FromAny_) (PyObject *, PyObject *, int, int, int, PyObject *); int (*PyArray_DescrConverter_) (PyObject *, PyObject **); bool (*PyArray_EquivTypes_) (PyObject *, PyObject *); - int (*PyArray_GetArrayParamsFromObject_)(PyObject *, PyObject *, char, PyObject **, int *, - Py_ssize_t *, PyObject **, PyObject *); + int (*PyArray_GetArrayParamsFromObject_)(PyObject *, PyObject *, unsigned char, PyObject **, int *, + Py_intptr_t *, PyObject **, PyObject *); PyObject *(*PyArray_Squeeze_)(PyObject *); + // Unused. Not removed because that affects ABI of the class. int (*PyArray_SetBaseObject_)(PyObject *, PyObject *); PyObject* (*PyArray_Resize_)(PyObject*, PyArray_Dims*, int, int); private: @@ -179,7 +216,7 @@ struct npy_api { API_PyArray_CopyInto = 82, API_PyArray_NewCopy = 85, API_PyArray_NewFromDescr = 94, - API_PyArray_DescrNewFromType = 9, + API_PyArray_DescrNewFromType = 96, API_PyArray_DescrConverter = 174, API_PyArray_EquivTypes = 182, API_PyArray_GetArrayParamsFromObject = 278, @@ -188,7 +225,7 @@ struct npy_api { }; static npy_api lookup() { - module m = module::import("numpy.core.multiarray"); + module_ m = module_::import("numpy.core.multiarray"); auto c = m.attr("_ARRAY_API"); #if PY_MAJOR_VERSION >= 3 void **api_ptr = (void **) PyCapsule_GetPointer(c.ptr(), NULL); @@ -247,10 +284,10 @@ template struct is_complex : std::false_type { }; template struct is_complex> : std::true_type { }; template struct array_info_scalar { - typedef T type; + using type = T; static constexpr bool is_array = false; static constexpr bool is_empty = false; - static PYBIND11_DESCR extents() { return _(""); } + static constexpr auto extents = _(""); static void append_extents(list& /* shape */) { } }; // Computes underlying type and a comma-separated list of extents for array @@ -269,15 +306,9 @@ template struct array_info> { array_info::append_extents(shape); } - template::is_array, int> = 0> - static PYBIND11_DESCR extents() { - return _(); - } - - template::is_array, int> = 0> - static PYBIND11_DESCR extents() { - return concat(_(), array_info::extents()); - } + static constexpr auto extents = _::is_array>( + concat(_(), array_info::extents), _() + ); }; // For numpy we have special handling for arrays of characters, so we don't include // the size in the array extents. @@ -300,6 +331,12 @@ template using is_pod_struct = all_of< satisfies_none_of >; +// Replacement for std::is_pod (deprecated in C++20) +template using is_pod = all_of< + std::is_standard_layout, + std::is_trivial +>; + template ssize_t byte_offset_unsafe(const Strides &) { return 0; } template ssize_t byte_offset_unsafe(const Strides &strides, ssize_t i, Ix... index) { @@ -391,6 +428,10 @@ class unchecked_mutable_reference : public unchecked_reference { using ConstBase::ConstBase; using ConstBase::Dynamic; public: + // Bring in const-qualified versions from base class + using ConstBase::operator(); + using ConstBase::operator[]; + /// Mutable, unchecked access to data at the given indices. template T& operator()(Ix... index) { static_assert(ssize_t{sizeof...(Ix)} == Dims || Dynamic, @@ -416,7 +457,7 @@ struct type_caster> { template struct type_caster> : type_caster> {}; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) class dtype : public object { public: @@ -446,7 +487,7 @@ class dtype : public object { /// This is essentially the same as calling numpy.dtype(args) in Python. static dtype from_args(object args) { PyObject *ptr = nullptr; - if (!detail::npy_api::get().PyArray_DescrConverter_(args.release().ptr(), &ptr) || !ptr) + if (!detail::npy_api::get().PyArray_DescrConverter_(args.ptr(), &ptr) || !ptr) throw error_already_set(); return reinterpret_steal(ptr); } @@ -473,7 +514,7 @@ class dtype : public object { private: static object _dtype_from_pep3118() { - static PyObject *obj = module::import("numpy.core._internal") + static PyObject *obj = module_::import("numpy.core._internal") .attr("_dtype_from_pep3118").cast().release().ptr(); return reinterpret_borrow(obj); } @@ -522,7 +563,7 @@ class array : public buffer { forcecast = detail::npy_api::NPY_ARRAY_FORCECAST_ }; - array() : array({{0}}, static_cast(nullptr)) {} + array() : array(0, static_cast(nullptr)) {} using ShapeContainer = detail::any_container; using StridesContainer = detail::any_container; @@ -532,7 +573,7 @@ class array : public buffer { const void *ptr = nullptr, handle base = handle()) { if (strides->empty()) - *strides = c_strides(*shape, dt.itemsize()); + *strides = detail::c_strides(*shape, dt.itemsize()); auto ndim = shape->size(); if (ndim != strides->size()) @@ -551,7 +592,10 @@ class array : public buffer { auto &api = detail::npy_api::get(); auto tmp = reinterpret_steal(api.PyArray_NewFromDescr_( - api.PyArray_Type_, descr.release().ptr(), (int) ndim, shape->data(), strides->data(), + api.PyArray_Type_, descr.release().ptr(), (int) ndim, + // Use reinterpret_cast for PyPy on Windows (remove if fixed, checked on 7.3.1) + reinterpret_cast(shape->data()), + reinterpret_cast(strides->data()), const_cast(ptr), flags, nullptr)); if (!tmp) throw error_already_set(); @@ -583,8 +627,8 @@ class array : public buffer { template explicit array(ssize_t count, const T *ptr, handle base = handle()) : array({count}, {}, ptr, base) { } - explicit array(const buffer_info &info) - : array(pybind11::dtype(info), info.shape, info.strides, info.ptr) { } + explicit array(const buffer_info &info, handle base = handle()) + : array(pybind11::dtype(info), info.shape, info.strides, info.ptr, base) { } /// Array descriptor (dtype) pybind11::dtype dtype() const { @@ -723,10 +767,12 @@ class array : public buffer { /// then resize will succeed only if it makes a reshape, i.e. original size doesn't change void resize(ShapeContainer new_shape, bool refcheck = true) { detail::npy_api::PyArray_Dims d = { - new_shape->data(), int(new_shape->size()) + // Use reinterpret_cast for PyPy on Windows (remove if fixed, checked on 7.3.1) + reinterpret_cast(new_shape->data()), + int(new_shape->size()) }; // try to resize, set ordering param to -1 cause it's not used anyway - object new_array = reinterpret_steal( + auto new_array = reinterpret_steal( detail::npy_api::get().PyArray_Resize_(m_ptr, &d, int(refcheck), -1) ); if (!new_array) throw error_already_set(); @@ -760,25 +806,6 @@ class array : public buffer { throw std::domain_error("array is not writeable"); } - // Default, C-style strides - static std::vector c_strides(const std::vector &shape, ssize_t itemsize) { - auto ndim = shape.size(); - std::vector strides(ndim, itemsize); - if (ndim > 0) - for (size_t i = ndim - 1; i > 0; --i) - strides[i - 1] = strides[i] * shape[i]; - return strides; - } - - // F-style strides; default when constructing an array_t with `ExtraFlags & f_style` - static std::vector f_strides(const std::vector &shape, ssize_t itemsize) { - auto ndim = shape.size(); - std::vector strides(ndim, itemsize); - for (size_t i = 1; i < ndim; ++i) - strides[i] = strides[i - 1] * shape[i - 1]; - return strides; - } - template void check_dimensions(Ix... index) const { check_dimensions_impl(ssize_t(0), shape(), ssize_t(index)...); } @@ -830,17 +857,19 @@ template class array_t : public if (!m_ptr) throw error_already_set(); } - explicit array_t(const buffer_info& info) : array(info) { } + explicit array_t(const buffer_info& info, handle base = handle()) : array(info, base) { } array_t(ShapeContainer shape, StridesContainer strides, const T *ptr = nullptr, handle base = handle()) : array(std::move(shape), std::move(strides), ptr, base) { } explicit array_t(ShapeContainer shape, const T *ptr = nullptr, handle base = handle()) : array_t(private_ctor{}, std::move(shape), - ExtraFlags & f_style ? f_strides(*shape, itemsize()) : c_strides(*shape, itemsize()), + ExtraFlags & f_style + ? detail::f_strides(*shape, itemsize()) + : detail::c_strides(*shape, itemsize()), ptr, base) { } - explicit array_t(size_t count, const T *ptr = nullptr, handle base = handle()) + explicit array_t(ssize_t count, const T *ptr = nullptr, handle base = handle()) : array({count}, {}, ptr, base) { } constexpr ssize_t itemsize() const { @@ -861,14 +890,14 @@ template class array_t : public // Reference to element at a given index template const T& at(Ix... index) const { - if (sizeof...(index) != ndim()) + if ((ssize_t) sizeof...(index) != ndim()) fail_dim_check(sizeof...(index), "index dimension mismatch"); return *(static_cast(array::data()) + byte_offset(ssize_t(index)...) / itemsize()); } // Mutable reference to element at a given index template T& mutable_at(Ix... index) { - if (sizeof...(index) != ndim()) + if ((ssize_t) sizeof...(index) != ndim()) fail_dim_check(sizeof...(index), "index dimension mismatch"); return *(static_cast(array::mutable_data()) + byte_offset(ssize_t(index)...) / itemsize()); } @@ -906,7 +935,8 @@ template class array_t : public static bool check_(handle h) { const auto &api = detail::npy_api::get(); return api.PyArray_Check_(h.ptr()) - && api.PyArray_EquivTypes_(detail::array_proxy(h.ptr())->descr, dtype::of().ptr()); + && api.PyArray_EquivTypes_(detail::array_proxy(h.ptr())->descr, dtype::of().ptr()) + && detail::check_flags(h.ptr(), ExtraFlags & (array::c_style | array::f_style)); } protected: @@ -948,12 +978,12 @@ template struct format_descriptor::is_array>> { static std::string format() { using namespace detail; - PYBIND11_DESCR extents = _("(") + array_info::extents() + _(")"); - return extents.text() + format_descriptor>::format(); + static constexpr auto extents = _("(") + array_info::extents + _(")"); + return extents.text + format_descriptor>::format(); } }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) template struct pyobject_caster> { using type = array_t; @@ -968,7 +998,7 @@ struct pyobject_caster> { static handle cast(const handle &src, return_value_policy /* policy */, handle /* parent */) { return src.inc_ref(); } - PYBIND11_TYPE_CASTER(type, handle_type_name::name()); + PYBIND11_TYPE_CASTER(type, handle_type_name::name); }; template @@ -978,13 +1008,40 @@ struct compare_buffer_info::valu } }; -template struct npy_format_descriptor::value>> { +template +struct npy_format_descriptor_name; + +template +struct npy_format_descriptor_name::value>> { + static constexpr auto name = _::value>( + _("bool"), _::value>("numpy.int", "numpy.uint") + _() + ); +}; + +template +struct npy_format_descriptor_name::value>> { + static constexpr auto name = _::value || std::is_same::value>( + _("numpy.float") + _(), _("numpy.longdouble") + ); +}; + +template +struct npy_format_descriptor_name::value>> { + static constexpr auto name = _::value + || std::is_same::value>( + _("numpy.complex") + _(), _("numpy.longcomplex") + ); +}; + +template +struct npy_format_descriptor::value>> + : npy_format_descriptor_name { private: // NB: the order here must match the one in common.h constexpr static const int values[15] = { npy_api::NPY_BOOL_, - npy_api::NPY_BYTE_, npy_api::NPY_UBYTE_, npy_api::NPY_SHORT_, npy_api::NPY_USHORT_, - npy_api::NPY_INT_, npy_api::NPY_UINT_, npy_api::NPY_LONGLONG_, npy_api::NPY_ULONGLONG_, + npy_api::NPY_BYTE_, npy_api::NPY_UBYTE_, npy_api::NPY_INT16_, npy_api::NPY_UINT16_, + npy_api::NPY_INT32_, npy_api::NPY_UINT32_, npy_api::NPY_INT64_, npy_api::NPY_UINT64_, npy_api::NPY_FLOAT_, npy_api::NPY_DOUBLE_, npy_api::NPY_LONGDOUBLE_, npy_api::NPY_CFLOAT_, npy_api::NPY_CDOUBLE_, npy_api::NPY_CLONGDOUBLE_ }; @@ -994,28 +1051,13 @@ template struct npy_format_descriptor(ptr); + return reinterpret_steal(ptr); pybind11_fail("Unsupported buffer format!"); } - template ::value, int> = 0> - static PYBIND11_DESCR name() { - return _::value>(_("bool"), - _::value>("int", "uint") + _()); - } - template ::value, int> = 0> - static PYBIND11_DESCR name() { - return _::value || std::is_same::value>( - _("float") + _(), _("longdouble")); - } - template ::value, int> = 0> - static PYBIND11_DESCR name() { - return _::value || std::is_same::value>( - _("complex") + _(), _("longcomplex")); - } }; #define PYBIND11_DECL_CHAR_FMT \ - static PYBIND11_DESCR name() { return _("S") + _(); } \ + static constexpr auto name = _("S") + _(); \ static pybind11::dtype dtype() { return pybind11::dtype(std::string("S") + std::to_string(N)); } template struct npy_format_descriptor { PYBIND11_DECL_CHAR_FMT }; template struct npy_format_descriptor> { PYBIND11_DECL_CHAR_FMT }; @@ -1027,7 +1069,7 @@ template struct npy_format_descriptor:: public: static_assert(!array_info::is_empty, "Zero-sized arrays are not supported"); - static PYBIND11_DESCR name() { return _("(") + array_info::extents() + _(")") + base_descr::name(); } + static constexpr auto name = _("(") + array_info::extents + _(")") + base_descr::name; static pybind11::dtype dtype() { list shape; array_info::append_extents(shape); @@ -1039,7 +1081,7 @@ template struct npy_format_descriptor private: using base_descr = npy_format_descriptor::type>; public: - static PYBIND11_DESCR name() { return base_descr::name(); } + static constexpr auto name = base_descr::name; static pybind11::dtype dtype() { return base_descr::dtype(); } }; @@ -1052,7 +1094,7 @@ struct field_descriptor { }; inline PYBIND11_NOINLINE void register_structured_dtype( - const std::initializer_list& fields, + any_container fields, const std::type_info& tinfo, ssize_t itemsize, bool (*direct_converter)(PyObject *, void *&)) { @@ -1060,8 +1102,14 @@ inline PYBIND11_NOINLINE void register_structured_dtype( if (numpy_internals.get_type_info(tinfo, false)) pybind11_fail("NumPy: dtype is already registered"); + // Use ordered fields because order matters as of NumPy 1.14: + // https://docs.scipy.org/doc/numpy/release.html#multiple-field-indexing-assignment-of-structured-arrays + std::vector ordered_fields(std::move(fields)); + std::sort(ordered_fields.begin(), ordered_fields.end(), + [](const field_descriptor &a, const field_descriptor &b) { return a.offset < b.offset; }); + list names, formats, offsets; - for (auto field : fields) { + for (auto& field : ordered_fields) { if (!field.descr) pybind11_fail(std::string("NumPy: unsupported field dtype: `") + field.name + "` @ " + tinfo.name()); @@ -1078,9 +1126,6 @@ inline PYBIND11_NOINLINE void register_structured_dtype( // - https://github.com/numpy/numpy/pull/7798 // Because of this, we won't use numpy's logic to generate buffer format // strings and will just do it ourselves. - std::vector ordered_fields(fields); - std::sort(ordered_fields.begin(), ordered_fields.end(), - [](const field_descriptor &a, const field_descriptor &b) { return a.offset < b.offset; }); ssize_t offset = 0; std::ostringstream oss; // mark the structure as unaligned with '^', because numpy and C++ don't @@ -1114,7 +1159,7 @@ inline PYBIND11_NOINLINE void register_structured_dtype( template struct npy_format_descriptor { static_assert(is_pod_struct::value, "Attempt to use a non-POD or unimplemented POD type as a numpy dtype"); - static PYBIND11_DESCR name() { return make_caster::name(); } + static constexpr auto name = make_caster::name; static pybind11::dtype dtype() { return reinterpret_borrow(dtype_ptr()); @@ -1125,8 +1170,8 @@ template struct npy_format_descriptor { return format_str; } - static void register_dtype(const std::initializer_list& fields) { - register_structured_dtype(fields, typeid(typename std::remove_cv::type), + static void register_dtype(any_container fields) { + register_structured_dtype(std::move(fields), typeid(typename std::remove_cv::type), sizeof(T), &direct_converter); } @@ -1180,7 +1225,7 @@ template struct npy_format_descriptor { #define PYBIND11_MAP_NEXT0(test, next, ...) next PYBIND11_MAP_OUT #define PYBIND11_MAP_NEXT1(test, next) PYBIND11_MAP_NEXT0 (test, next, 0) #define PYBIND11_MAP_NEXT(test, next) PYBIND11_MAP_NEXT1 (PYBIND11_MAP_GET_END test, next) -#ifdef _MSC_VER // MSVC is not as eager to expand macros, hence this workaround +#if defined(_MSC_VER) && !defined(__clang__) // MSVC is not as eager to expand macros, hence this workaround #define PYBIND11_MAP_LIST_NEXT1(test, next) \ PYBIND11_EVAL0 (PYBIND11_MAP_NEXT0 (test, PYBIND11_MAP_COMMA next, 0)) #else @@ -1199,9 +1244,10 @@ template struct npy_format_descriptor { #define PYBIND11_NUMPY_DTYPE(Type, ...) \ ::pybind11::detail::npy_format_descriptor::register_dtype \ - ({PYBIND11_MAP_LIST (PYBIND11_FIELD_DESCRIPTOR, Type, __VA_ARGS__)}) + (::std::vector<::pybind11::detail::field_descriptor> \ + {PYBIND11_MAP_LIST (PYBIND11_FIELD_DESCRIPTOR, Type, __VA_ARGS__)}) -#ifdef _MSC_VER +#if defined(_MSC_VER) && !defined(__clang__) #define PYBIND11_MAP2_LIST_NEXT1(test, next) \ PYBIND11_EVAL0 (PYBIND11_MAP_NEXT0 (test, PYBIND11_MAP_COMMA next, 0)) #else @@ -1220,23 +1266,11 @@ template struct npy_format_descriptor { #define PYBIND11_NUMPY_DTYPE_EX(Type, ...) \ ::pybind11::detail::npy_format_descriptor::register_dtype \ - ({PYBIND11_MAP2_LIST (PYBIND11_FIELD_DESCRIPTOR_EX, Type, __VA_ARGS__)}) + (::std::vector<::pybind11::detail::field_descriptor> \ + {PYBIND11_MAP2_LIST (PYBIND11_FIELD_DESCRIPTOR_EX, Type, __VA_ARGS__)}) #endif // __CLION_IDE__ -template -using array_iterator = typename std::add_pointer::type; - -template -array_iterator array_begin(const buffer_info& buffer) { - return array_iterator(reinterpret_cast(buffer.ptr)); -} - -template -array_iterator array_end(const buffer_info& buffer) { - return array_iterator(reinterpret_cast(buffer.ptr) + buffer.size); -} - class common_iterator { public: using container_type = std::vector; @@ -1250,7 +1284,7 @@ class common_iterator { m_strides.back() = static_cast(strides.back()); for (size_type i = m_strides.size() - 1; i != 0; --i) { size_type j = i - 1; - value_type s = static_cast(shape[i]); + auto s = static_cast(shape[i]); m_strides[j] = strides[j] + m_strides[i] - strides[i] * s; } } @@ -1428,7 +1462,7 @@ struct vectorize_arg { using call_type = remove_reference_t; // Is this a vectorized argument? static constexpr bool vectorize = - satisfies_any_of::value && + satisfies_any_of::value && satisfies_none_of::value && (!std::is_reference::value || (std::is_lvalue_reference::value && std::is_const::value)); @@ -1436,9 +1470,66 @@ struct vectorize_arg { using type = conditional_t, array::forcecast>, T>; }; + +// py::vectorize when a return type is present +template +struct vectorize_returned_array { + using Type = array_t; + + static Type create(broadcast_trivial trivial, const std::vector &shape) { + if (trivial == broadcast_trivial::f_trivial) + return array_t(shape); + else + return array_t(shape); + } + + static Return *mutable_data(Type &array) { + return array.mutable_data(); + } + + static Return call(Func &f, Args &... args) { + return f(args...); + } + + static void call(Return *out, size_t i, Func &f, Args &... args) { + out[i] = f(args...); + } +}; + +// py::vectorize when a return type is not present +template +struct vectorize_returned_array { + using Type = none; + + static Type create(broadcast_trivial, const std::vector &) { + return none(); + } + + static void *mutable_data(Type &) { + return nullptr; + } + + static detail::void_type call(Func &f, Args &... args) { + f(args...); + return {}; + } + + static void call(void *, size_t, Func &f, Args &... args) { + f(args...); + } +}; + + template struct vectorize_helper { + +// NVCC for some reason breaks if NVectorized is private +#ifdef __CUDACC__ +public: +#else private: +#endif + static constexpr size_t N = sizeof...(Args); static constexpr size_t NVectorized = constexpr_sum(vectorize_arg::vectorize...); static_assert(NVectorized >= 1, @@ -1458,7 +1549,12 @@ struct vectorize_helper { private: remove_reference_t f; - template using param_n_t = typename pack_element::call_type...>::type; + // Internal compiler error in MSVC 19.16.27025.1 (Visual Studio 2017 15.9.4), when compiling with "/permissive-" flag + // when arg_call_types is manually inlined. + using arg_call_types = std::tuple::call_type...>; + template using param_n_t = typename std::tuple_element::type; + + using returned_array = vectorize_returned_array; // Runs a vectorized function given arguments tuple and three index sequences: // - Index is the full set of 0 ... (N-1) argument indices; @@ -1483,7 +1579,7 @@ struct vectorize_helper { ssize_t nd = 0; std::vector shape(0); auto trivial = broadcast(buffers, nd, shape); - size_t ndim = (size_t) nd; + auto ndim = (size_t) nd; size_t size = std::accumulate(shape.begin(), shape.end(), (size_t) 1, std::multiplies()); @@ -1491,22 +1587,21 @@ struct vectorize_helper { // not wrapped in an array). if (size == 1 && ndim == 0) { PYBIND11_EXPAND_SIDE_EFFECTS(params[VIndex] = buffers[BIndex].ptr); - return cast(f(*reinterpret_cast *>(params[Index])...)); + return cast(returned_array::call(f, *reinterpret_cast *>(params[Index])...)); } - array_t result; - if (trivial == broadcast_trivial::f_trivial) result = array_t(shape); - else result = array_t(shape); + auto result = returned_array::create(trivial, shape); - if (size == 0) return result; + if (size == 0) return std::move(result); /* Call the function */ + auto mutable_data = returned_array::mutable_data(result); if (trivial == broadcast_trivial::non_trivial) - apply_broadcast(buffers, params, result, i_seq, vi_seq, bi_seq); + apply_broadcast(buffers, params, mutable_data, size, shape, i_seq, vi_seq, bi_seq); else - apply_trivial(buffers, params, result.mutable_data(), size, i_seq, vi_seq, bi_seq); + apply_trivial(buffers, params, mutable_data, size, i_seq, vi_seq, bi_seq); - return result; + return std::move(result); } template @@ -1527,7 +1622,7 @@ struct vectorize_helper { }}; for (size_t i = 0; i < size; ++i) { - out[i] = f(*reinterpret_cast *>(params[Index])...); + returned_array::call(out, i, f, *reinterpret_cast *>(params[Index])...); for (auto &x : vecparams) x.first += x.second; } } @@ -1535,19 +1630,18 @@ struct vectorize_helper { template void apply_broadcast(std::array &buffers, std::array ¶ms, - array_t &output_array, + Return *out, + size_t size, + const std::vector &output_shape, index_sequence, index_sequence, index_sequence) { - buffer_info output = output_array.request(); - multi_array_iterator input_iter(buffers, output.shape); + multi_array_iterator input_iter(buffers, output_shape); - for (array_iterator iter = array_begin(output), end = array_end(output); - iter != end; - ++iter, ++input_iter) { + for (size_t i = 0; i < size; ++i, ++input_iter) { PYBIND11_EXPAND_SIDE_EFFECTS(( params[VIndex] = input_iter.template data() )); - *iter = f(*reinterpret_cast *>(std::get(params))...); + returned_array::call(out, i, f, *reinterpret_cast *>(std::get(params))...); } } }; @@ -1559,12 +1653,10 @@ vectorize_extractor(const Func &f, Return (*) (Args ...)) { } template struct handle_type_name> { - static PYBIND11_DESCR name() { - return _("numpy.ndarray[") + npy_format_descriptor::name() + _("]"); - } + static constexpr auto name = _("numpy.ndarray[") + npy_format_descriptor::name + _("]"); }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) // Vanilla pointer vectorizer: template @@ -1594,7 +1686,7 @@ Helper vectorize(Return (Class::*f)(Args...) const) { return Helper(std::mem_fn(f)); } -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) #if defined(_MSC_VER) #pragma warning(pop) diff --git a/plugins/python/pybind11/include/pybind11/operators.h b/plugins/python/pybind11/include/pybind11/operators.h index b3dd62c..086cb4c 100644 --- a/plugins/python/pybind11/include/pybind11/operators.h +++ b/plugins/python/pybind11/include/pybind11/operators.h @@ -18,8 +18,8 @@ # pragma warning(disable: 4127) // warning C4127: Conditional expression is constant #endif -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) /// Enumeration with all supported operator types enum op_id : int { @@ -147,6 +147,9 @@ PYBIND11_INPLACE_OPERATOR(ixor, operator^=, l ^= r) PYBIND11_INPLACE_OPERATOR(ior, operator|=, l |= r) PYBIND11_UNARY_OPERATOR(neg, operator-, -l) PYBIND11_UNARY_OPERATOR(pos, operator+, +l) +// WARNING: This usage of `abs` should only be done for existing STL overloads. +// Adding overloads directly in to the `std::` namespace is advised against: +// https://en.cppreference.com/w/cpp/language/extending_std PYBIND11_UNARY_OPERATOR(abs, abs, std::abs(l)) PYBIND11_UNARY_OPERATOR(hash, hash, std::hash()(l)) PYBIND11_UNARY_OPERATOR(invert, operator~, (~l)) @@ -157,11 +160,13 @@ PYBIND11_UNARY_OPERATOR(float, float_, (double) l) #undef PYBIND11_BINARY_OPERATOR #undef PYBIND11_INPLACE_OPERATOR #undef PYBIND11_UNARY_OPERATOR -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) using detail::self; +// Add named operators so that they are accessible via `py::`. +using detail::hash; -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) #if defined(_MSC_VER) # pragma warning(pop) diff --git a/plugins/python/pybind11/include/pybind11/options.h b/plugins/python/pybind11/include/pybind11/options.h index cc1e1f6..d74db1c 100644 --- a/plugins/python/pybind11/include/pybind11/options.h +++ b/plugins/python/pybind11/include/pybind11/options.h @@ -11,7 +11,7 @@ #include "detail/common.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) class options { public: @@ -62,4 +62,4 @@ class options { state previous_state; }; -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/pybind11.h b/plugins/python/pybind11/include/pybind11/pybind11.h index 9094fc4..e2ddda0 100644 --- a/plugins/python/pybind11/include/pybind11/pybind11.h +++ b/plugins/python/pybind11/include/pybind11/pybind11.h @@ -10,7 +10,17 @@ #pragma once -#if defined(_MSC_VER) +#if defined(__INTEL_COMPILER) +# pragma warning push +# pragma warning disable 68 // integer conversion resulted in a change of sign +# pragma warning disable 186 // pointless comparison of unsigned integer with zero +# pragma warning disable 878 // incompatible exception specifications +# pragma warning disable 1334 // the "template" keyword used for syntactic disambiguation may only be used within a template +# pragma warning disable 1682 // implicit conversion of a 64-bit integral type to a smaller integral type (potential portability problem) +# pragma warning disable 1786 // function "strdup" was declared deprecated +# pragma warning disable 1875 // offsetof applied to non-POD (Plain Old Data) types is nonstandard +# pragma warning disable 2196 // warning #2196: routine is both "inline" and "noinline" +#elif defined(_MSC_VER) # pragma warning(push) # pragma warning(disable: 4100) // warning C4100: Unreferenced formal parameter # pragma warning(disable: 4127) // warning C4127: Conditional expression is constant @@ -19,15 +29,7 @@ # pragma warning(disable: 4996) // warning C4996: The POSIX name for this item is deprecated. Instead, use the ISO C and C++ conformant name # pragma warning(disable: 4702) // warning C4702: unreachable code # pragma warning(disable: 4522) // warning C4522: multiple assignment operators specified -#elif defined(__INTEL_COMPILER) -# pragma warning(push) -# pragma warning(disable: 68) // integer conversion resulted in a change of sign -# pragma warning(disable: 186) // pointless comparison of unsigned integer with zero -# pragma warning(disable: 878) // incompatible exception specifications -# pragma warning(disable: 1334) // the "template" keyword used for syntactic disambiguation may only be used within a template -# pragma warning(disable: 1682) // implicit conversion of a 64-bit integral type to a smaller integral type (potential portability problem) -# pragma warning(disable: 1875) // offsetof applied to non-POD (Plain Old Data) types is nonstandard -# pragma warning(disable: 2196) // warning #2196: routine is both "inline" and "noinline" +# pragma warning(disable: 4505) // warning C4505: 'PySlice_GetIndicesEx': unreferenced local function has been removed (PyPy only) #elif defined(__GNUG__) && !defined(__clang__) # pragma GCC diagnostic push # pragma GCC diagnostic ignored "-Wunused-but-set-parameter" @@ -45,12 +47,22 @@ #include "detail/class.h" #include "detail/init.h" -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +#include +#include +#include +#include + +#if defined(__GNUG__) && !defined(__clang__) +# include +#endif + +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) /// Wraps an arbitrary C++ function/method/lambda function/.. into a callable Python object class cpp_function : public function { public: - cpp_function() { } + cpp_function() = default; + cpp_function(std::nullptr_t) { } /// Construct a cpp_function from a vanilla function pointer template @@ -66,16 +78,34 @@ class cpp_function : public function { (detail::function_signature_t *) nullptr, extra...); } - /// Construct a cpp_function from a class method (non-const) + /// Construct a cpp_function from a class method (non-const, no ref-qualifier) template cpp_function(Return (Class::*f)(Arg...), const Extra&... extra) { + initialize([f](Class *c, Arg... args) -> Return { return (c->*f)(std::forward(args)...); }, + (Return (*) (Class *, Arg...)) nullptr, extra...); + } + + /// Construct a cpp_function from a class method (non-const, lvalue ref-qualifier) + /// A copy of the overload for non-const functions without explicit ref-qualifier + /// but with an added `&`. + template + cpp_function(Return (Class::*f)(Arg...)&, const Extra&... extra) { initialize([f](Class *c, Arg... args) -> Return { return (c->*f)(args...); }, (Return (*) (Class *, Arg...)) nullptr, extra...); } - /// Construct a cpp_function from a class method (const) + /// Construct a cpp_function from a class method (const, no ref-qualifier) template cpp_function(Return (Class::*f)(Arg...) const, const Extra&... extra) { + initialize([f](const Class *c, Arg... args) -> Return { return (c->*f)(std::forward(args)...); }, + (Return (*)(const Class *, Arg ...)) nullptr, extra...); + } + + /// Construct a cpp_function from a class method (const, lvalue ref-qualifier) + /// A copy of the overload for const functions without explicit ref-qualifier + /// but with an added `&`. + template + cpp_function(Return (Class::*f)(Arg...) const&, const Extra&... extra) { initialize([f](const Class *c, Arg... args) -> Return { return (c->*f)(args...); }, (Return (*)(const Class *, Arg ...)) nullptr, extra...); } @@ -93,7 +123,6 @@ class cpp_function : public function { template void initialize(Func &&f, Return (*)(Args...), const Extra&... extra) { using namespace detail; - struct capture { remove_reference_t f; }; /* Store the function including any extra state it might have (e.g. a lambda capture object) */ @@ -142,7 +171,7 @@ class cpp_function : public function { /* Get a pointer to the capture object */ auto data = (sizeof(capture) <= sizeof(call.func.data) ? &call.func.data : call.func.data[0]); - capture *cap = const_cast(reinterpret_cast(data)); + auto *cap = const_cast(reinterpret_cast(data)); /* Override policy for rvalues -- usually to enforce rvp::move on an rvalue */ return_value_policy policy = return_value_policy_override::policy(call.func.policy); @@ -163,11 +192,22 @@ class cpp_function : public function { /* Process any user-provided function attributes */ process_attributes::init(extra..., rec); + { + constexpr bool has_kw_only_args = any_of...>::value, + has_pos_only_args = any_of...>::value, + has_args = any_of...>::value, + has_arg_annotations = any_of...>::value; + static_assert(has_arg_annotations || !has_kw_only_args, "py::kw_only requires the use of argument annotations"); + static_assert(has_arg_annotations || !has_pos_only_args, "py::pos_only requires the use of argument annotations (for docstrings and aligning the annotations to the argument)"); + static_assert(!(has_args && has_kw_only_args), "py::kw_only cannot be combined with a py::args argument"); + } + /* Generate a readable signature describing the function's arguments and return value types */ - PYBIND11_DESCR signature = _("(") + cast_in::arg_names() + _(") -> ") + cast_out::name(); + static constexpr auto signature = _("(") + cast_in::arg_names + _(") -> ") + cast_out::name; + PYBIND11_DESCR_CONSTEXPR auto types = decltype(signature)::types(); /* Register the function with Python from generic (non-templated) code */ - initialize_generic(rec, signature.text(), signature.types(), sizeof...(Args)); + initialize_generic(rec, signature.text, types.data(), sizeof...(Args)); if (cast_in::has_args) rec->has_args = true; if (cast_in::has_kwargs) rec->has_kwargs = true; @@ -196,14 +236,14 @@ class cpp_function : public function { if (a.descr) a.descr = strdup(a.descr); else if (a.value) - a.descr = strdup(a.value.attr("__repr__")().cast().c_str()); + a.descr = strdup(repr(a.value).cast().c_str()); } rec->is_constructor = !strcmp(rec->name, "__init__") || !strcmp(rec->name, "__setstate__"); #if !defined(NDEBUG) && !defined(PYBIND11_DISABLE_NEW_STYLE_INIT_WARNING) if (rec->is_constructor && !rec->is_new_style_constructor) { - const auto class_name = std::string(((PyTypeObject *) rec->scope.ptr())->tp_name); + const auto class_name = detail::get_fully_qualified_tp_name((PyTypeObject *) rec->scope.ptr()); const auto func_name = std::string(rec->name); PyErr_WarnEx( PyExc_FutureWarning, @@ -217,34 +257,37 @@ class cpp_function : public function { /* Generate a proper function signature */ std::string signature; - size_t type_depth = 0, char_index = 0, type_index = 0, arg_index = 0; - while (true) { - char c = text[char_index++]; - if (c == '\0') - break; + size_t type_index = 0, arg_index = 0; + for (auto *pc = text; *pc != '\0'; ++pc) { + const auto c = *pc; if (c == '{') { - // Write arg name for everything except *args, **kwargs and return type. - if (type_depth == 0 && text[char_index] != '*' && arg_index < args) { - if (!rec->args.empty() && rec->args[arg_index].name) { - signature += rec->args[arg_index].name; - } else if (arg_index == 0 && rec->is_method) { - signature += "self"; - } else { - signature += "arg" + std::to_string(arg_index - (rec->is_method ? 1 : 0)); - } - signature += ": "; + // Write arg name for everything except *args and **kwargs. + if (*(pc + 1) == '*') + continue; + // Separator for keyword-only arguments, placed before the kw + // arguments start + if (rec->nargs_kw_only > 0 && arg_index + rec->nargs_kw_only == args) + signature += "*, "; + if (arg_index < rec->args.size() && rec->args[arg_index].name) { + signature += rec->args[arg_index].name; + } else if (arg_index == 0 && rec->is_method) { + signature += "self"; + } else { + signature += "arg" + std::to_string(arg_index - (rec->is_method ? 1 : 0)); } - ++type_depth; + signature += ": "; } else if (c == '}') { - --type_depth; - if (type_depth == 0) { - if (arg_index < rec->args.size() && rec->args[arg_index].descr) { - signature += "="; - signature += rec->args[arg_index].descr; - } - arg_index++; + // Write default value if available. + if (arg_index < rec->args.size() && rec->args[arg_index].descr) { + signature += " = "; + signature += rec->args[arg_index].descr; } + // Separator for positional-only arguments (placed after the + // argument, rather than before like * + if (rec->nargs_pos_only > 0 && (arg_index + 1) == rec->nargs_pos_only) + signature += ", /"; + arg_index++; } else if (c == '%') { const std::type_info *t = types[type_index++]; if (!t) @@ -269,13 +312,9 @@ class cpp_function : public function { signature += c; } } - if (type_depth != 0 || types[type_index] != nullptr) - pybind11_fail("Internal error while parsing type signature (2)"); - #if !defined(PYBIND11_CONSTEXPR_DESCR) - delete[] types; - delete[] text; - #endif + if (arg_index != args || types[type_index] != nullptr) + pybind11_fail("Internal error while parsing type signature (2)"); #if PY_MAJOR_VERSION < 3 if (strcmp(rec->name, "__next__") == 0) { @@ -334,10 +373,9 @@ class cpp_function : public function { if (!m_ptr) pybind11_fail("cpp_function::cpp_function(): Could not allocate function object"); } else { - /* Append at the end of the overload chain */ + /* Append at the beginning or end of the overload chain */ m_ptr = rec->sibling.ptr(); inc_ref(); - chain_start = chain; if (chain->is_method != rec->is_method) pybind11_fail("overloading a method with both static and instance methods is not supported; " #if defined(NDEBUG) @@ -347,9 +385,22 @@ class cpp_function : public function { std::string(pybind11::str(rec->scope.attr("__name__"))) + "." + std::string(rec->name) + signature #endif ); - while (chain->next) - chain = chain->next; - chain->next = rec; + + if (rec->prepend) { + // Beginning of chain; we need to replace the capsule's current head-of-the-chain + // pointer with this one, then make this one point to the previous head of the + // chain. + chain_start = rec; + rec->next = chain; + auto rec_capsule = reinterpret_borrow(((PyCFunctionObject *) m_ptr)->m_self); + rec_capsule.set_pointer(rec); + } else { + // Or end of chain (normal behavior) + chain_start = chain; + while (chain->next) + chain = chain->next; + chain->next = rec; + } } std::string signatures; @@ -387,7 +438,7 @@ class cpp_function : public function { } /* Install docstring */ - PyCFunctionObject *func = (PyCFunctionObject *) m_ptr; + auto *func = (PyCFunctionObject *) m_ptr; if (func->m_ml->ml_doc) std::free(const_cast(func->m_ml->ml_doc)); func->m_ml->ml_doc = strdup(signatures.c_str()); @@ -402,6 +453,12 @@ class cpp_function : public function { /// When a cpp_function is GCed, release any memory allocated by pybind11 static void destruct(detail::function_record *rec) { + // If on Python 3.9, check the interpreter "MICRO" (patch) version. + // If this is running on 3.9.0, we have to work around a bug. + #if !defined(PYPY_VERSION) && PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION == 9 + static bool is_zero = Py_GetVersion()[4] == '0'; + #endif + while (rec) { detail::function_record *next = rec->next; if (rec->free_data) @@ -416,7 +473,15 @@ class cpp_function : public function { } if (rec->def) { std::free(const_cast(rec->def->ml_doc)); - delete rec->def; + // Python 3.9.0 decref's these in the wrong order; rec->def + // If loaded on 3.9.0, let these leak (use Python 3.9.1 at runtime to fix) + // See https://github.com/python/cpython/pull/22670 + #if !defined(PYPY_VERSION) && PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION == 9 + if (!is_zero) + delete rec->def; + #else + delete rec->def; + #endif } delete rec; rec = next; @@ -428,11 +493,11 @@ class cpp_function : public function { using namespace detail; /* Iterator over the list of potentially admissible overloads */ - function_record *overloads = (function_record *) PyCapsule_GetPointer(self, nullptr), - *it = overloads; + const function_record *overloads = (function_record *) PyCapsule_GetPointer(self, nullptr), + *it = overloads; /* Need to know how many arguments + keyword arguments there are to pick the right overload */ - const size_t n_args_in = (size_t) PyTuple_GET_SIZE(args_in); + const auto n_args_in = (size_t) PyTuple_GET_SIZE(args_in); handle parent = n_args_in > 0 ? PyTuple_GET_ITEM(args_in, 0) : nullptr, result = PYBIND11_TRY_NEXT_OVERLOAD; @@ -485,20 +550,21 @@ class cpp_function : public function { result other than PYBIND11_TRY_NEXT_OVERLOAD. */ - function_record &func = *it; - size_t pos_args = func.nargs; // Number of positional arguments that we need - if (func.has_args) --pos_args; // (but don't count py::args - if (func.has_kwargs) --pos_args; // or py::kwargs) + const function_record &func = *it; + size_t num_args = func.nargs; // Number of positional arguments that we need + if (func.has_args) --num_args; // (but don't count py::args + if (func.has_kwargs) --num_args; // or py::kwargs) + size_t pos_args = num_args - func.nargs_kw_only; if (!func.has_args && n_args_in > pos_args) - continue; // Too many arguments for this overload + continue; // Too many positional arguments for this overload if (n_args_in < pos_args && func.args.size() < pos_args) - continue; // Not enough arguments given, and not enough defaults to fill in the blanks + continue; // Not enough positional arguments given, and not enough defaults to fill in the blanks function_call call(func, parent); - size_t args_to_copy = std::min(pos_args, n_args_in); + size_t args_to_copy = (std::min)(pos_args, n_args_in); // Protect std::min with parentheses size_t args_copied = 0; // 0. Inject new-style `self` argument @@ -509,7 +575,7 @@ class cpp_function : public function { self_value_and_holder.type->dealloc(self_value_and_holder); call.init_self = PyTuple_GET_ITEM(args_in, 0); - call.args.push_back(reinterpret_cast(&self_value_and_holder)); + call.args.emplace_back(reinterpret_cast(&self_value_and_holder)); call.args_convert.push_back(false); ++args_copied; } @@ -517,7 +583,7 @@ class cpp_function : public function { // 1. Copy any position arguments given. bool bad_arg = false; for (; args_copied < args_to_copy; ++args_copied) { - argument_record *arg_rec = args_copied < func.args.size() ? &func.args[args_copied] : nullptr; + const argument_record *arg_rec = args_copied < func.args.size() ? &func.args[args_copied] : nullptr; if (kwargs_in && arg_rec && arg_rec->name && PyDict_GetItemString(kwargs_in, arg_rec->name)) { bad_arg = true; break; @@ -537,16 +603,36 @@ class cpp_function : public function { // We'll need to copy this if we steal some kwargs for defaults dict kwargs = reinterpret_borrow(kwargs_in); + // 1.5. Fill in any missing pos_only args from defaults if they exist + if (args_copied < func.nargs_pos_only) { + for (; args_copied < func.nargs_pos_only; ++args_copied) { + const auto &arg_rec = func.args[args_copied]; + handle value; + + if (arg_rec.value) { + value = arg_rec.value; + } + if (value) { + call.args.push_back(value); + call.args_convert.push_back(arg_rec.convert); + } else + break; + } + + if (args_copied < func.nargs_pos_only) + continue; // Not enough defaults to fill the positional arguments + } + // 2. Check kwargs and, failing that, defaults that may help complete the list - if (args_copied < pos_args) { + if (args_copied < num_args) { bool copied_kwargs = false; - for (; args_copied < pos_args; ++args_copied) { - const auto &arg = func.args[args_copied]; + for (; args_copied < num_args; ++args_copied) { + const auto &arg_rec = func.args[args_copied]; handle value; - if (kwargs_in && arg.name) - value = PyDict_GetItemString(kwargs.ptr(), arg.name); + if (kwargs_in && arg_rec.name) + value = PyDict_GetItemString(kwargs.ptr(), arg_rec.name); if (value) { // Consume a kwargs value @@ -554,25 +640,29 @@ class cpp_function : public function { kwargs = reinterpret_steal(PyDict_Copy(kwargs.ptr())); copied_kwargs = true; } - PyDict_DelItemString(kwargs.ptr(), arg.name); - } else if (arg.value) { - value = arg.value; + PyDict_DelItemString(kwargs.ptr(), arg_rec.name); + } else if (arg_rec.value) { + value = arg_rec.value; + } + + if (!arg_rec.none && value.is_none()) { + break; } if (value) { call.args.push_back(value); - call.args_convert.push_back(arg.convert); + call.args_convert.push_back(arg_rec.convert); } else break; } - if (args_copied < pos_args) + if (args_copied < num_args) continue; // Not enough arguments, defaults, or kwargs to fill the positional arguments } // 3. Check everything was consumed (unless we have a kwargs arg) - if (kwargs && kwargs.size() > 0 && !func.has_kwargs) + if (kwargs && !kwargs.empty() && !func.has_kwargs) continue; // Unconsumed kwargs, but no py::kwargs argument to accept them // 4a. If we have a py::args argument, create a new tuple with leftovers @@ -658,13 +748,22 @@ class cpp_function : public function { result = PYBIND11_TRY_NEXT_OVERLOAD; } - if (result.ptr() != PYBIND11_TRY_NEXT_OVERLOAD) + if (result.ptr() != PYBIND11_TRY_NEXT_OVERLOAD) { + // The error reporting logic below expects 'it' to be valid, as it would be + // if we'd encountered this failure in the first-pass loop. + if (!result) + it = &call.func; break; + } } } } catch (error_already_set &e) { e.restore(); return nullptr; +#ifdef __GLIBCXX__ + } catch ( abi::__forced_unwind& ) { + throw; +#endif } catch (...) { /* When an exception is caught, give each registered exception translator a chance to translate it to a Python exception @@ -711,7 +810,7 @@ class cpp_function : public function { " arguments. The following argument types are supported:\n"; int ctr = 0; - for (function_record *it2 = overloads; it2 != nullptr; it2 = it2->next) { + for (const function_record *it2 = overloads; it2 != nullptr; it2 = it2->next) { msg += " "+ std::to_string(++ctr) + ". "; bool wrote_sig = false; @@ -743,18 +842,27 @@ class cpp_function : public function { for (size_t ti = overloads->is_constructor ? 1 : 0; ti < args_.size(); ++ti) { if (!some_args) some_args = true; else msg += ", "; - msg += pybind11::repr(args_[ti]); + try { + msg += pybind11::repr(args_[ti]); + } catch (const error_already_set&) { + msg += ""; + } } if (kwargs_in) { auto kwargs = reinterpret_borrow(kwargs_in); - if (kwargs.size() > 0) { + if (!kwargs.empty()) { if (some_args) msg += "; "; msg += "kwargs: "; bool first = true; for (auto kwarg : kwargs) { if (first) first = false; else msg += ", "; - msg += pybind11::str("{}={!r}").format(kwarg.first, kwarg.second); + msg += pybind11::str("{}=").format(kwarg.first); + try { + msg += pybind11::repr(kwarg.second); + } catch (const error_already_set&) { + msg += ""; + } } } } @@ -780,27 +888,18 @@ class cpp_function : public function { }; /// Wrapper for Python extension modules -class module : public object { +class module_ : public object { public: - PYBIND11_OBJECT_DEFAULT(module, object, PyModule_Check) + PYBIND11_OBJECT_DEFAULT(module_, object, PyModule_Check) /// Create a new top-level Python module with the given name and docstring - explicit module(const char *name, const char *doc = nullptr) { - if (!options::show_user_defined_docstrings()) doc = nullptr; + PYBIND11_DEPRECATED("Use PYBIND11_MODULE or module_::create_extension_module instead") + explicit module_(const char *name, const char *doc = nullptr) { #if PY_MAJOR_VERSION >= 3 - PyModuleDef *def = new PyModuleDef(); - std::memset(def, 0, sizeof(PyModuleDef)); - def->m_name = name; - def->m_doc = doc; - def->m_size = -1; - Py_INCREF(def); - m_ptr = PyModule_Create(def); + *this = create_extension_module(name, doc, new PyModuleDef()); #else - m_ptr = Py_InitModule3(name, nullptr, doc); + *this = create_extension_module(name, doc, nullptr); #endif - if (m_ptr == nullptr) - pybind11_fail("Internal error in module::module()"); - inc_ref(); } /** \rst @@ -809,7 +908,7 @@ class module : public object { details on the ``Extra&& ... extra`` argument, see section :ref:`extras`. \endrst */ template - module &def(const char *name_, Func &&f, const Extra& ... extra) { + module_ &def(const char *name_, Func &&f, const Extra& ... extra) { cpp_function func(std::forward(f), name(name_), scope(*this), sibling(getattr(*this, name_, none())), extra...); // NB: allow overwriting here because cpp_function sets up a chain with the intention of @@ -824,14 +923,14 @@ class module : public object { .. code-block:: cpp - py::module m("example", "pybind11 example plugin"); - py::module m2 = m.def_submodule("sub", "A submodule of 'example'"); - py::module m3 = m2.def_submodule("subsub", "A submodule of 'example.sub'"); + py::module_ m("example", "pybind11 example plugin"); + py::module_ m2 = m.def_submodule("sub", "A submodule of 'example'"); + py::module_ m3 = m2.def_submodule("subsub", "A submodule of 'example.sub'"); \endrst */ - module def_submodule(const char *name, const char *doc = nullptr) { + module_ def_submodule(const char *name, const char *doc = nullptr) { std::string full_name = std::string(PyModule_GetName(m_ptr)) + std::string(".") + std::string(name); - auto result = reinterpret_borrow(PyImport_AddModule(full_name.c_str())); + auto result = reinterpret_borrow(PyImport_AddModule(full_name.c_str())); if (doc && options::show_user_defined_docstrings()) result.attr("__doc__") = pybind11::str(doc); attr(name) = result; @@ -839,11 +938,11 @@ class module : public object { } /// Import and return a module or throws `error_already_set`. - static module import(const char *name) { + static module_ import(const char *name) { PyObject *obj = PyImport_ImportModule(name); if (!obj) throw error_already_set(); - return reinterpret_steal(obj); + return reinterpret_steal(obj); } /// Reload the module or throws `error_already_set`. @@ -851,14 +950,16 @@ class module : public object { PyObject *obj = PyImport_ReloadModule(ptr()); if (!obj) throw error_already_set(); - *this = reinterpret_steal(obj); + *this = reinterpret_steal(obj); } - // Adds an object to the module using the given name. Throws if an object with the given name - // already exists. - // - // overwrite should almost always be false: attempting to overwrite objects that pybind11 has - // established will, in most cases, break things. + /** \rst + Adds an object to the module using the given name. Throws if an object with the given name + already exists. + + ``overwrite`` should almost always be false: attempting to overwrite objects that pybind11 has + established will, in most cases, break things. + \endrst */ PYBIND11_NOINLINE void add_object(const char *name, handle obj, bool overwrite = false) { if (!overwrite && hasattr(*this, name)) pybind11_fail("Error during initialization: multiple incompatible definitions with name \"" + @@ -866,25 +967,71 @@ class module : public object { PyModule_AddObject(ptr(), name, obj.inc_ref().ptr() /* steals a reference */); } + +#if PY_MAJOR_VERSION >= 3 + using module_def = PyModuleDef; +#else + struct module_def {}; +#endif + + /** \rst + Create a new top-level module that can be used as the main module of a C extension. + + For Python 3, ``def`` should point to a staticly allocated module_def. + For Python 2, ``def`` can be a nullptr and is completely ignored. + \endrst */ + static module_ create_extension_module(const char *name, const char *doc, module_def *def) { +#if PY_MAJOR_VERSION >= 3 + // module_def is PyModuleDef + def = new (def) PyModuleDef { // Placement new (not an allocation). + /* m_base */ PyModuleDef_HEAD_INIT, + /* m_name */ name, + /* m_doc */ options::show_user_defined_docstrings() ? doc : nullptr, + /* m_size */ -1, + /* m_methods */ nullptr, + /* m_slots */ nullptr, + /* m_traverse */ nullptr, + /* m_clear */ nullptr, + /* m_free */ nullptr + }; + auto m = PyModule_Create(def); +#else + // Ignore module_def *def; only necessary for Python 3 + (void) def; + auto m = Py_InitModule3(name, nullptr, options::show_user_defined_docstrings() ? doc : nullptr); +#endif + if (m == nullptr) { + if (PyErr_Occurred()) + throw error_already_set(); + pybind11_fail("Internal error in module_::create_extension_module()"); + } + // TODO: Sould be reinterpret_steal for Python 3, but Python also steals it again when returned from PyInit_... + // For Python 2, reinterpret_borrow is correct. + return reinterpret_borrow(m); + } }; +// When inside a namespace (or anywhere as long as it's not the first item on a line), +// C++20 allows "module" to be used. This is provided for backward compatibility, and for +// simplicity, if someone wants to use py::module for example, that is perfectly safe. +using module = module_; + /// \ingroup python_builtins /// Return a dictionary representing the global variables in the current execution frame, /// or ``__main__.__dict__`` if there is no frame (usually when the interpreter is embedded). inline dict globals() { PyObject *p = PyEval_GetGlobals(); - return reinterpret_borrow(p ? p : module::import("__main__").attr("__dict__").ptr()); + return reinterpret_borrow(p ? p : module_::import("__main__").attr("__dict__").ptr()); } -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) /// Generic support for creating new Python heap types class generic_type : public object { - template friend class class_; public: PYBIND11_OBJECT_DEFAULT(generic_type, object, PyType_Check) protected: void initialize(const type_record &rec) { - if (rec.scope && hasattr(rec.scope, rec.name)) + if (rec.scope && hasattr(rec.scope, "__dict__") && rec.scope.attr("__dict__").contains(rec.name)) pybind11_fail("generic_type: cannot initialize type \"" + std::string(rec.name) + "\": an object with that name is already defined"); @@ -899,6 +1046,7 @@ class generic_type : public object { tinfo->type = (PyTypeObject *) m_ptr; tinfo->cpptype = rec.type; tinfo->type_size = rec.type_size; + tinfo->type_align = rec.type_align; tinfo->operator_new = rec.operator_new; tinfo->holder_size_in_ptrs = size_in_ptrs(rec.holder_size); tinfo->init_instance = rec.init_instance; @@ -947,13 +1095,13 @@ class generic_type : public object { void install_buffer_funcs( buffer_info *(*get_buffer)(PyObject *, void *), void *get_buffer_data) { - PyHeapTypeObject *type = (PyHeapTypeObject*) m_ptr; + auto *type = (PyHeapTypeObject*) m_ptr; auto tinfo = detail::get_type_info(&type->ht_type); if (!type->ht_type.tp_as_buffer) pybind11_fail( "To be able to register buffer protocol support for the type '" + - std::string(tinfo->type->tp_name) + + get_fully_qualified_tp_name(tinfo->type) + "' the associated class<>(..) invocation must " "include the pybind11::buffer_protocol() annotation!"); @@ -961,18 +1109,18 @@ class generic_type : public object { tinfo->get_buffer_data = get_buffer_data; } + // rec_func must be set for either fget or fset. void def_property_static_impl(const char *name, handle fget, handle fset, - detail::function_record *rec_fget) { - const auto is_static = !(rec_fget->is_method && rec_fget->scope); - const auto has_doc = rec_fget->doc && pybind11::options::show_user_defined_docstrings(); - + detail::function_record *rec_func) { + const auto is_static = rec_func && !(rec_func->is_method && rec_func->scope); + const auto has_doc = rec_func && rec_func->doc && pybind11::options::show_user_defined_docstrings(); auto property = handle((PyObject *) (is_static ? get_internals().static_property_type : &PyProperty_Type)); attr(name) = property(fget.ptr() ? fget : none(), fset.ptr() ? fset : none(), /*deleter*/none(), - pybind11::str(has_doc ? rec_fget->doc : "")); + pybind11::str(has_doc ? rec_func->doc : "")); } }; @@ -990,13 +1138,37 @@ template struct has_operator_delete_size::value, int> = 0> -void call_operator_delete(T *p, size_t) { T::operator delete(p); } +void call_operator_delete(T *p, size_t, size_t) { T::operator delete(p); } template ::value && has_operator_delete_size::value, int> = 0> -void call_operator_delete(T *p, size_t s) { T::operator delete(p, s); } +void call_operator_delete(T *p, size_t s, size_t) { T::operator delete(p, s); } + +inline void call_operator_delete(void *p, size_t s, size_t a) { + (void)s; (void)a; + #if defined(__cpp_aligned_new) && (!defined(_MSC_VER) || _MSC_VER >= 1912) + if (a > __STDCPP_DEFAULT_NEW_ALIGNMENT__) { + #ifdef __cpp_sized_deallocation + ::operator delete(p, s, std::align_val_t(a)); + #else + ::operator delete(p, std::align_val_t(a)); + #endif + return; + } + #endif + #ifdef __cpp_sized_deallocation + ::operator delete(p, s); + #else + ::operator delete(p); + #endif +} -inline void call_operator_delete(void *p, size_t) { ::operator delete(p); } +inline void add_class_method(object& cls, const char *name_, const cpp_function &cf) { + cls.attr(cf.name()) = cf; + if (strcmp(name_, "__eq__") == 0 && !cls.attr("__dict__").contains("__hash__")) { + cls.attr("__hash__") = none(); + } +} -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /// Given a pointer to a member function, cast it to its `Derived` version. /// Forward everything else unchanged. @@ -1004,10 +1176,18 @@ template auto method_adaptor(F &&f) -> decltype(std::forward(f)) { return std::forward(f); } template -auto method_adaptor(Return (Class::*pmf)(Args...)) -> Return (Derived::*)(Args...) { return pmf; } +auto method_adaptor(Return (Class::*pmf)(Args...)) -> Return (Derived::*)(Args...) { + static_assert(detail::is_accessible_base_of::value, + "Cannot bind an inaccessible base class method; use a lambda definition instead"); + return pmf; +} template -auto method_adaptor(Return (Class::*pmf)(Args...) const) -> Return (Derived::*)(Args...) const { return pmf; } +auto method_adaptor(Return (Class::*pmf)(Args...) const) -> Return (Derived::*)(Args...) const { + static_assert(detail::is_accessible_base_of::value, + "Cannot bind an inaccessible base class method; use a lambda definition instead"); + return pmf; +} template class class_ : public detail::generic_type { @@ -1049,10 +1229,11 @@ class class_ : public detail::generic_type { record.name = name; record.type = &typeid(type); record.type_size = sizeof(conditional_t); + record.type_align = alignof(conditional_t&); record.holder_size = sizeof(holder_type); record.init_instance = init_instance; record.dealloc = dealloc; - record.default_holder = std::is_same>::value; + record.default_holder = detail::is_instantiation::value; set_operator_new(&record); @@ -1084,7 +1265,7 @@ class class_ : public detail::generic_type { class_ &def(const char *name_, Func&& f, const Extra&... extra) { cpp_function cf(method_adaptor(std::forward(f)), name(name_), is_method(*this), sibling(getattr(*this, name_, none())), extra...); - attr(cf.name()) = cf; + add_class_method(*this, name_, cf); return *this; } @@ -1094,7 +1275,7 @@ class class_ : public detail::generic_type { "def_static(...) called with a non-static member function pointer"); cpp_function cf(std::forward(f), name(name_), scope(*this), sibling(getattr(*this, name_, none())), extra...); - attr(cf.name()) = cf; + attr(cf.name()) = staticmethod(cf); return *this; } @@ -1134,15 +1315,20 @@ class class_ : public detail::generic_type { return *this; } - template class_& def_buffer(Func &&func) { + template + class_& def_buffer(Func &&func) { struct capture { Func func; }; - capture *ptr = new capture { std::forward(func) }; + auto *ptr = new capture { std::forward(func) }; install_buffer_funcs([](PyObject *obj, void *ptr) -> buffer_info* { detail::make_caster caster; if (!caster.load(obj, false)) return nullptr; return new buffer_info(((capture *) ptr)->func(caster)); }, ptr); + weakref(m_ptr, cpp_function([ptr](handle wr) { + delete ptr; + wr.dec_ref(); + })).release(); return *this; } @@ -1158,7 +1344,7 @@ class class_ : public detail::generic_type { template class_ &def_readwrite(const char *name, D C::*pm, const Extra&... extra) { - static_assert(std::is_base_of::value, "def_readwrite() requires a class member (or base class member)"); + static_assert(std::is_same::value || std::is_base_of::value, "def_readwrite() requires a class member (or base class member)"); cpp_function fget([pm](const type &c) -> const D &{ return c.*pm; }, is_method(*this)), fset([pm](type &c, const D &value) { c.*pm = value; }, is_method(*this)); def_property(name, fget, fset, return_value_policy::reference_internal, extra...); @@ -1167,7 +1353,7 @@ class class_ : public detail::generic_type { template class_ &def_readonly(const char *name, const D C::*pm, const Extra& ...extra) { - static_assert(std::is_base_of::value, "def_readonly() requires a class member (or base class member)"); + static_assert(std::is_same::value || std::is_base_of::value, "def_readonly() requires a class member (or base class member)"); cpp_function fget([pm](const type &c) -> const D &{ return c.*pm; }, is_method(*this)); def_property_readonly(name, fget, return_value_policy::reference_internal, extra...); return *this; @@ -1198,7 +1384,7 @@ class class_ : public detail::generic_type { /// Uses cpp_function's return_value_policy by default template class_ &def_property_readonly(const char *name, const cpp_function &fget, const Extra& ...extra) { - return def_property(name, fget, cpp_function(), extra...); + return def_property(name, fget, nullptr, extra...); } /// Uses return_value_policy::reference by default @@ -1210,7 +1396,7 @@ class class_ : public detail::generic_type { /// Uses cpp_function's return_value_policy by default template class_ &def_property_readonly_static(const char *name, const cpp_function &fget, const Extra& ...extra) { - return def_property_static(name, fget, cpp_function(), extra...); + return def_property_static(name, fget, nullptr, extra...); } /// Uses return_value_policy::reference_internal by default @@ -1239,22 +1425,28 @@ class class_ : public detail::generic_type { /// Uses cpp_function's return_value_policy by default template class_ &def_property_static(const char *name, const cpp_function &fget, const cpp_function &fset, const Extra& ...extra) { + static_assert( 0 == detail::constexpr_sum(std::is_base_of::value...), + "Argument annotations are not allowed for properties"); auto rec_fget = get_function_record(fget), rec_fset = get_function_record(fset); - char *doc_prev = rec_fget->doc; /* 'extra' field may include a property-specific documentation string */ - detail::process_attributes::init(extra..., rec_fget); - if (rec_fget->doc && rec_fget->doc != doc_prev) { - free(doc_prev); - rec_fget->doc = strdup(rec_fget->doc); + auto *rec_active = rec_fget; + if (rec_fget) { + char *doc_prev = rec_fget->doc; /* 'extra' field may include a property-specific documentation string */ + detail::process_attributes::init(extra..., rec_fget); + if (rec_fget->doc && rec_fget->doc != doc_prev) { + free(doc_prev); + rec_fget->doc = strdup(rec_fget->doc); + } } if (rec_fset) { - doc_prev = rec_fset->doc; + char *doc_prev = rec_fset->doc; detail::process_attributes::init(extra..., rec_fset); if (rec_fset->doc && rec_fset->doc != doc_prev) { free(doc_prev); rec_fset->doc = strdup(rec_fset->doc); } + if (! rec_active) rec_active = rec_fset; } - def_property_static_impl(name, fget, fset, rec_fget); + def_property_static_impl(name, fget, fset, rec_active); return *this; } @@ -1315,12 +1507,22 @@ class class_ : public detail::generic_type { /// Deallocates an instance; via holder, if constructed; otherwise via operator delete. static void dealloc(detail::value_and_holder &v_h) { + // We could be deallocating because we are cleaning up after a Python exception. + // If so, the Python error indicator will be set. We need to clear that before + // running the destructor, in case the destructor code calls more Python. + // If we don't, the Python API will exit with an exception, and pybind11 will + // throw error_already_set from the C++ destructor which is forbidden and triggers + // std::terminate(). + error_scope scope; if (v_h.holder_constructed()) { v_h.holder().~holder_type(); v_h.set_holder_constructed(false); } else { - detail::call_operator_delete(v_h.value_ptr(), v_h.type->type_size); + detail::call_operator_delete(v_h.value_ptr(), + v_h.type->type_size, + v_h.type->type_align + ); } v_h.value_ptr() = nullptr; } @@ -1356,96 +1558,212 @@ detail::initimpl::pickle_factory pickle(GetState &&g, SetSta return {std::forward(g), std::forward(s)}; } +PYBIND11_NAMESPACE_BEGIN(detail) + +inline str enum_name(handle arg) { + dict entries = arg.get_type().attr("__entries"); + for (auto kv : entries) { + if (handle(kv.second[int_(0)]).equal(arg)) + return pybind11::str(kv.first); + } + return "???"; +} + +struct enum_base { + enum_base(handle base, handle parent) : m_base(base), m_parent(parent) { } + + PYBIND11_NOINLINE void init(bool is_arithmetic, bool is_convertible) { + m_base.attr("__entries") = dict(); + auto property = handle((PyObject *) &PyProperty_Type); + auto static_property = handle((PyObject *) get_internals().static_property_type); + + m_base.attr("__repr__") = cpp_function( + [](object arg) -> str { + handle type = type::handle_of(arg); + object type_name = type.attr("__name__"); + return pybind11::str("<{}.{}: {}>").format(type_name, enum_name(arg), int_(arg)); + }, name("__repr__"), is_method(m_base) + ); + + m_base.attr("name") = property(cpp_function(&enum_name, name("name"), is_method(m_base))); + + m_base.attr("__str__") = cpp_function( + [](handle arg) -> str { + object type_name = type::handle_of(arg).attr("__name__"); + return pybind11::str("{}.{}").format(type_name, enum_name(arg)); + }, name("name"), is_method(m_base) + ); + + m_base.attr("__doc__") = static_property(cpp_function( + [](handle arg) -> std::string { + std::string docstring; + dict entries = arg.attr("__entries"); + if (((PyTypeObject *) arg.ptr())->tp_doc) + docstring += std::string(((PyTypeObject *) arg.ptr())->tp_doc) + "\n\n"; + docstring += "Members:"; + for (auto kv : entries) { + auto key = std::string(pybind11::str(kv.first)); + auto comment = kv.second[int_(1)]; + docstring += "\n\n " + key; + if (!comment.is_none()) + docstring += " : " + (std::string) pybind11::str(comment); + } + return docstring; + }, name("__doc__") + ), none(), none(), ""); + + m_base.attr("__members__") = static_property(cpp_function( + [](handle arg) -> dict { + dict entries = arg.attr("__entries"), m; + for (auto kv : entries) + m[kv.first] = kv.second[int_(0)]; + return m; + }, name("__members__")), none(), none(), "" + ); + + #define PYBIND11_ENUM_OP_STRICT(op, expr, strict_behavior) \ + m_base.attr(op) = cpp_function( \ + [](object a, object b) { \ + if (!type::handle_of(a).is(type::handle_of(b))) \ + strict_behavior; \ + return expr; \ + }, \ + name(op), is_method(m_base), arg("other")) + + #define PYBIND11_ENUM_OP_CONV(op, expr) \ + m_base.attr(op) = cpp_function( \ + [](object a_, object b_) { \ + int_ a(a_), b(b_); \ + return expr; \ + }, \ + name(op), is_method(m_base), arg("other")) + + #define PYBIND11_ENUM_OP_CONV_LHS(op, expr) \ + m_base.attr(op) = cpp_function( \ + [](object a_, object b) { \ + int_ a(a_); \ + return expr; \ + }, \ + name(op), is_method(m_base), arg("other")) + + if (is_convertible) { + PYBIND11_ENUM_OP_CONV_LHS("__eq__", !b.is_none() && a.equal(b)); + PYBIND11_ENUM_OP_CONV_LHS("__ne__", b.is_none() || !a.equal(b)); + + if (is_arithmetic) { + PYBIND11_ENUM_OP_CONV("__lt__", a < b); + PYBIND11_ENUM_OP_CONV("__gt__", a > b); + PYBIND11_ENUM_OP_CONV("__le__", a <= b); + PYBIND11_ENUM_OP_CONV("__ge__", a >= b); + PYBIND11_ENUM_OP_CONV("__and__", a & b); + PYBIND11_ENUM_OP_CONV("__rand__", a & b); + PYBIND11_ENUM_OP_CONV("__or__", a | b); + PYBIND11_ENUM_OP_CONV("__ror__", a | b); + PYBIND11_ENUM_OP_CONV("__xor__", a ^ b); + PYBIND11_ENUM_OP_CONV("__rxor__", a ^ b); + m_base.attr("__invert__") = cpp_function( + [](object arg) { return ~(int_(arg)); }, name("__invert__"), is_method(m_base)); + } + } else { + PYBIND11_ENUM_OP_STRICT("__eq__", int_(a).equal(int_(b)), return false); + PYBIND11_ENUM_OP_STRICT("__ne__", !int_(a).equal(int_(b)), return true); + + if (is_arithmetic) { + #define PYBIND11_THROW throw type_error("Expected an enumeration of matching type!"); + PYBIND11_ENUM_OP_STRICT("__lt__", int_(a) < int_(b), PYBIND11_THROW); + PYBIND11_ENUM_OP_STRICT("__gt__", int_(a) > int_(b), PYBIND11_THROW); + PYBIND11_ENUM_OP_STRICT("__le__", int_(a) <= int_(b), PYBIND11_THROW); + PYBIND11_ENUM_OP_STRICT("__ge__", int_(a) >= int_(b), PYBIND11_THROW); + #undef PYBIND11_THROW + } + } + + #undef PYBIND11_ENUM_OP_CONV_LHS + #undef PYBIND11_ENUM_OP_CONV + #undef PYBIND11_ENUM_OP_STRICT + + m_base.attr("__getstate__") = cpp_function( + [](object arg) { return int_(arg); }, name("__getstate__"), is_method(m_base)); + + m_base.attr("__hash__") = cpp_function( + [](object arg) { return int_(arg); }, name("__hash__"), is_method(m_base)); + } + + PYBIND11_NOINLINE void value(char const* name_, object value, const char *doc = nullptr) { + dict entries = m_base.attr("__entries"); + str name(name_); + if (entries.contains(name)) { + std::string type_name = (std::string) str(m_base.attr("__name__")); + throw value_error(type_name + ": element \"" + std::string(name_) + "\" already exists!"); + } + + entries[name] = std::make_pair(value, doc); + m_base.attr(name) = value; + } + + PYBIND11_NOINLINE void export_values() { + dict entries = m_base.attr("__entries"); + for (auto kv : entries) + m_parent.attr(kv.first) = kv.second[int_(0)]; + } + + handle m_base; + handle m_parent; +}; + +PYBIND11_NAMESPACE_END(detail) + /// Binds C++ enumerations and enumeration classes to Python template class enum_ : public class_ { public: - using class_::def; - using class_::def_property_readonly_static; + using Base = class_; + using Base::def; + using Base::attr; + using Base::def_property_readonly; + using Base::def_property_readonly_static; using Scalar = typename std::underlying_type::type; template enum_(const handle &scope, const char *name, const Extra&... extra) - : class_(scope, name, extra...), m_entries(), m_parent(scope) { - + : class_(scope, name, extra...), m_base(*this, scope) { constexpr bool is_arithmetic = detail::any_of...>::value; + constexpr bool is_convertible = std::is_convertible::value; + m_base.init(is_arithmetic, is_convertible); - auto m_entries_ptr = m_entries.inc_ref().ptr(); - def("__repr__", [name, m_entries_ptr](Type value) -> pybind11::str { - for (const auto &kv : reinterpret_borrow(m_entries_ptr)) { - if (pybind11::cast(kv.second) == value) - return pybind11::str("{}.{}").format(name, kv.first); - } - return pybind11::str("{}.???").format(name); - }); - def_property_readonly_static("__members__", [m_entries_ptr](object /* self */) { - dict m; - for (const auto &kv : reinterpret_borrow(m_entries_ptr)) - m[kv.first] = kv.second; - return m; - }, return_value_policy::copy); - def(init([](Scalar i) { return static_cast(i); })); + def(init([](Scalar i) { return static_cast(i); }), arg("value")); def("__int__", [](Type value) { return (Scalar) value; }); #if PY_MAJOR_VERSION < 3 def("__long__", [](Type value) { return (Scalar) value; }); #endif - def("__eq__", [](const Type &value, Type *value2) { return value2 && value == *value2; }); - def("__ne__", [](const Type &value, Type *value2) { return !value2 || value != *value2; }); - if (is_arithmetic) { - def("__lt__", [](const Type &value, Type *value2) { return value2 && value < *value2; }); - def("__gt__", [](const Type &value, Type *value2) { return value2 && value > *value2; }); - def("__le__", [](const Type &value, Type *value2) { return value2 && value <= *value2; }); - def("__ge__", [](const Type &value, Type *value2) { return value2 && value >= *value2; }); - } - if (std::is_convertible::value) { - // Don't provide comparison with the underlying type if the enum isn't convertible, - // i.e. if Type is a scoped enum, mirroring the C++ behaviour. (NB: we explicitly - // convert Type to Scalar below anyway because this needs to compile). - def("__eq__", [](const Type &value, Scalar value2) { return (Scalar) value == value2; }); - def("__ne__", [](const Type &value, Scalar value2) { return (Scalar) value != value2; }); - if (is_arithmetic) { - def("__lt__", [](const Type &value, Scalar value2) { return (Scalar) value < value2; }); - def("__gt__", [](const Type &value, Scalar value2) { return (Scalar) value > value2; }); - def("__le__", [](const Type &value, Scalar value2) { return (Scalar) value <= value2; }); - def("__ge__", [](const Type &value, Scalar value2) { return (Scalar) value >= value2; }); - def("__invert__", [](const Type &value) { return ~((Scalar) value); }); - def("__and__", [](const Type &value, Scalar value2) { return (Scalar) value & value2; }); - def("__or__", [](const Type &value, Scalar value2) { return (Scalar) value | value2; }); - def("__xor__", [](const Type &value, Scalar value2) { return (Scalar) value ^ value2; }); - def("__rand__", [](const Type &value, Scalar value2) { return (Scalar) value & value2; }); - def("__ror__", [](const Type &value, Scalar value2) { return (Scalar) value | value2; }); - def("__rxor__", [](const Type &value, Scalar value2) { return (Scalar) value ^ value2; }); - def("__and__", [](const Type &value, const Type &value2) { return (Scalar) value & (Scalar) value2; }); - def("__or__", [](const Type &value, const Type &value2) { return (Scalar) value | (Scalar) value2; }); - def("__xor__", [](const Type &value, const Type &value2) { return (Scalar) value ^ (Scalar) value2; }); - } - } - def("__hash__", [](const Type &value) { return (Scalar) value; }); - // Pickling and unpickling -- needed for use with the 'multiprocessing' module - def(pickle([](const Type &value) { return pybind11::make_tuple((Scalar) value); }, - [](tuple t) { return static_cast(t[0].cast()); })); + #if PY_MAJOR_VERSION > 3 || (PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION >= 8) + def("__index__", [](Type value) { return (Scalar) value; }); + #endif + + attr("__setstate__") = cpp_function( + [](detail::value_and_holder &v_h, Scalar arg) { + detail::initimpl::setstate(v_h, static_cast(arg), + Py_TYPE(v_h.inst) != v_h.type->type); }, + detail::is_new_style_constructor(), + pybind11::name("__setstate__"), is_method(*this), arg("state")); } /// Export enumeration entries into the parent scope enum_& export_values() { - for (const auto &kv : m_entries) - m_parent.attr(kv.first) = kv.second; + m_base.export_values(); return *this; } /// Add an enumeration entry - enum_& value(char const* name, Type value) { - auto v = pybind11::cast(value, return_value_policy::copy); - this->attr(name) = v; - m_entries[pybind11::str(name)] = v; + enum_& value(char const* name, Type value, const char *doc = nullptr) { + m_base.value(name, pybind11::cast(value, return_value_policy::copy), doc); return *this; } private: - dict m_entries; - handle m_parent; + detail::enum_base m_base; }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) inline void keep_alive_impl(handle nurse, handle patient) { @@ -1515,7 +1833,7 @@ struct iterator_state { bool first_or_done; }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /// Makes a python iterator from a first and past-the-end C++ InputIterator. template ()), typename... Extra> iterator make_iterator(Iterator first, Sentinel last, Extra &&... extra) { - typedef detail::iterator_state state; + using state = detail::iterator_state; if (!detail::get_type_info(typeid(state), false)) { class_(handle(), "iterator", pybind11::module_local()) @@ -1553,7 +1871,7 @@ template ()).first), typename... Extra> iterator make_key_iterator(Iterator first, Sentinel last, Extra &&... extra) { - typedef detail::iterator_state state; + using state = detail::iterator_state; if (!detail::get_type_info(typeid(state), false)) { class_(handle(), "iterator", pybind11::module_local()) @@ -1632,11 +1950,11 @@ template class exception : public object { public: exception() = default; - exception(handle scope, const char *name, PyObject *base = PyExc_Exception) { + exception(handle scope, const char *name, handle base = PyExc_Exception) { std::string full_name = scope.attr("__name__").cast() + std::string(".") + name; - m_ptr = PyErr_NewException(const_cast(full_name.c_str()), base, NULL); - if (hasattr(scope, name)) + m_ptr = PyErr_NewException(const_cast(full_name.c_str()), base.ptr(), NULL); + if (hasattr(scope, "__dict__") && scope.attr("__dict__").contains(name)) pybind11_fail("Error during initialization: multiple incompatible " "definitions with name \"" + std::string(name) + "\""); scope.attr(name) = *this; @@ -1648,13 +1966,13 @@ class exception : public object { } }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) // Returns a reference to a function-local static exception object used in the simple // register_exception approach below. (It would be simpler to have the static local variable // directly in register_exception, but that makes clang <3.5 segfault - issue #1349). template exception &get_exception_object() { static exception ex; return ex; } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /** * Registers a Python exception in `m` of the given `name` and installs an exception translator to @@ -1665,7 +1983,7 @@ NAMESPACE_END(detail) template exception ®ister_exception(handle scope, const char *name, - PyObject *base = PyExc_Exception) { + handle base = PyExc_Exception) { auto &ex = detail::get_exception_object(); if (!ex) ex = exception(scope, name, base); @@ -1680,7 +1998,7 @@ exception ®ister_exception(handle scope, return ex; } -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) PYBIND11_NOINLINE inline void print(tuple args, dict kwargs) { auto strings = tuple(args.size()); for (size_t i = 0; i < args.size(); ++i) { @@ -1694,7 +2012,7 @@ PYBIND11_NOINLINE inline void print(tuple args, dict kwargs) { file = kwargs["file"].cast(); } else { try { - file = module::import("sys").attr("stdout"); + file = module_::import("sys").attr("stdout"); } catch (const error_already_set &) { /* If print() is called from code that is executed as part of garbage collection during interpreter shutdown, @@ -1711,7 +2029,7 @@ PYBIND11_NOINLINE inline void print(tuple args, dict kwargs) { if (kwargs.contains("flush") && kwargs["flush"].cast()) file.attr("flush")(); } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) template void print(Args &&...args) { @@ -1749,6 +2067,15 @@ class gil_scoped_acquire { auto const &internals = detail::get_internals(); tstate = (PyThreadState *) PYBIND11_TLS_GET_VALUE(internals.tstate); + if (!tstate) { + /* Check if the GIL was acquired using the PyGILState_* API instead (e.g. if + calling from a Python thread). Since we use a different key, this ensures + we don't create a new thread state and deadlock in PyEval_AcquireThread + below. Note we don't save this state with internals.tstate, since we don't + create it we would fail to clear it (its reference count should be > 0). */ + tstate = PyGILState_GetThisThreadState(); + } + if (!tstate) { tstate = PyThreadState_New(internals.istate); #if !defined(NDEBUG) @@ -1856,30 +2183,31 @@ class gil_scoped_release { }; #endif error_already_set::~error_already_set() { - if (type) { - error_scope scope; + if (m_type) { gil_scoped_acquire gil; - type.release().dec_ref(); - value.release().dec_ref(); - trace.release().dec_ref(); + error_scope scope; + m_type.release().dec_ref(); + m_value.release().dec_ref(); + m_trace.release().dec_ref(); } } -inline function get_type_overload(const void *this_ptr, const detail::type_info *this_type, const char *name) { - handle self = detail::get_object_handle(this_ptr, this_type); +PYBIND11_NAMESPACE_BEGIN(detail) +inline function get_type_override(const void *this_ptr, const type_info *this_type, const char *name) { + handle self = get_object_handle(this_ptr, this_type); if (!self) return function(); - handle type = self.get_type(); + handle type = type::handle_of(self); auto key = std::make_pair(type.ptr(), name); - /* Cache functions that aren't overloaded in Python to avoid + /* Cache functions that aren't overridden in Python to avoid many costly Python dictionary lookups below */ - auto &cache = detail::get_internals().inactive_overload_cache; + auto &cache = get_internals().inactive_override_cache; if (cache.find(key) != cache.end()) return function(); - function overload = getattr(self, name, function()); - if (overload.is_cpp_function()) { + function override = getattr(self, name, function()); + if (override.is_cpp_function()) { cache.insert(key); return function(); } @@ -1919,47 +2247,132 @@ inline function get_type_overload(const void *this_ptr, const detail::type_info Py_DECREF(result); #endif - return overload; + return override; } +PYBIND11_NAMESPACE_END(detail) -template function get_overload(const T *this_ptr, const char *name) { +/** \rst + Try to retrieve a python method by the provided name from the instance pointed to by the this_ptr. + + :this_ptr: The pointer to the object the overriden method should be retrieved for. This should be + the first non-trampoline class encountered in the inheritance chain. + :name: The name of the overridden Python method to retrieve. + :return: The Python method by this name from the object or an empty function wrapper. + \endrst */ +template function get_override(const T *this_ptr, const char *name) { auto tinfo = detail::get_type_info(typeid(T)); - return tinfo ? get_type_overload(this_ptr, tinfo, name) : function(); + return tinfo ? detail::get_type_override(this_ptr, tinfo, name) : function(); } -#define PYBIND11_OVERLOAD_INT(ret_type, cname, name, ...) { \ +#define PYBIND11_OVERRIDE_IMPL(ret_type, cname, name, ...) \ + do { \ pybind11::gil_scoped_acquire gil; \ - pybind11::function overload = pybind11::get_overload(static_cast(this), name); \ - if (overload) { \ - auto o = overload(__VA_ARGS__); \ + pybind11::function override = pybind11::get_override(static_cast(this), name); \ + if (override) { \ + auto o = override(__VA_ARGS__); \ if (pybind11::detail::cast_is_temporary_value_reference::value) { \ - static pybind11::detail::overload_caster_t caster; \ + static pybind11::detail::override_caster_t caster; \ return pybind11::detail::cast_ref(std::move(o), caster); \ } \ else return pybind11::detail::cast_safe(std::move(o)); \ } \ - } + } while (false) + +/** \rst + Macro to populate the virtual method in the trampoline class. This macro tries to look up a method named 'fn' + from the Python side, deals with the :ref:`gil` and necessary argument conversions to call this method and return + the appropriate type. See :ref:`overriding_virtuals` for more information. This macro should be used when the method + name in C is not the same as the method name in Python. For example with `__str__`. + + .. code-block:: cpp + + std::string toString() override { + PYBIND11_OVERRIDE_NAME( + std::string, // Return type (ret_type) + Animal, // Parent class (cname) + "__str__", // Name of method in Python (name) + toString, // Name of function in C++ (fn) + ); + } +\endrst */ +#define PYBIND11_OVERRIDE_NAME(ret_type, cname, name, fn, ...) \ + do { \ + PYBIND11_OVERRIDE_IMPL(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), name, __VA_ARGS__); \ + return cname::fn(__VA_ARGS__); \ + } while (false) + +/** \rst + Macro for pure virtual functions, this function is identical to :c:macro:`PYBIND11_OVERRIDE_NAME`, except that it + throws if no override can be found. +\endrst */ +#define PYBIND11_OVERRIDE_PURE_NAME(ret_type, cname, name, fn, ...) \ + do { \ + PYBIND11_OVERRIDE_IMPL(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), name, __VA_ARGS__); \ + pybind11::pybind11_fail("Tried to call pure virtual function \"" PYBIND11_STRINGIFY(cname) "::" name "\""); \ + } while (false) + +/** \rst + Macro to populate the virtual method in the trampoline class. This macro tries to look up the method + from the Python side, deals with the :ref:`gil` and necessary argument conversions to call this method and return + the appropriate type. This macro should be used if the method name in C and in Python are identical. + See :ref:`overriding_virtuals` for more information. + + .. code-block:: cpp + + class PyAnimal : public Animal { + public: + // Inherit the constructors + using Animal::Animal; + + // Trampoline (need one for each virtual function) + std::string go(int n_times) override { + PYBIND11_OVERRIDE_PURE( + std::string, // Return type (ret_type) + Animal, // Parent class (cname) + go, // Name of function in C++ (must match Python name) (fn) + n_times // Argument(s) (...) + ); + } + }; +\endrst */ +#define PYBIND11_OVERRIDE(ret_type, cname, fn, ...) \ + PYBIND11_OVERRIDE_NAME(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), #fn, fn, __VA_ARGS__) + +/** \rst + Macro for pure virtual functions, this function is identical to :c:macro:`PYBIND11_OVERRIDE`, except that it throws + if no override can be found. +\endrst */ +#define PYBIND11_OVERRIDE_PURE(ret_type, cname, fn, ...) \ + PYBIND11_OVERRIDE_PURE_NAME(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), #fn, fn, __VA_ARGS__) + + +// Deprecated versions + +PYBIND11_DEPRECATED("get_type_overload has been deprecated") +inline function get_type_overload(const void *this_ptr, const detail::type_info *this_type, const char *name) { + return detail::get_type_override(this_ptr, this_type, name); +} -#define PYBIND11_OVERLOAD_NAME(ret_type, cname, name, fn, ...) \ - PYBIND11_OVERLOAD_INT(ret_type, cname, name, __VA_ARGS__) \ - return cname::fn(__VA_ARGS__) +template +inline function get_overload(const T *this_ptr, const char *name) { + return get_override(this_ptr, name); +} +#define PYBIND11_OVERLOAD_INT(ret_type, cname, name, ...) \ + PYBIND11_OVERRIDE_IMPL(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), name, __VA_ARGS__) +#define PYBIND11_OVERLOAD_NAME(ret_type, cname, name, fn, ...) \ + PYBIND11_OVERRIDE_NAME(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), name, fn, __VA_ARGS__) #define PYBIND11_OVERLOAD_PURE_NAME(ret_type, cname, name, fn, ...) \ - PYBIND11_OVERLOAD_INT(ret_type, cname, name, __VA_ARGS__) \ - pybind11::pybind11_fail("Tried to call pure virtual function \"" #cname "::" name "\""); - + PYBIND11_OVERRIDE_PURE_NAME(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), name, fn, __VA_ARGS__); #define PYBIND11_OVERLOAD(ret_type, cname, fn, ...) \ - PYBIND11_OVERLOAD_NAME(ret_type, cname, #fn, fn, __VA_ARGS__) - + PYBIND11_OVERRIDE(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), fn, __VA_ARGS__) #define PYBIND11_OVERLOAD_PURE(ret_type, cname, fn, ...) \ - PYBIND11_OVERLOAD_PURE_NAME(ret_type, cname, #fn, fn, __VA_ARGS__) + PYBIND11_OVERRIDE_PURE(PYBIND11_TYPE(ret_type), PYBIND11_TYPE(cname), fn, __VA_ARGS__); -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) -#if defined(_MSC_VER) +#if defined(_MSC_VER) && !defined(__INTEL_COMPILER) # pragma warning(pop) -#elif defined(__INTEL_COMPILER) -/* Leave ignored warnings on */ #elif defined(__GNUG__) && !defined(__clang__) # pragma GCC diagnostic pop #endif diff --git a/plugins/python/pybind11/include/pybind11/pytypes.h b/plugins/python/pybind11/include/pybind11/pytypes.h index d7fa177..1010ad7 100644 --- a/plugins/python/pybind11/include/pybind11/pytypes.h +++ b/plugins/python/pybind11/include/pybind11/pytypes.h @@ -14,14 +14,15 @@ #include #include -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) /* A few forward declarations */ class handle; class object; class str; class iterator; +class type; struct arg; struct arg_v; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) class args_proxy; inline bool isinstance_generic(handle obj, const std::type_info &tp); @@ -34,7 +35,7 @@ namespace accessor_policies { struct sequence_item; struct list_item; struct tuple_item; -} +} // namespace accessor_policies using obj_attr_accessor = accessor; using str_attr_accessor = accessor; using item_accessor = accessor; @@ -114,6 +115,35 @@ class object_api : public pyobject_tag { bool is(object_api const& other) const { return derived().ptr() == other.derived().ptr(); } /// Equivalent to ``obj is None`` in Python. bool is_none() const { return derived().ptr() == Py_None; } + /// Equivalent to obj == other in Python + bool equal(object_api const &other) const { return rich_compare(other, Py_EQ); } + bool not_equal(object_api const &other) const { return rich_compare(other, Py_NE); } + bool operator<(object_api const &other) const { return rich_compare(other, Py_LT); } + bool operator<=(object_api const &other) const { return rich_compare(other, Py_LE); } + bool operator>(object_api const &other) const { return rich_compare(other, Py_GT); } + bool operator>=(object_api const &other) const { return rich_compare(other, Py_GE); } + + object operator-() const; + object operator~() const; + object operator+(object_api const &other) const; + object operator+=(object_api const &other) const; + object operator-(object_api const &other) const; + object operator-=(object_api const &other) const; + object operator*(object_api const &other) const; + object operator*=(object_api const &other) const; + object operator/(object_api const &other) const; + object operator/=(object_api const &other) const; + object operator|(object_api const &other) const; + object operator|=(object_api const &other) const; + object operator&(object_api const &other) const; + object operator&=(object_api const &other) const; + object operator^(object_api const &other) const; + object operator^=(object_api const &other) const; + object operator<<(object_api const &other) const; + object operator<<=(object_api const &other) const; + object operator>>(object_api const &other) const; + object operator>>=(object_api const &other) const; + PYBIND11_DEPRECATED("Use py::str(obj) instead") pybind11::str str() const; @@ -122,11 +152,15 @@ class object_api : public pyobject_tag { /// Return the object's current reference count int ref_count() const { return static_cast(Py_REFCNT(derived().ptr())); } - /// Return a handle to the Python type object underlying the instance + + // TODO PYBIND11_DEPRECATED("Call py::type::handle_of(h) or py::type::of(h) instead of h.get_type()") handle get_type() const; + +private: + bool rich_compare(object_api const &other, int value) const; }; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /** \rst Holds a reference to a Python object (no reference counting) @@ -208,7 +242,7 @@ class object : public handle { ~object() { dec_ref(); } /** \rst - Resets the internal pointer to ``nullptr`` without without decreasing the + Resets the internal pointer to ``nullptr`` without decreasing the object's reference count. The function returns a raw handle to the original Python object. \endrst */ @@ -279,9 +313,9 @@ template T reinterpret_borrow(handle h) { return {h, object::borrow \endrst */ template T reinterpret_steal(handle h) { return {h, object::stolen_t{}}; } -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) inline std::string error_string(); -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) /// Fetch and hold an error which was already set in Python. An instance of this is typically /// thrown to propagate python-side errors back through C++ which can either be caught manually or @@ -292,15 +326,32 @@ class error_already_set : public std::runtime_error { /// Constructs a new exception from the current Python error indicator, if any. The current /// Python error indicator will be cleared. error_already_set() : std::runtime_error(detail::error_string()) { - PyErr_Fetch(&type.ptr(), &value.ptr(), &trace.ptr()); + PyErr_Fetch(&m_type.ptr(), &m_value.ptr(), &m_trace.ptr()); } - inline ~error_already_set(); + error_already_set(const error_already_set &) = default; + error_already_set(error_already_set &&) = default; + + inline ~error_already_set() override; /// Give the currently-held error back to Python, if any. If there is currently a Python error /// already set it is cleared first. After this call, the current object no longer stores the /// error variables (but the `.what()` string is still available). - void restore() { PyErr_Restore(type.release().ptr(), value.release().ptr(), trace.release().ptr()); } + void restore() { PyErr_Restore(m_type.release().ptr(), m_value.release().ptr(), m_trace.release().ptr()); } + + /// If it is impossible to raise the currently-held error, such as in destructor, we can write + /// it out using Python's unraisable hook (sys.unraisablehook). The error context should be + /// some object whose repr() helps identify the location of the error. Python already knows the + /// type and value of the error, so there is no need to repeat that. For example, __func__ could + /// be helpful. After this call, the current object no longer stores the error variables, + /// and neither does Python. + void discard_as_unraisable(object err_context) { + restore(); + PyErr_WriteUnraisable(err_context.ptr()); + } + void discard_as_unraisable(const char *err_context) { + discard_as_unraisable(reinterpret_steal(PYBIND11_FROM_STRING(err_context))); + } // Does nothing; provided for backwards compatibility. PYBIND11_DEPRECATED("Use of error_already_set.clear() is deprecated") @@ -309,10 +360,14 @@ class error_already_set : public std::runtime_error { /// Check if the currently trapped error type matches the given Python exception class (or a /// subclass thereof). May also be passed a tuple to search for any exception class matches in /// the given tuple. - bool matches(handle ex) const { return PyErr_GivenExceptionMatches(ex.ptr(), type.ptr()); } + bool matches(handle exc) const { return PyErr_GivenExceptionMatches(m_type.ptr(), exc.ptr()); } + + const object& type() const { return m_type; } + const object& value() const { return m_value; } + const object& trace() const { return m_trace; } private: - object type, value, trace; + object m_type, m_value, m_trace; }; /** \defgroup python_builtins _ @@ -331,7 +386,7 @@ bool isinstance(handle obj) { return T::check_(obj); } template ::value, int> = 0> bool isinstance(handle obj) { return detail::isinstance_generic(obj, typeid(T)); } -template <> inline bool isinstance(handle obj) = delete; +template <> inline bool isinstance(handle) = delete; template <> inline bool isinstance(handle obj) { return obj.ptr() != nullptr; } /// \ingroup python_builtins @@ -353,6 +408,14 @@ inline bool hasattr(handle obj, const char *name) { return PyObject_HasAttrString(obj.ptr(), name) == 1; } +inline void delattr(handle obj, handle name) { + if (PyObject_DelAttr(obj.ptr(), name.ptr()) != 0) { throw error_already_set(); } +} + +inline void delattr(handle obj, const char *name) { + if (PyObject_DelAttrString(obj.ptr(), name) != 0) { throw error_already_set(); } +} + inline object getattr(handle obj, handle name) { PyObject *result = PyObject_GetAttr(obj.ptr(), name.ptr()); if (!result) { throw error_already_set(); } @@ -399,7 +462,7 @@ inline ssize_t hash(handle obj) { /// @} python_builtins -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) inline handle get_function(handle value) { if (value) { #if PY_MAJOR_VERSION >= 3 @@ -424,7 +487,6 @@ object object_or_cast(T &&o); // Match a PyObject*, which we want to convert directly to handle via its converting constructor inline handle object_or_cast(PyObject *ptr) { return ptr; } - template class accessor : public object_api> { using key_type = typename Policy::key_type; @@ -474,7 +536,7 @@ class accessor : public object_api> { mutable object cache; }; -NAMESPACE_BEGIN(accessor_policies) +PYBIND11_NAMESPACE_BEGIN(accessor_policies) struct obj_attr { using key_type = object; static object get(handle obj, handle key) { return getattr(obj, key); } @@ -551,7 +613,7 @@ struct tuple_item { } } }; -NAMESPACE_END(accessor_policies) +PYBIND11_NAMESPACE_END(accessor_policies) /// STL iterator template used for tuple, list, sequence and dict template @@ -592,7 +654,7 @@ class generic_iterator : public Policy { friend bool operator<=(const It &a, const It &b) { return !(a > b); } }; -NAMESPACE_BEGIN(iterator_policies) +PYBIND11_NAMESPACE_BEGIN(iterator_policies) /// Quick proxy class needed to implement ``operator->`` for iterators which can't return pointers template struct arrow_proxy { @@ -662,10 +724,10 @@ class dict_readonly { private: handle obj; - PyObject *key, *value; + PyObject *key = nullptr, *value = nullptr; ssize_t pos = -1; }; -NAMESPACE_END(iterator_policies) +PYBIND11_NAMESPACE_END(iterator_policies) #if !defined(PYPY_VERSION) using tuple_iterator = generic_iterator; @@ -690,9 +752,12 @@ inline bool PyIterable_Check(PyObject *obj) { } inline bool PyNone_Check(PyObject *o) { return o == Py_None; } +inline bool PyEllipsis_Check(PyObject *o) { return o == Py_Ellipsis; } inline bool PyUnicode_Check_Permissive(PyObject *o) { return PyUnicode_Check(o) || PYBIND11_BYTES_CHECK(o); } +inline bool PyStaticMethod_Check(PyObject *o) { return o->ob_type == &PyStaticMethod_Type; } + class kwargs_proxy : public handle { public: explicit kwargs_proxy(handle h) : handle(h) { } @@ -719,7 +784,7 @@ class simple_collector; template class unpacking_collector; -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) // TODO: After the deprecated constructors are removed, this macro can be simplified by // inheriting ctors: `using Parent::Parent`. It's not an option right now because @@ -733,7 +798,9 @@ NAMESPACE_END(detail) Name(handle h, stolen_t) : Parent(h, stolen_t{}) { } \ PYBIND11_DEPRECATED("Use py::isinstance(obj) instead") \ bool check() const { return m_ptr != nullptr && (bool) CheckFun(m_ptr); } \ - static bool check_(handle h) { return h.ptr() != nullptr && CheckFun(h.ptr()); } + static bool check_(handle h) { return h.ptr() != nullptr && CheckFun(h.ptr()); } \ + template \ + Name(const ::pybind11::detail::accessor &a) : Name(object(a)) { } #define PYBIND11_OBJECT_CVT(Name, Parent, CheckFun, ConvertFun) \ PYBIND11_OBJECT_COMMON(Name, Parent, CheckFun) \ @@ -743,15 +810,20 @@ NAMESPACE_END(detail) { if (!m_ptr) throw error_already_set(); } \ Name(object &&o) \ : Parent(check_(o) ? o.release().ptr() : ConvertFun(o.ptr()), stolen_t{}) \ - { if (!m_ptr) throw error_already_set(); } \ - template \ - Name(const ::pybind11::detail::accessor &a) : Name(object(a)) { } + { if (!m_ptr) throw error_already_set(); } + +#define PYBIND11_OBJECT_CHECK_FAILED(Name, o) \ + ::pybind11::type_error("Object of type '" + \ + ::pybind11::detail::get_fully_qualified_tp_name(Py_TYPE(o.ptr())) + \ + "' is not an instance of '" #Name "'") #define PYBIND11_OBJECT(Name, Parent, CheckFun) \ PYBIND11_OBJECT_COMMON(Name, Parent, CheckFun) \ /* This is deliberately not 'explicit' to allow implicit conversion from object: */ \ - Name(const object &o) : Parent(o) { } \ - Name(object &&o) : Parent(std::move(o)) { } + Name(const object &o) : Parent(o) \ + { if (o && !check_(o)) throw PYBIND11_OBJECT_CHECK_FAILED(Name, o); } \ + Name(object &&o) : Parent(std::move(o)) \ + { if (o && !check_(o)) throw PYBIND11_OBJECT_CHECK_FAILED(Name, o); } #define PYBIND11_OBJECT_DEFAULT(Name, Parent, CheckFun) \ PYBIND11_OBJECT(Name, Parent, CheckFun) \ @@ -827,6 +899,32 @@ class iterator : public object { object value = {}; }; + + +class type : public object { +public: + PYBIND11_OBJECT(type, object, PyType_Check) + + /// Return a type handle from a handle or an object + static handle handle_of(handle h) { return handle((PyObject*) Py_TYPE(h.ptr())); } + + /// Return a type object from a handle or an object + static type of(handle h) { return type(type::handle_of(h), borrowed_t{}); } + + // Defined in pybind11/cast.h + /// Convert C++ type to handle if previously registered. Does not convert + /// standard types, like int, float. etc. yet. + /// See https://github.com/pybind/pybind11/issues/2486 + template + static handle handle_of(); + + /// Convert C++ type to type if previously registered. Does not convert + /// standard types, like int, float. etc. yet. + /// See https://github.com/pybind/pybind11/issues/2486 + template + static type of() {return type(type::handle_of(), borrowed_t{}); } +}; + class iterable : public object { public: PYBIND11_OBJECT_DEFAULT(iterable, object, detail::PyIterable_Check) @@ -857,7 +955,7 @@ class str : public object { Return a string representation of the object. This is analogous to the ``str()`` function in Python. \endrst */ - explicit str(handle h) : object(raw_str(h.ptr()), stolen_t{}) { } + explicit str(handle h) : object(raw_str(h.ptr()), stolen_t{}) { if (!m_ptr) throw error_already_set(); } operator std::string() const { object temp = *this; @@ -897,7 +995,7 @@ inline namespace literals { String literal version of `str` \endrst */ inline str operator"" _s(const char *s, size_t size) { return {s, size}; } -} +} // namespace literals /// \addtogroup pytypes /// @{ @@ -929,6 +1027,9 @@ class bytes : public object { return std::string(buffer, (size_t) length); } }; +// Note: breathe >= 4.17.0 will fail to build docs if the below two constructors +// are included in the doxygen group; close here and reopen after as a workaround +/// @} pytypes inline bytes::bytes(const pybind11::str &s) { object temp = s; @@ -958,12 +1059,20 @@ inline str::str(const bytes& b) { m_ptr = obj.release().ptr(); } +/// \addtogroup pytypes +/// @{ class none : public object { public: PYBIND11_OBJECT(none, object, detail::PyNone_Check) none() : object(Py_None, borrowed_t{}) { } }; +class ellipsis : public object { +public: + PYBIND11_OBJECT(ellipsis, object, detail::PyEllipsis_Check) + ellipsis() : object(Py_Ellipsis, borrowed_t{}) { } +}; + class bool_ : public object { public: PYBIND11_OBJECT_CVT(bool_, object, PyBool_Check, raw_bool) @@ -981,7 +1090,7 @@ class bool_ : public object { } }; -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) // Converts a value to the given unsigned type. If an error occurs, you get back (Unsigned) -1; // otherwise you get back the unsigned long or unsigned long long value cast to (Unsigned). // (The distinction is critically important when casting a returned -1 error value to some other @@ -1001,7 +1110,7 @@ Unsigned as_unsigned(PyObject *o) { return v == (unsigned long long) -1 && PyErr_Occurred() ? (Unsigned) -1 : (Unsigned) v; } } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) class int_ : public object { public: @@ -1074,6 +1183,13 @@ class slice : public object { (ssize_t *) stop, (ssize_t *) step, (ssize_t *) slicelength) == 0; } + bool compute(ssize_t length, ssize_t *start, ssize_t *stop, ssize_t *step, + ssize_t *slicelength) const { + return PySlice_GetIndicesEx((PYBIND11_SLICE_OBJECT *) m_ptr, + length, start, + stop, step, + slicelength) == 0; + } }; class capsule : public object { @@ -1120,12 +1236,24 @@ class capsule : public object { } template operator T *() const { + return get_pointer(); + } + + /// Get the pointer the capsule holds. + template + T* get_pointer() const { auto name = this->name(); - T * result = static_cast(PyCapsule_GetPointer(m_ptr, name)); + T *result = static_cast(PyCapsule_GetPointer(m_ptr, name)); if (!result) pybind11_fail("Unable to extract capsule contents!"); return result; } + /// Replaces a capsule's pointer *without* calling the destructor on the existing one. + void set_pointer(const void *value) { + if (PyCapsule_SetPointer(m_ptr, const_cast(value)) != 0) + pybind11_fail("Could not set capsule pointer"); + } + const char *name() const { return PyCapsule_GetName(m_ptr); } }; @@ -1136,7 +1264,9 @@ class tuple : public object { if (!m_ptr) pybind11_fail("Could not allocate tuple object!"); } size_t size() const { return (size_t) PyTuple_Size(m_ptr); } + bool empty() const { return size() == 0; } detail::tuple_accessor operator[](size_t index) const { return {*this, index}; } + detail::item_accessor operator[](handle h) const { return object::operator[](h); } detail::tuple_iterator begin() const { return {*this, 0}; } detail::tuple_iterator end() const { return {*this, PyTuple_GET_SIZE(m_ptr)}; } }; @@ -1154,11 +1284,13 @@ class dict : public object { explicit dict(Args &&...args) : dict(collector(std::forward(args)...).kwargs()) { } size_t size() const { return (size_t) PyDict_Size(m_ptr); } + bool empty() const { return size() == 0; } detail::dict_iterator begin() const { return {*this, 0}; } detail::dict_iterator end() const { return {}; } void clear() const { PyDict_Clear(ptr()); } - bool contains(handle key) const { return PyDict_Contains(ptr(), key.ptr()) == 1; } - bool contains(const char *key) const { return PyDict_Contains(ptr(), pybind11::str(key).ptr()) == 1; } + template bool contains(T &&key) const { + return PyDict_Contains(m_ptr, detail::object_or_cast(std::forward(key)).ptr()) == 1; + } private: /// Call the `dict` Python type -- always returns a new reference @@ -1172,8 +1304,15 @@ class dict : public object { class sequence : public object { public: PYBIND11_OBJECT_DEFAULT(sequence, object, PySequence_Check) - size_t size() const { return (size_t) PySequence_Size(m_ptr); } + size_t size() const { + ssize_t result = PySequence_Size(m_ptr); + if (result == -1) + throw error_already_set(); + return (size_t) result; + } + bool empty() const { return size() == 0; } detail::sequence_accessor operator[](size_t index) const { return {*this, index}; } + detail::item_accessor operator[](handle h) const { return object::operator[](h); } detail::sequence_iterator begin() const { return {*this, 0}; } detail::sequence_iterator end() const { return {*this, PySequence_Size(m_ptr)}; } }; @@ -1185,12 +1324,18 @@ class list : public object { if (!m_ptr) pybind11_fail("Could not allocate list object!"); } size_t size() const { return (size_t) PyList_Size(m_ptr); } + bool empty() const { return size() == 0; } detail::list_accessor operator[](size_t index) const { return {*this, index}; } + detail::item_accessor operator[](handle h) const { return object::operator[](h); } detail::list_iterator begin() const { return {*this, 0}; } detail::list_iterator end() const { return {*this, PyList_GET_SIZE(m_ptr)}; } template void append(T &&val) const { PyList_Append(m_ptr, detail::object_or_cast(std::forward(val)).ptr()); } + template void insert(size_t index, T &&val) const { + PyList_Insert(m_ptr, static_cast(index), + detail::object_or_cast(std::forward(val)).ptr()); + } }; class args : public tuple { PYBIND11_OBJECT_DEFAULT(args, tuple, PyTuple_Check) }; @@ -1203,10 +1348,14 @@ class set : public object { if (!m_ptr) pybind11_fail("Could not allocate set object!"); } size_t size() const { return (size_t) PySet_Size(m_ptr); } + bool empty() const { return size() == 0; } template bool add(T &&val) const { return PySet_Add(m_ptr, detail::object_or_cast(std::forward(val)).ptr()) == 0; } void clear() const { PySet_Clear(m_ptr); } + template bool contains(T &&val) const { + return PySet_Contains(m_ptr, detail::object_or_cast(std::forward(val)).ptr()) == 1; + } }; class function : public object { @@ -1221,14 +1370,19 @@ class function : public object { bool is_cpp_function() const { return (bool) cpp_function(); } }; +class staticmethod : public object { +public: + PYBIND11_OBJECT_CVT(staticmethod, object, detail::PyStaticMethod_Check, PyStaticMethod_New) +}; + class buffer : public object { public: PYBIND11_OBJECT_DEFAULT(buffer, object, PyObject_CheckBuffer) - buffer_info request(bool writable = false) { + buffer_info request(bool writable = false) const { int flags = PyBUF_STRIDES | PyBUF_FORMAT; if (writable) flags |= PyBUF_WRITABLE; - Py_buffer *view = new Py_buffer(); + auto *view = new Py_buffer(); if (PyObject_GetBuffer(m_ptr, view, flags) != 0) { delete view; throw error_already_set(); @@ -1239,43 +1393,166 @@ class buffer : public object { class memoryview : public object { public: - explicit memoryview(const buffer_info& info) { - static Py_buffer buf { }; - // Py_buffer uses signed sizes, strides and shape!.. - static std::vector py_strides { }; - static std::vector py_shape { }; - buf.buf = info.ptr; - buf.itemsize = info.itemsize; - buf.format = const_cast(info.format.c_str()); - buf.ndim = (int) info.ndim; - buf.len = info.size; - py_strides.clear(); - py_shape.clear(); - for (size_t i = 0; i < (size_t) info.ndim; ++i) { - py_strides.push_back(info.strides[i]); - py_shape.push_back(info.shape[i]); - } - buf.strides = py_strides.data(); - buf.shape = py_shape.data(); - buf.suboffsets = nullptr; - buf.readonly = false; - buf.internal = nullptr; + PYBIND11_OBJECT_CVT(memoryview, object, PyMemoryView_Check, PyMemoryView_FromObject) - m_ptr = PyMemoryView_FromBuffer(&buf); + /** \rst + Creates ``memoryview`` from ``buffer_info``. + + ``buffer_info`` must be created from ``buffer::request()``. Otherwise + throws an exception. + + For creating a ``memoryview`` from objects that support buffer protocol, + use ``memoryview(const object& obj)`` instead of this constructor. + \endrst */ + explicit memoryview(const buffer_info& info) { + if (!info.view()) + pybind11_fail("Prohibited to create memoryview without Py_buffer"); + // Note: PyMemoryView_FromBuffer never increments obj reference. + m_ptr = (info.view()->obj) ? + PyMemoryView_FromObject(info.view()->obj) : + PyMemoryView_FromBuffer(info.view()); if (!m_ptr) pybind11_fail("Unable to create memoryview from buffer descriptor"); } - PYBIND11_OBJECT_CVT(memoryview, object, PyMemoryView_Check, PyMemoryView_FromObject) + /** \rst + Creates ``memoryview`` from static buffer. + + This method is meant for providing a ``memoryview`` for C/C++ buffer not + managed by Python. The caller is responsible for managing the lifetime + of ``ptr`` and ``format``, which MUST outlive the memoryview constructed + here. + + See also: Python C API documentation for `PyMemoryView_FromBuffer`_. + + .. _PyMemoryView_FromBuffer: https://docs.python.org/c-api/memoryview.html#c.PyMemoryView_FromBuffer + + :param ptr: Pointer to the buffer. + :param itemsize: Byte size of an element. + :param format: Pointer to the null-terminated format string. For + homogeneous Buffers, this should be set to + ``format_descriptor::value``. + :param shape: Shape of the tensor (1 entry per dimension). + :param strides: Number of bytes between adjacent entries (for each + per dimension). + :param readonly: Flag to indicate if the underlying storage may be + written to. + \endrst */ + static memoryview from_buffer( + void *ptr, ssize_t itemsize, const char *format, + detail::any_container shape, + detail::any_container strides, bool readonly = false); + + static memoryview from_buffer( + const void *ptr, ssize_t itemsize, const char *format, + detail::any_container shape, + detail::any_container strides) { + return memoryview::from_buffer( + const_cast(ptr), itemsize, format, shape, strides, true); + } + + template + static memoryview from_buffer( + T *ptr, detail::any_container shape, + detail::any_container strides, bool readonly = false) { + return memoryview::from_buffer( + reinterpret_cast(ptr), sizeof(T), + format_descriptor::value, shape, strides, readonly); + } + + template + static memoryview from_buffer( + const T *ptr, detail::any_container shape, + detail::any_container strides) { + return memoryview::from_buffer( + const_cast(ptr), shape, strides, true); + } + +#if PY_MAJOR_VERSION >= 3 + /** \rst + Creates ``memoryview`` from static memory. + + This method is meant for providing a ``memoryview`` for C/C++ buffer not + managed by Python. The caller is responsible for managing the lifetime + of ``mem``, which MUST outlive the memoryview constructed here. + + This method is not available in Python 2. + + See also: Python C API documentation for `PyMemoryView_FromBuffer`_. + + .. _PyMemoryView_FromMemory: https://docs.python.org/c-api/memoryview.html#c.PyMemoryView_FromMemory + \endrst */ + static memoryview from_memory(void *mem, ssize_t size, bool readonly = false) { + PyObject* ptr = PyMemoryView_FromMemory( + reinterpret_cast(mem), size, + (readonly) ? PyBUF_READ : PyBUF_WRITE); + if (!ptr) + pybind11_fail("Could not allocate memoryview object!"); + return memoryview(object(ptr, stolen_t{})); + } + + static memoryview from_memory(const void *mem, ssize_t size) { + return memoryview::from_memory(const_cast(mem), size, true); + } +#endif }; + +#ifndef DOXYGEN_SHOULD_SKIP_THIS +inline memoryview memoryview::from_buffer( + void *ptr, ssize_t itemsize, const char* format, + detail::any_container shape, + detail::any_container strides, bool readonly) { + size_t ndim = shape->size(); + if (ndim != strides->size()) + pybind11_fail("memoryview: shape length doesn't match strides length"); + ssize_t size = ndim ? 1 : 0; + for (size_t i = 0; i < ndim; ++i) + size *= (*shape)[i]; + Py_buffer view; + view.buf = ptr; + view.obj = nullptr; + view.len = size * itemsize; + view.readonly = static_cast(readonly); + view.itemsize = itemsize; + view.format = const_cast(format); + view.ndim = static_cast(ndim); + view.shape = shape->data(); + view.strides = strides->data(); + view.suboffsets = nullptr; + view.internal = nullptr; + PyObject* obj = PyMemoryView_FromBuffer(&view); + if (!obj) + throw error_already_set(); + return memoryview(object(obj, stolen_t{})); +} +#endif // DOXYGEN_SHOULD_SKIP_THIS /// @} pytypes /// \addtogroup python_builtins /// @{ + +/// Get the length of a Python object. inline size_t len(handle h) { ssize_t result = PyObject_Length(h.ptr()); if (result < 0) - pybind11_fail("Unable to compute length of object"); + throw error_already_set(); + return (size_t) result; +} + +/// Get the length hint of a Python object. +/// Returns 0 when this cannot be determined. +inline size_t len_hint(handle h) { +#if PY_VERSION_HEX >= 0x03040000 + ssize_t result = PyObject_LengthHint(h.ptr(), 0); +#else + ssize_t result = PyObject_Length(h.ptr()); +#endif + if (result < 0) { + // Sometimes a length can't be determined at all (eg generators) + // In which case simply return 0 + PyErr_Clear(); + return 0; + } return (size_t) result; } @@ -1297,7 +1574,7 @@ inline iterator iter(handle obj) { } /// @} python_builtins -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) template iterator object_api::begin() const { return iter(derived()); } template iterator object_api::end() const { return iterator::sentinel(); } template item_accessor object_api::operator[](handle key) const { @@ -1326,7 +1603,57 @@ template str_attr_accessor object_api::doc() const { return attr("__doc__"); } template -handle object_api::get_type() const { return (PyObject *) Py_TYPE(derived().ptr()); } +handle object_api::get_type() const { return type::handle_of(derived()); } + +template +bool object_api::rich_compare(object_api const &other, int value) const { + int rv = PyObject_RichCompareBool(derived().ptr(), other.derived().ptr(), value); + if (rv == -1) + throw error_already_set(); + return rv == 1; +} + +#define PYBIND11_MATH_OPERATOR_UNARY(op, fn) \ + template object object_api::op() const { \ + object result = reinterpret_steal(fn(derived().ptr())); \ + if (!result.ptr()) \ + throw error_already_set(); \ + return result; \ + } + +#define PYBIND11_MATH_OPERATOR_BINARY(op, fn) \ + template \ + object object_api::op(object_api const &other) const { \ + object result = reinterpret_steal( \ + fn(derived().ptr(), other.derived().ptr())); \ + if (!result.ptr()) \ + throw error_already_set(); \ + return result; \ + } -NAMESPACE_END(detail) -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_MATH_OPERATOR_UNARY (operator~, PyNumber_Invert) +PYBIND11_MATH_OPERATOR_UNARY (operator-, PyNumber_Negative) +PYBIND11_MATH_OPERATOR_BINARY(operator+, PyNumber_Add) +PYBIND11_MATH_OPERATOR_BINARY(operator+=, PyNumber_InPlaceAdd) +PYBIND11_MATH_OPERATOR_BINARY(operator-, PyNumber_Subtract) +PYBIND11_MATH_OPERATOR_BINARY(operator-=, PyNumber_InPlaceSubtract) +PYBIND11_MATH_OPERATOR_BINARY(operator*, PyNumber_Multiply) +PYBIND11_MATH_OPERATOR_BINARY(operator*=, PyNumber_InPlaceMultiply) +PYBIND11_MATH_OPERATOR_BINARY(operator/, PyNumber_TrueDivide) +PYBIND11_MATH_OPERATOR_BINARY(operator/=, PyNumber_InPlaceTrueDivide) +PYBIND11_MATH_OPERATOR_BINARY(operator|, PyNumber_Or) +PYBIND11_MATH_OPERATOR_BINARY(operator|=, PyNumber_InPlaceOr) +PYBIND11_MATH_OPERATOR_BINARY(operator&, PyNumber_And) +PYBIND11_MATH_OPERATOR_BINARY(operator&=, PyNumber_InPlaceAnd) +PYBIND11_MATH_OPERATOR_BINARY(operator^, PyNumber_Xor) +PYBIND11_MATH_OPERATOR_BINARY(operator^=, PyNumber_InPlaceXor) +PYBIND11_MATH_OPERATOR_BINARY(operator<<, PyNumber_Lshift) +PYBIND11_MATH_OPERATOR_BINARY(operator<<=, PyNumber_InPlaceLshift) +PYBIND11_MATH_OPERATOR_BINARY(operator>>, PyNumber_Rshift) +PYBIND11_MATH_OPERATOR_BINARY(operator>>=, PyNumber_InPlaceRshift) + +#undef PYBIND11_MATH_OPERATOR_UNARY +#undef PYBIND11_MATH_OPERATOR_BINARY + +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/include/pybind11/stl.h b/plugins/python/pybind11/include/pybind11/stl.h index 1a4bbf0..721bb66 100644 --- a/plugins/python/pybind11/include/pybind11/stl.h +++ b/plugins/python/pybind11/include/pybind11/stl.h @@ -16,6 +16,7 @@ #include #include #include +#include #include #if defined(_MSC_VER) @@ -47,8 +48,8 @@ # define PYBIND11_HAS_VARIANT 1 #endif -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) /// Extracts an const lvalue reference or rvalue reference for U based on the type of T (e.g. for /// forwarding a container element). Typically used indirect via forwarded_type(), below. @@ -83,7 +84,8 @@ template struct set_caster { template static handle cast(T &&src, return_value_policy policy, handle parent) { - policy = return_value_policy_override::policy(policy); + if (!std::is_lvalue_reference::value) + policy = return_value_policy_override::policy(policy); pybind11::set s; for (auto &&value : src) { auto value_ = reinterpret_steal(key_conv::cast(forward_like(value), policy, parent)); @@ -93,7 +95,7 @@ template struct set_caster { return s.release(); } - PYBIND11_TYPE_CASTER(type, _("Set[") + key_conv::name() + _("]")); + PYBIND11_TYPE_CASTER(type, _("Set[") + key_conv::name + _("]")); }; template struct map_caster { @@ -119,8 +121,12 @@ template struct map_caster { template static handle cast(T &&src, return_value_policy policy, handle parent) { dict d; - return_value_policy policy_key = return_value_policy_override::policy(policy); - return_value_policy policy_value = return_value_policy_override::policy(policy); + return_value_policy policy_key = policy; + return_value_policy policy_value = policy; + if (!std::is_lvalue_reference::value) { + policy_key = return_value_policy_override::policy(policy_key); + policy_value = return_value_policy_override::policy(policy_value); + } for (auto &&kv : src) { auto key = reinterpret_steal(key_conv::cast(forward_like(kv.first), policy_key, parent)); auto value = reinterpret_steal(value_conv::cast(forward_like(kv.second), policy_value, parent)); @@ -131,14 +137,14 @@ template struct map_caster { return d.release(); } - PYBIND11_TYPE_CASTER(Type, _("Dict[") + key_conv::name() + _(", ") + value_conv::name() + _("]")); + PYBIND11_TYPE_CASTER(Type, _("Dict[") + key_conv::name + _(", ") + value_conv::name + _("]")); }; template struct list_caster { using value_conv = make_caster; bool load(handle src, bool convert) { - if (!isinstance(src)) + if (!isinstance(src) || isinstance(src)) return false; auto s = reinterpret_borrow(src); value.clear(); @@ -161,7 +167,8 @@ template struct list_caster { public: template static handle cast(T &&src, return_value_policy policy, handle parent) { - policy = return_value_policy_override::policy(policy); + if (!std::is_lvalue_reference::value) + policy = return_value_policy_override::policy(policy); list l(src.size()); size_t index = 0; for (auto &&value : src) { @@ -173,12 +180,15 @@ template struct list_caster { return l.release(); } - PYBIND11_TYPE_CASTER(Type, _("List[") + value_conv::name() + _("]")); + PYBIND11_TYPE_CASTER(Type, _("List[") + value_conv::name + _("]")); }; template struct type_caster> : list_caster, Type> { }; +template struct type_caster> + : list_caster, Type> { }; + template struct type_caster> : list_caster, Type> { }; @@ -199,9 +209,9 @@ template s public: bool load(handle src, bool convert) { - if (!isinstance(src)) + if (!isinstance(src)) return false; - auto l = reinterpret_borrow(src); + auto l = reinterpret_borrow(src); if (!require_size(l.size())) return false; size_t ctr = 0; @@ -227,7 +237,7 @@ template s return l.release(); } - PYBIND11_TYPE_CASTER(ArrayType, _("List[") + value_conv::name() + _(_(""), _("[") + _() + _("]")) + _("]")); + PYBIND11_TYPE_CASTER(ArrayType, _("List[") + value_conv::name + _(_(""), _("[") + _() + _("]")) + _("]")); }; template struct type_caster> @@ -256,7 +266,9 @@ template struct optional_caster { static handle cast(T_ &&src, return_value_policy policy, handle parent) { if (!src) return none().inc_ref(); - policy = return_value_policy_override::policy(policy); + if (!std::is_lvalue_reference::value) { + policy = return_value_policy_override::policy(policy); + } return value_conv::cast(*std::forward(src), policy, parent); } @@ -274,10 +286,10 @@ template struct optional_caster { return true; } - PYBIND11_TYPE_CASTER(T, _("Optional[") + value_conv::name() + _("]")); + PYBIND11_TYPE_CASTER(T, _("Optional[") + value_conv::name + _("]")); }; -#if PYBIND11_HAS_OPTIONAL +#if defined(PYBIND11_HAS_OPTIONAL) template struct type_caster> : public optional_caster> {}; @@ -285,7 +297,7 @@ template<> struct type_caster : public void_caster {}; #endif -#if PYBIND11_HAS_EXP_OPTIONAL +#if defined(PYBIND11_HAS_EXP_OPTIONAL) template struct type_caster> : public optional_caster> {}; @@ -354,22 +366,22 @@ struct variant_caster> { } using Type = V; - PYBIND11_TYPE_CASTER(Type, _("Union[") + detail::concat(make_caster::name()...) + _("]")); + PYBIND11_TYPE_CASTER(Type, _("Union[") + detail::concat(make_caster::name...) + _("]")); }; -#if PYBIND11_HAS_VARIANT +#if defined(PYBIND11_HAS_VARIANT) template struct type_caster> : variant_caster> { }; #endif -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) inline std::ostream &operator<<(std::ostream &os, const handle &obj) { os << (std::string) str(obj); return os; } -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) #if defined(_MSC_VER) #pragma warning(pop) diff --git a/plugins/python/pybind11/include/pybind11/stl_bind.h b/plugins/python/pybind11/include/pybind11/stl_bind.h index 38dd68f..9d8ed0c 100644 --- a/plugins/python/pybind11/include/pybind11/stl_bind.h +++ b/plugins/python/pybind11/include/pybind11/stl_bind.h @@ -15,8 +15,8 @@ #include #include -NAMESPACE_BEGIN(PYBIND11_NAMESPACE) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_BEGIN(detail) /* SFINAE helper class used by 'is_comparable */ template struct container_traits { @@ -115,6 +115,14 @@ void vector_modifiers(enable_if_t= n) + throw index_error(); + return i; + }; + cl.def("append", [](Vector &v, const T &value) { v.push_back(value); }, arg("x"), @@ -122,12 +130,19 @@ void vector_modifiers(enable_if_t(new Vector()); - v->reserve(len(it)); + v->reserve(len_hint(it)); for (handle h : it) v->push_back(h.cast()); return v.release(); })); + cl.def("clear", + [](Vector &v) { + v.clear(); + }, + "Clear the contents" + ); + cl.def("extend", [](Vector &v, const Vector &src) { v.insert(v.end(), src.begin(), src.end()); @@ -136,11 +151,36 @@ void vector_modifiers(enable_if_t()); + } + } catch (const cast_error &) { + v.erase(v.begin() + static_cast(old_size), v.end()); + try { + v.shrink_to_fit(); + } catch (const std::exception &) { + // Do nothing + } + throw; + } + }, + arg("L"), + "Extend the list by appending all the items in the given list" + ); + cl.def("insert", - [](Vector &v, SizeType i, const T &x) { - if (i > v.size()) + [](Vector &v, DiffType i, const T &x) { + // Can't use wrap_i; i == v.size() is OK + if (i < 0) + i += v.size(); + if (i < 0 || (SizeType)i > v.size()) throw index_error(); - v.insert(v.begin() + (DiffType) i, x); + v.insert(v.begin() + i, x); }, arg("i") , arg("x"), "Insert an item at a given position." @@ -158,11 +198,10 @@ void vector_modifiers(enable_if_t= v.size()) - throw index_error(); - T t = v[i]; - v.erase(v.begin() + (DiffType) i); + [wrap_i](Vector &v, DiffType i) { + i = wrap_i(i, v.size()); + T t = v[(SizeType) i]; + v.erase(v.begin() + i); return t; }, arg("i"), @@ -170,10 +209,9 @@ void vector_modifiers(enable_if_t= v.size()) - throw index_error(); - v[i] = t; + [wrap_i](Vector &v, DiffType i, const T &t) { + i = wrap_i(i, v.size()); + v[(SizeType)i] = t; } ); @@ -185,7 +223,7 @@ void vector_modifiers(enable_if_treserve((size_t) slicelength); for (size_t i=0; i= v.size()) - throw index_error(); - v.erase(v.begin() + DiffType(i)); + [wrap_i](Vector &v, DiffType i) { + i = wrap_i(i, v.size()); + v.erase(v.begin() + i); }, "Delete the list elements at index ``i``" ); @@ -255,13 +292,21 @@ template void vector_accessor(enable_if_t::value, Class_> &cl) { using T = typename Vector::value_type; using SizeType = typename Vector::size_type; + using DiffType = typename Vector::difference_type; using ItType = typename Vector::iterator; + auto wrap_i = [](DiffType i, SizeType n) { + if (i < 0) + i += n; + if (i < 0 || (SizeType)i >= n) + throw index_error(); + return i; + }; + cl.def("__getitem__", - [](Vector &v, SizeType i) -> T & { - if (i >= v.size()) - throw index_error(); - return v[i]; + [wrap_i](Vector &v, DiffType i) -> T & { + i = wrap_i(i, v.size()); + return v[(SizeType)i]; }, return_value_policy::reference_internal // ref + keepalive ); @@ -281,12 +326,15 @@ template void vector_accessor(enable_if_t::value, Class_> &cl) { using T = typename Vector::value_type; using SizeType = typename Vector::size_type; + using DiffType = typename Vector::difference_type; using ItType = typename Vector::iterator; cl.def("__getitem__", - [](const Vector &v, SizeType i) -> T { - if (i >= v.size()) + [](const Vector &v, DiffType i) -> T { + if (i < 0 && (i += v.size()) < 0) + throw index_error(); + if ((SizeType)i >= v.size()) throw index_error(); - return v[i]; + return v[(SizeType)i]; } ); @@ -349,14 +397,19 @@ vector_buffer(Class_& cl) { if (!detail::compare_buffer_info::compare(info) || (ssize_t) sizeof(T) != info.itemsize) throw type_error("Format mismatch (Python: " + info.format + " C++: " + format_descriptor::format() + ")"); - auto vec = std::unique_ptr(new Vector()); - vec->reserve((size_t) info.shape[0]); T *p = static_cast(info.ptr); ssize_t step = info.strides[0] / static_cast(sizeof(T)); T *end = p + info.shape[0] * step; - for (; p != end; p += step) - vec->push_back(*p); - return vec.release(); + if (step == 1) { + return Vector(p, end); + } + else { + Vector vec; + vec.reserve((size_t) info.shape[0]); + for (; p != end; p += step) + vec.push_back(*p); + return vec; + } })); return; @@ -365,7 +418,7 @@ vector_buffer(Class_& cl) { template enable_if_t...>::value> vector_buffer(Class_&) {} -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) // // std::vector @@ -463,7 +516,7 @@ class_ bind_vector(handle scope, std::string const &name, A // std::map, std::unordered_map // -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(detail) /* Fallback functions */ template void map_if_insertion_operator(const Args &...) { } @@ -471,7 +524,7 @@ template void map_assignment(const Args & // Map assignment when copy-assignable: just copy the value template -void map_assignment(enable_if_t::value, Class_> &cl) { +void map_assignment(enable_if_t::value, Class_> &cl) { using KeyType = typename Map::key_type; using MappedType = typename Map::mapped_type; @@ -487,7 +540,7 @@ void map_assignment(enable_if_t void map_assignment(enable_if_t< - !std::is_copy_assignable::value && + !is_copy_assignable::value && is_copy_constructible::value, Class_> &cl) { using KeyType = typename Map::key_type; @@ -529,7 +582,7 @@ template auto map_if_insertion_operator(Class_ & } -NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(detail) template , typename... Args> class_ bind_map(handle scope, const std::string &name, Args&&... args) { @@ -579,6 +632,15 @@ class_ bind_map(handle scope, const std::string &name, Args&&. return_value_policy::reference_internal // ref + keepalive ); + cl.def("__contains__", + [](Map &m, const KeyType &k) -> bool { + auto it = m.find(k); + if (it == m.end()) + return false; + return true; + } + ); + // Assignment provided only if the type is copyable detail::map_assignment(cl); @@ -596,4 +658,4 @@ class_ bind_map(handle scope, const std::string &name, Args&&. return cl; } -NAMESPACE_END(PYBIND11_NAMESPACE) +PYBIND11_NAMESPACE_END(PYBIND11_NAMESPACE) diff --git a/plugins/python/pybind11/pybind11/__init__.py b/plugins/python/pybind11/pybind11/__init__.py index 5782ffe..ad65420 100644 --- a/plugins/python/pybind11/pybind11/__init__.py +++ b/plugins/python/pybind11/pybind11/__init__.py @@ -1,28 +1,12 @@ -from ._version import version_info, __version__ # noqa: F401 imported but unused +# -*- coding: utf-8 -*- +from ._version import version_info, __version__ +from .commands import get_include, get_cmake_dir -def get_include(user=False): - from distutils.dist import Distribution - import os - import sys - # Are we running in a virtual environment? - virtualenv = hasattr(sys, 'real_prefix') or \ - sys.prefix != getattr(sys, "base_prefix", sys.prefix) - - if virtualenv: - return os.path.join(sys.prefix, 'include', 'site', - 'python' + sys.version[:3]) - else: - dist = Distribution({'name': 'pybind11'}) - dist.parse_config_files() - - dist_cobj = dist.get_command_obj('install', create=True) - - # Search for packages in user's home directory? - if user: - dist_cobj.user = user - dist_cobj.prefix = "" - dist_cobj.finalize_options() - - return os.path.dirname(dist_cobj.install_headers) +__all__ = ( + "version_info", + "__version__", + "get_include", + "get_cmake_dir", +) diff --git a/plugins/python/pybind11/pybind11/__main__.py b/plugins/python/pybind11/pybind11/__main__.py index 9ef8378..020988c 100644 --- a/plugins/python/pybind11/pybind11/__main__.py +++ b/plugins/python/pybind11/pybind11/__main__.py @@ -1,37 +1,52 @@ +# -*- coding: utf-8 -*- from __future__ import print_function import argparse import sys import sysconfig -from . import get_include +from .commands import get_include, get_cmake_dir def print_includes(): - dirs = [sysconfig.get_path('include'), - sysconfig.get_path('platinclude'), - get_include(), - get_include(True)] + # type: () -> None + dirs = [ + sysconfig.get_path("include"), + sysconfig.get_path("platinclude"), + get_include(), + ] # Make unique but preserve order unique_dirs = [] for d in dirs: - if d not in unique_dirs: + if d and d not in unique_dirs: unique_dirs.append(d) - print(' '.join('-I' + d for d in unique_dirs)) + print(" ".join("-I" + d for d in unique_dirs)) def main(): - parser = argparse.ArgumentParser(prog='python -m pybind11') - parser.add_argument('--includes', action='store_true', - help='Include flags for both pybind11 and Python headers.') + # type: () -> None + + parser = argparse.ArgumentParser() + parser.add_argument( + "--includes", + action="store_true", + help="Include flags for both pybind11 and Python headers.", + ) + parser.add_argument( + "--cmakedir", + action="store_true", + help="Print the CMake module directory, ideal for setting -Dpybind11_ROOT in CMake.", + ) args = parser.parse_args() if not sys.argv[1:]: parser.print_help() if args.includes: print_includes() + if args.cmakedir: + print(get_cmake_dir()) -if __name__ == '__main__': +if __name__ == "__main__": main() diff --git a/plugins/python/pybind11/pybind11/_version.py b/plugins/python/pybind11/pybind11/_version.py index 54ebfb1..d18535c 100644 --- a/plugins/python/pybind11/pybind11/_version.py +++ b/plugins/python/pybind11/pybind11/_version.py @@ -1,2 +1,12 @@ -version_info = (2, 2, 4) -__version__ = '.'.join(map(str, version_info)) +# -*- coding: utf-8 -*- + + +def _to_int(s): + try: + return int(s) + except ValueError: + return s + + +__version__ = "2.6.1" +version_info = tuple(_to_int(s) for s in __version__.split(".")) diff --git a/plugins/python/pybind11/pybind11/_version.pyi b/plugins/python/pybind11/pybind11/_version.pyi new file mode 100644 index 0000000..970184c --- /dev/null +++ b/plugins/python/pybind11/pybind11/_version.pyi @@ -0,0 +1,6 @@ +from typing import Union, Tuple + +def _to_int(s: str) -> Union[int, str]: ... + +__version__: str +version_info: Tuple[Union[int, str], ...] diff --git a/plugins/python/pybind11/pybind11/commands.py b/plugins/python/pybind11/pybind11/commands.py new file mode 100644 index 0000000..34dbaf8 --- /dev/null +++ b/plugins/python/pybind11/pybind11/commands.py @@ -0,0 +1,22 @@ +# -*- coding: utf-8 -*- +import os + + +DIR = os.path.abspath(os.path.dirname(__file__)) + + +def get_include(user=False): + # type: (bool) -> str + installed_path = os.path.join(DIR, "include") + source_path = os.path.join(os.path.dirname(DIR), "include") + return installed_path if os.path.exists(installed_path) else source_path + + +def get_cmake_dir(): + # type: () -> str + cmake_installed_path = os.path.join(DIR, "share", "cmake", "pybind11") + if os.path.exists(cmake_installed_path): + return cmake_installed_path + else: + msg = "pybind11 not installed, installation required to access the CMake files" + raise ImportError(msg) diff --git a/plugins/python/pybind11/pybind11/py.typed b/plugins/python/pybind11/pybind11/py.typed new file mode 100644 index 0000000..e69de29 diff --git a/plugins/python/pybind11/pybind11/setup_helpers.py b/plugins/python/pybind11/pybind11/setup_helpers.py new file mode 100644 index 0000000..33605dd --- /dev/null +++ b/plugins/python/pybind11/pybind11/setup_helpers.py @@ -0,0 +1,436 @@ +# -*- coding: utf-8 -*- + +""" +This module provides helpers for C++11+ projects using pybind11. + +LICENSE: + +Copyright (c) 2016 Wenzel Jakob , All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + +3. Neither the name of the copyright holder nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +""" + +# IMPORTANT: If you change this file in the pybind11 repo, also review +# setup_helpers.pyi for matching changes. +# +# If you copy this file in, you don't +# need the .pyi file; it's just an interface file for static type checkers. + +import contextlib +import os +import shutil +import sys +import tempfile +import threading +import platform +import warnings + +try: + from setuptools.command.build_ext import build_ext as _build_ext + from setuptools import Extension as _Extension +except ImportError: + from distutils.command.build_ext import build_ext as _build_ext + from distutils.extension import Extension as _Extension + +import distutils.errors +import distutils.ccompiler + + +WIN = sys.platform.startswith("win32") +PY2 = sys.version_info[0] < 3 +MACOS = sys.platform.startswith("darwin") +STD_TMPL = "/std:c++{}" if WIN else "-std=c++{}" + + +# It is recommended to use PEP 518 builds if using this module. However, this +# file explicitly supports being copied into a user's project directory +# standalone, and pulling pybind11 with the deprecated setup_requires feature. +# If you copy the file, remember to add it to your MANIFEST.in, and add the current +# directory into your path if it sits beside your setup.py. + + +class Pybind11Extension(_Extension): + """ + Build a C++11+ Extension module with pybind11. This automatically adds the + recommended flags when you init the extension and assumes C++ sources - you + can further modify the options yourself. + + The customizations are: + + * ``/EHsc`` and ``/bigobj`` on Windows + * ``stdlib=libc++`` on macOS + * ``visibility=hidden`` and ``-g0`` on Unix + + Finally, you can set ``cxx_std`` via constructor or afterwords to enable + flags for C++ std, and a few extra helper flags related to the C++ standard + level. It is _highly_ recommended you either set this, or use the provided + ``build_ext``, which will search for the highest supported extension for + you if the ``cxx_std`` property is not set. Do not set the ``cxx_std`` + property more than once, as flags are added when you set it. Set the + property to None to disable the addition of C++ standard flags. + + If you want to add pybind11 headers manually, for example for an exact + git checkout, then set ``include_pybind11=False``. + + Warning: do not use property-based access to the instance on Python 2 - + this is an ugly old-style class due to Distutils. + """ + + def _add_cflags(self, *flags): + for flag in flags: + if flag not in self.extra_compile_args: + self.extra_compile_args.append(flag) + + def _add_lflags(self, *flags): + for flag in flags: + if flag not in self.extra_link_args: + self.extra_link_args.append(flag) + + def __init__(self, *args, **kwargs): + + self._cxx_level = 0 + cxx_std = kwargs.pop("cxx_std", 0) + + if "language" not in kwargs: + kwargs["language"] = "c++" + + include_pybind11 = kwargs.pop("include_pybind11", True) + + # Can't use super here because distutils has old-style classes in + # Python 2! + _Extension.__init__(self, *args, **kwargs) + + # Include the installed package pybind11 headers + if include_pybind11: + # If using setup_requires, this fails the first time - that's okay + try: + import pybind11 + + pyinc = pybind11.get_include() + + if pyinc not in self.include_dirs: + self.include_dirs.append(pyinc) + except ImportError: + pass + + # Have to use the accessor manually to support Python 2 distutils + Pybind11Extension.cxx_std.__set__(self, cxx_std) + + if WIN: + self._add_cflags("/EHsc", "/bigobj") + else: + self._add_cflags("-fvisibility=hidden", "-g0") + if MACOS: + self._add_cflags("-stdlib=libc++") + self._add_lflags("-stdlib=libc++") + + @property + def cxx_std(self): + """ + The CXX standard level. If set, will add the required flags. If left + at 0, it will trigger an automatic search when pybind11's build_ext + is used. If None, will have no effect. Besides just the flags, this + may add a register warning/error fix for Python 2 or macos-min 10.9 + or 10.14. + """ + return self._cxx_level + + @cxx_std.setter + def cxx_std(self, level): + + if self._cxx_level: + warnings.warn("You cannot safely change the cxx_level after setting it!") + + # MSVC 2015 Update 3 and later only have 14 (and later 17) modes, so + # force a valid flag here. + if WIN and level == 11: + level = 14 + + self._cxx_level = level + + if not level: + return + + self.extra_compile_args.append(STD_TMPL.format(level)) + + if MACOS and "MACOSX_DEPLOYMENT_TARGET" not in os.environ: + # C++17 requires a higher min version of macOS. An earlier version + # (10.12 or 10.13) can be set manually via environment variable if + # you are careful in your feature usage, but 10.14 is the safest + # setting for general use. However, never set higher than the + # current macOS version! + current_macos = tuple(int(x) for x in platform.mac_ver()[0].split(".")[:2]) + desired_macos = (10, 9) if level < 17 else (10, 14) + macos_string = ".".join(str(x) for x in min(current_macos, desired_macos)) + macosx_min = "-mmacosx-version-min=" + macos_string + self.extra_compile_args.append(macosx_min) + self.extra_link_args.append(macosx_min) + + if PY2: + if WIN: + # Will be ignored on MSVC 2015, where C++17 is not supported so + # this flag is not valid. + self.extra_compile_args.append("/wd5033") + elif level >= 17: + self.extra_compile_args.append("-Wno-register") + elif level >= 14: + self.extra_compile_args.append("-Wno-deprecated-register") + + +# Just in case someone clever tries to multithread +tmp_chdir_lock = threading.Lock() +cpp_cache_lock = threading.Lock() + + +@contextlib.contextmanager +def tmp_chdir(): + "Prepare and enter a temporary directory, cleanup when done" + + # Threadsafe + with tmp_chdir_lock: + olddir = os.getcwd() + try: + tmpdir = tempfile.mkdtemp() + os.chdir(tmpdir) + yield tmpdir + finally: + os.chdir(olddir) + shutil.rmtree(tmpdir) + + +# cf http://bugs.python.org/issue26689 +def has_flag(compiler, flag): + """ + Return the flag if a flag name is supported on the + specified compiler, otherwise None (can be used as a boolean). + If multiple flags are passed, return the first that matches. + """ + + with tmp_chdir(): + fname = "flagcheck.cpp" + with open(fname, "w") as f: + f.write("int main (int argc, char **argv) { return 0; }") + + try: + compiler.compile([fname], extra_postargs=[flag]) + except distutils.errors.CompileError: + return False + return True + + +# Every call will cache the result +cpp_flag_cache = None + + +def auto_cpp_level(compiler): + """ + Return the max supported C++ std level (17, 14, or 11). Returns latest on Windows. + """ + + if WIN: + return "latest" + + global cpp_flag_cache + + # If this has been previously calculated with the same args, return that + with cpp_cache_lock: + if cpp_flag_cache: + return cpp_flag_cache + + levels = [17, 14, 11] + + for level in levels: + if has_flag(compiler, STD_TMPL.format(level)): + with cpp_cache_lock: + cpp_flag_cache = level + return level + + msg = "Unsupported compiler -- at least C++11 support is needed!" + raise RuntimeError(msg) + + +class build_ext(_build_ext): # noqa: N801 + """ + Customized build_ext that allows an auto-search for the highest supported + C++ level for Pybind11Extension. This is only needed for the auto-search + for now, and is completely optional otherwise. + """ + + def build_extensions(self): + """ + Build extensions, injecting C++ std for Pybind11Extension if needed. + """ + + for ext in self.extensions: + if hasattr(ext, "_cxx_level") and ext._cxx_level == 0: + # Python 2 syntax - old-style distutils class + ext.__class__.cxx_std.__set__(ext, auto_cpp_level(self.compiler)) + + # Python 2 doesn't allow super here, since distutils uses old-style + # classes! + _build_ext.build_extensions(self) + + +def naive_recompile(obj, src): + """ + This will recompile only if the source file changes. It does not check + header files, so a more advanced function or Ccache is better if you have + editable header files in your package. + """ + return os.stat(obj).st_mtime < os.stat(src).st_mtime + + +def no_recompile(obg, src): + """ + This is the safest but slowest choice (and is the default) - will always + recompile sources. + """ + return True + + +# Optional parallel compile utility +# inspired by: http://stackoverflow.com/questions/11013851/speeding-up-build-process-with-distutils +# and: https://github.com/tbenthompson/cppimport/blob/stable/cppimport/build_module.py +# and NumPy's parallel distutils module: +# https://github.com/numpy/numpy/blob/master/numpy/distutils/ccompiler.py +class ParallelCompile(object): + """ + Make a parallel compile function. Inspired by + numpy.distutils.ccompiler.CCompiler_compile and cppimport. + + This takes several arguments that allow you to customize the compile + function created: + + envvar: + Set an environment variable to control the compilation threads, like + NPY_NUM_BUILD_JOBS + default: + 0 will automatically multithread, or 1 will only multithread if the + envvar is set. + max: + The limit for automatic multithreading if non-zero + needs_recompile: + A function of (obj, src) that returns True when recompile is needed. No + effect in isolated mode; use ccache instead, see + https://github.com/matplotlib/matplotlib/issues/1507/ + + To use:: + + ParallelCompile("NPY_NUM_BUILD_JOBS").install() + + or:: + + with ParallelCompile("NPY_NUM_BUILD_JOBS"): + setup(...) + + By default, this assumes all files need to be recompiled. A smarter + function can be provided via needs_recompile. If the output has not yet + been generated, the compile will always run, and this function is not + called. + """ + + __slots__ = ("envvar", "default", "max", "_old", "needs_recompile") + + def __init__(self, envvar=None, default=0, max=0, needs_recompile=no_recompile): + self.envvar = envvar + self.default = default + self.max = max + self.needs_recompile = needs_recompile + self._old = [] + + def function(self): + """ + Builds a function object usable as distutils.ccompiler.CCompiler.compile. + """ + + def compile_function( + compiler, + sources, + output_dir=None, + macros=None, + include_dirs=None, + debug=0, + extra_preargs=None, + extra_postargs=None, + depends=None, + ): + + # These lines are directly from distutils.ccompiler.CCompiler + macros, objects, extra_postargs, pp_opts, build = compiler._setup_compile( + output_dir, macros, include_dirs, sources, depends, extra_postargs + ) + cc_args = compiler._get_cc_args(pp_opts, debug, extra_preargs) + + # The number of threads; start with default. + threads = self.default + + # Determine the number of compilation threads, unless set by an environment variable. + if self.envvar is not None: + threads = int(os.environ.get(self.envvar, self.default)) + + def _single_compile(obj): + try: + src, ext = build[obj] + except KeyError: + return + + if not os.path.exists(obj) or self.needs_recompile(obj, src): + compiler._compile(obj, src, ext, cc_args, extra_postargs, pp_opts) + + try: + import multiprocessing + from multiprocessing.pool import ThreadPool + except ImportError: + threads = 1 + + if threads == 0: + try: + threads = multiprocessing.cpu_count() + threads = self.max if self.max and self.max < threads else threads + except NotImplementedError: + threads = 1 + + if threads > 1: + for _ in ThreadPool(threads).imap_unordered(_single_compile, objects): + pass + else: + for ob in objects: + _single_compile(ob) + + return objects + + return compile_function + + def install(self): + distutils.ccompiler.CCompiler.compile = self.function() + return self + + def __enter__(self): + self._old.append(distutils.ccompiler.CCompiler.compile) + return self.install() + + def __exit__(self, *args): + distutils.ccompiler.CCompiler.compile = self._old.pop() diff --git a/plugins/python/pybind11/pybind11/setup_helpers.pyi b/plugins/python/pybind11/pybind11/setup_helpers.pyi new file mode 100644 index 0000000..23232e1 --- /dev/null +++ b/plugins/python/pybind11/pybind11/setup_helpers.pyi @@ -0,0 +1,61 @@ +# IMPORTANT: Should stay in sync with setup_helpers.py (mostly checked by CI / +# pre-commit). + +from typing import Any, Callable, Iterator, Optional, Type, TypeVar, Union +from types import TracebackType + +from distutils.command.build_ext import build_ext as _build_ext # type: ignore +from distutils.extension import Extension as _Extension +import distutils.ccompiler +import contextlib + +WIN: bool +PY2: bool +MACOS: bool +STD_TMPL: str + +class Pybind11Extension(_Extension): + def _add_cflags(self, *flags: str) -> None: ... + def _add_lflags(self, *flags: str) -> None: ... + def __init__( + self, *args: Any, cxx_std: int = 0, language: str = "c++", **kwargs: Any + ) -> None: ... + @property + def cxx_std(self) -> int: ... + @cxx_std.setter + def cxx_std(self, level: int) -> None: ... + +@contextlib.contextmanager +def tmp_chdir() -> Iterator[str]: ... +def has_flag(compiler: distutils.ccompiler.CCompiler, flag: str) -> bool: ... +def auto_cpp_level(compiler: distutils.ccompiler.CCompiler) -> Union[int, str]: ... + +class build_ext(_build_ext): # type: ignore + def build_extensions(self) -> None: ... + +def no_recompile(obj: str, src: str) -> bool: ... +def naive_recompile(obj: str, src: str) -> bool: ... + +T = TypeVar("T", bound="ParallelCompile") + +class ParallelCompile: + envvar: Optional[str] + default: int + max: int + needs_recompile: Callable[[str, str], bool] + def __init__( + self, + envvar: Optional[str] = None, + default: int = 0, + max: int = 0, + needs_recompile: Callable[[str, str], bool] = no_recompile, + ) -> None: ... + def function(self) -> Any: ... + def install(self: T) -> T: ... + def __enter__(self: T) -> T: ... + def __exit__( + self, + exc_type: Optional[Type[BaseException]], + exc_value: Optional[BaseException], + traceback: Optional[TracebackType], + ) -> None: ... diff --git a/plugins/python/pybind11/pyproject.toml b/plugins/python/pybind11/pyproject.toml new file mode 100644 index 0000000..5c9d153 --- /dev/null +++ b/plugins/python/pybind11/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["setuptools>=42", "wheel", "cmake>=3.18", "ninja"] +build-backend = "setuptools.build_meta" diff --git a/plugins/python/pybind11/setup.cfg b/plugins/python/pybind11/setup.cfg index 369788b..e7fc8f4 100644 --- a/plugins/python/pybind11/setup.cfg +++ b/plugins/python/pybind11/setup.cfg @@ -1,10 +1,71 @@ +[metadata] +long_description = file: README.rst +long_description_content_type = text/x-rst +description = Seamless operability between C++11 and Python +author = Wenzel Jakob +author_email = wenzel.jakob@epfl.ch +url = https://github.com/pybind/pybind11 +license = BSD + +classifiers = + Development Status :: 5 - Production/Stable + Intended Audience :: Developers + Topic :: Software Development :: Libraries :: Python Modules + Topic :: Utilities + Programming Language :: C++ + Programming Language :: Python :: 2.7 + Programming Language :: Python :: 3 + Programming Language :: Python :: 3.5 + Programming Language :: Python :: 3.6 + Programming Language :: Python :: 3.7 + Programming Language :: Python :: 3.8 + Programming Language :: Python :: 3.9 + License :: OSI Approved :: BSD License + Programming Language :: Python :: Implementation :: PyPy + Programming Language :: Python :: Implementation :: CPython + Programming Language :: C++ + Topic :: Software Development :: Libraries :: Python Modules + +keywords = + C++11 + Python bindings + +[options] +python_requires = >=2.7, !=3.0, !=3.1, !=3.2, !=3.3, !=3.4 +zip_safe = False + [bdist_wheel] universal=1 +[check-manifest] +ignore = + tests/** + docs/** + tools/** + include/** + .appveyor.yml + .cmake-format.yaml + .gitmodules + .pre-commit-config.yaml + .readthedocs.yml + .clang-tidy + pybind11/include/** + pybind11/share/** + CMakeLists.txt + + [flake8] max-line-length = 99 show_source = True exclude = .git, __pycache__, build, dist, docs, tools, venv ignore = # required for pretty matrix formatting: multiple spaces after `,` and `[` - E201, E241 + E201, E241, W504, + # camelcase 'cPickle' imported as lowercase 'pickle' + N813 + # Black conflict + W503, E203 + +[mypy] +files = pybind11 +strict = True diff --git a/plugins/python/pybind11/setup.py b/plugins/python/pybind11/setup.py index f677f2a..3a03279 100644 --- a/plugins/python/pybind11/setup.py +++ b/plugins/python/pybind11/setup.py @@ -1,108 +1,115 @@ #!/usr/bin/env python +# -*- coding: utf-8 -*- # Setup script for PyPI; use CMakeFile.txt to build extension modules -from setuptools import setup -from distutils.command.install_headers import install_headers -from pybind11 import __version__ +import contextlib import os +import re +import shutil +import string +import subprocess +import sys +import tempfile -# Prevent installation of pybind11 headers by setting -# PYBIND11_USE_CMAKE. -if os.environ.get('PYBIND11_USE_CMAKE'): - headers = [] -else: - headers = [ - 'include/pybind11/detail/class.h', - 'include/pybind11/detail/common.h', - 'include/pybind11/detail/descr.h', - 'include/pybind11/detail/init.h', - 'include/pybind11/detail/internals.h', - 'include/pybind11/detail/typeid.h', - 'include/pybind11/attr.h', - 'include/pybind11/buffer_info.h', - 'include/pybind11/cast.h', - 'include/pybind11/chrono.h', - 'include/pybind11/common.h', - 'include/pybind11/complex.h', - 'include/pybind11/eigen.h', - 'include/pybind11/embed.h', - 'include/pybind11/eval.h', - 'include/pybind11/functional.h', - 'include/pybind11/iostream.h', - 'include/pybind11/numpy.h', - 'include/pybind11/operators.h', - 'include/pybind11/options.h', - 'include/pybind11/pybind11.h', - 'include/pybind11/pytypes.h', - 'include/pybind11/stl.h', - 'include/pybind11/stl_bind.h', - ] - - -class InstallHeaders(install_headers): - """Use custom header installer because the default one flattens subdirectories""" - def run(self): - if not self.distribution.headers: - return - - for header in self.distribution.headers: - subdir = os.path.dirname(os.path.relpath(header, 'include/pybind11')) - install_dir = os.path.join(self.install_dir, subdir) - self.mkpath(install_dir) - - (out, _) = self.copy_file(header, install_dir) - self.outfiles.append(out) - - -setup( - name='pybind11', - version=__version__, - description='Seamless operability between C++11 and Python', - author='Wenzel Jakob', - author_email='wenzel.jakob@epfl.ch', - url='https://github.com/pybind/pybind11', - download_url='https://github.com/pybind/pybind11/tarball/v' + __version__, - packages=['pybind11'], - license='BSD', - headers=headers, - cmdclass=dict(install_headers=InstallHeaders), - classifiers=[ - 'Development Status :: 5 - Production/Stable', - 'Intended Audience :: Developers', - 'Topic :: Software Development :: Libraries :: Python Modules', - 'Topic :: Utilities', - 'Programming Language :: C++', - 'Programming Language :: Python :: 2.7', - 'Programming Language :: Python :: 3', - 'Programming Language :: Python :: 3.2', - 'Programming Language :: Python :: 3.3', - 'Programming Language :: Python :: 3.4', - 'Programming Language :: Python :: 3.5', - 'Programming Language :: Python :: 3.6', - 'License :: OSI Approved :: BSD License' - ], - keywords='C++11, Python bindings', - long_description="""pybind11 is a lightweight header-only library that -exposes C++ types in Python and vice versa, mainly to create Python bindings of -existing C++ code. Its goals and syntax are similar to the excellent -Boost.Python by David Abrahams: to minimize boilerplate code in traditional -extension modules by inferring type information using compile-time -introspection. - -The main issue with Boost.Python-and the reason for creating such a similar -project-is Boost. Boost is an enormously large and complex suite of utility -libraries that works with almost every C++ compiler in existence. This -compatibility has its cost: arcane template tricks and workarounds are -necessary to support the oldest and buggiest of compiler specimens. Now that -C++11-compatible compilers are widely available, this heavy machinery has -become an excessively large and unnecessary dependency. - -Think of this library as a tiny self-contained version of Boost.Python with -everything stripped away that isn't relevant for binding generation. Without -comments, the core header files only require ~4K lines of code and depend on -Python (2.7 or 3.x, or PyPy2.7 >= 5.7) and the C++ standard library. This -compact implementation was possible thanks to some of the new C++11 language -features (specifically: tuples, lambda functions and variadic templates). Since -its creation, this library has grown beyond Boost.Python in many ways, leading -to dramatically simpler binding code in many common situations.""") +import setuptools.command.sdist + +DIR = os.path.abspath(os.path.dirname(__file__)) +VERSION_REGEX = re.compile( + r"^\s*#\s*define\s+PYBIND11_VERSION_([A-Z]+)\s+(.*)$", re.MULTILINE +) + +# PYBIND11_GLOBAL_SDIST will build a different sdist, with the python-headers +# files, and the sys.prefix files (CMake and headers). + +global_sdist = os.environ.get("PYBIND11_GLOBAL_SDIST", False) + +setup_py = "tools/setup_global.py.in" if global_sdist else "tools/setup_main.py.in" +extra_cmd = 'cmdclass["sdist"] = SDist\n' + +to_src = ( + ("pyproject.toml", "tools/pyproject.toml"), + ("setup.py", setup_py), +) + +# Read the listed version +with open("pybind11/_version.py") as f: + code = compile(f.read(), "pybind11/_version.py", "exec") +loc = {} +exec(code, loc) +version = loc["__version__"] + +# Verify that the version matches the one in C++ +with open("include/pybind11/detail/common.h") as f: + matches = dict(VERSION_REGEX.findall(f.read())) +cpp_version = "{MAJOR}.{MINOR}.{PATCH}".format(**matches) +if version != cpp_version: + msg = "Python version {} does not match C++ version {}!".format( + version, cpp_version + ) + raise RuntimeError(msg) + + +def get_and_replace(filename, binary=False, **opts): + with open(filename, "rb" if binary else "r") as f: + contents = f.read() + # Replacement has to be done on text in Python 3 (both work in Python 2) + if binary: + return string.Template(contents.decode()).substitute(opts).encode() + else: + return string.Template(contents).substitute(opts) + + +# Use our input files instead when making the SDist (and anything that depends +# on it, like a wheel) +class SDist(setuptools.command.sdist.sdist): + def make_release_tree(self, base_dir, files): + setuptools.command.sdist.sdist.make_release_tree(self, base_dir, files) + + for to, src in to_src: + txt = get_and_replace(src, binary=True, version=version, extra_cmd="") + + dest = os.path.join(base_dir, to) + + # This is normally linked, so unlink before writing! + os.unlink(dest) + with open(dest, "wb") as f: + f.write(txt) + + +# Backport from Python 3 +@contextlib.contextmanager +def TemporaryDirectory(): # noqa: N802 + "Prepare a temporary directory, cleanup when done" + try: + tmpdir = tempfile.mkdtemp() + yield tmpdir + finally: + shutil.rmtree(tmpdir) + + +# Remove the CMake install directory when done +@contextlib.contextmanager +def remove_output(*sources): + try: + yield + finally: + for src in sources: + shutil.rmtree(src) + + +with remove_output("pybind11/include", "pybind11/share"): + # Generate the files if they are not present. + with TemporaryDirectory() as tmpdir: + cmd = ["cmake", "-S", ".", "-B", tmpdir] + [ + "-DCMAKE_INSTALL_PREFIX=pybind11", + "-DBUILD_TESTING=OFF", + "-DPYBIND11_NOPYTHON=ON", + ] + cmake_opts = dict(cwd=DIR, stdout=sys.stdout, stderr=sys.stderr) + subprocess.check_call(cmd, **cmake_opts) + subprocess.check_call(["cmake", "--install", tmpdir], **cmake_opts) + + txt = get_and_replace(setup_py, version=version, extra_cmd=extra_cmd) + code = compile(txt, setup_py, "exec") + exec(code, {"SDist": SDist}) diff --git a/plugins/python/pybind11/tests/CMakeLists.txt b/plugins/python/pybind11/tests/CMakeLists.txt index 25e0666..dae8b5a 100644 --- a/plugins/python/pybind11/tests/CMakeLists.txt +++ b/plugins/python/pybind11/tests/CMakeLists.txt @@ -5,80 +5,161 @@ # All rights reserved. Use of this source code is governed by a # BSD-style license that can be found in the LICENSE file. -cmake_minimum_required(VERSION 2.8.12) +cmake_minimum_required(VERSION 3.4) -option(PYBIND11_WERROR "Report all warnings as errors" OFF) +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) +endif() -if (CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR) - # We're being loaded directly, i.e. not via add_subdirectory, so make this - # work as its own project and load the pybind11Config to get the tools we need - project(pybind11_tests CXX) +# Only needed for CMake < 3.5 support +include(CMakeParseArguments) - find_package(pybind11 REQUIRED CONFIG) +# Filter out items; print an optional message if any items filtered +# +# Usage: +# pybind11_filter_tests(LISTNAME file1.cpp file2.cpp ... MESSAGE "") +# +macro(PYBIND11_FILTER_TESTS LISTNAME) + cmake_parse_arguments(ARG "" "MESSAGE" "" ${ARGN}) + set(PYBIND11_FILTER_TESTS_FOUND OFF) + foreach(filename IN LISTS ARG_UNPARSED_ARGUMENTS) + list(FIND ${LISTNAME} ${filename} _FILE_FOUND) + if(_FILE_FOUND GREATER -1) + list(REMOVE_AT ${LISTNAME} ${_FILE_FOUND}) + set(PYBIND11_FILTER_TESTS_FOUND ON) + endif() + endforeach() + if(PYBIND11_FILTER_TESTS_FOUND AND ARG_MESSAGE) + message(STATUS "${ARG_MESSAGE}") + endif() +endmacro() + +# New Python support +if(DEFINED Python_EXECUTABLE) + set(PYTHON_EXECUTABLE "${Python_EXECUTABLE}") + set(PYTHON_VERSION "${Python_VERSION}") +endif() + +# There's no harm in including a project in a project +project(pybind11_tests CXX) + +# Access FindCatch and more +list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/../tools") + +option(PYBIND11_WERROR "Report all warnings as errors" OFF) +option(DOWNLOAD_EIGEN "Download EIGEN (requires CMake 3.11+)" OFF) +option(PYBIND11_CUDA_TESTS "Enable building CUDA tests (requires CMake 3.12+)" OFF) +set(PYBIND11_TEST_OVERRIDE + "" + CACHE STRING "Tests from ;-separated list of *.cpp files will be built instead of all tests") +set(PYBIND11_TEST_FILTER + "" + CACHE STRING "Tests from ;-separated list of *.cpp files will be removed from all tests") + +if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR) + # We're being loaded directly, i.e. not via add_subdirectory, so make this + # work as its own project and load the pybind11Config to get the tools we need + find_package(pybind11 REQUIRED CONFIG) endif() if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) message(STATUS "Setting tests build type to MinSizeRel as none was specified") - set(CMAKE_BUILD_TYPE MinSizeRel CACHE STRING "Choose the type of build." FORCE) - set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug" "Release" - "MinSizeRel" "RelWithDebInfo") + set(CMAKE_BUILD_TYPE + MinSizeRel + CACHE STRING "Choose the type of build." FORCE) + set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug" "Release" "MinSizeRel" + "RelWithDebInfo") +endif() + +if(PYBIND11_CUDA_TESTS) + enable_language(CUDA) + if(DEFINED CMAKE_CXX_STANDARD) + set(CMAKE_CUDA_STANDARD ${CMAKE_CXX_STANDARD}) + endif() + set(CMAKE_CUDA_STANDARD_REQUIRED ON) endif() # Full set of test files (you can override these; see below) set(PYBIND11_TEST_FILES - test_buffers.cpp - test_builtin_casters.cpp - test_call_policies.cpp - test_callbacks.cpp - test_chrono.cpp - test_class.cpp - test_constants_and_functions.cpp - test_copy_move.cpp - test_docstring_options.cpp - test_eigen.cpp - test_enum.cpp - test_eval.cpp - test_exceptions.cpp - test_factory_constructors.cpp - test_iostream.cpp - test_kwargs_and_defaults.cpp - test_local_bindings.cpp - test_methods_and_attributes.cpp - test_modules.cpp - test_multiple_inheritance.cpp - test_numpy_array.cpp - test_numpy_dtypes.cpp - test_numpy_vectorize.cpp - test_opaque_types.cpp - test_operator_overloading.cpp - test_pickling.cpp - test_pytypes.cpp - test_sequences_and_iterators.cpp - test_smart_ptr.cpp - test_stl.cpp - test_stl_binders.cpp - test_virtual_functions.cpp -) + test_async.cpp + test_buffers.cpp + test_builtin_casters.cpp + test_call_policies.cpp + test_callbacks.cpp + test_chrono.cpp + test_class.cpp + test_constants_and_functions.cpp + test_copy_move.cpp + test_custom_type_casters.cpp + test_docstring_options.cpp + test_eigen.cpp + test_enum.cpp + test_eval.cpp + test_exceptions.cpp + test_factory_constructors.cpp + test_gil_scoped.cpp + test_iostream.cpp + test_kwargs_and_defaults.cpp + test_local_bindings.cpp + test_methods_and_attributes.cpp + test_modules.cpp + test_multiple_inheritance.cpp + test_numpy_array.cpp + test_numpy_dtypes.cpp + test_numpy_vectorize.cpp + test_opaque_types.cpp + test_operator_overloading.cpp + test_pickling.cpp + test_pytypes.cpp + test_sequences_and_iterators.cpp + test_smart_ptr.cpp + test_stl.cpp + test_stl_binders.cpp + test_tagbased_polymorphic.cpp + test_union.cpp + test_virtual_functions.cpp) # Invoking cmake with something like: -# cmake -DPYBIND11_TEST_OVERRIDE="test_callbacks.cpp;test_picking.cpp" .. +# cmake -DPYBIND11_TEST_OVERRIDE="test_callbacks.cpp;test_pickling.cpp" .. # lets you override the tests that get compiled and run. You can restore to all tests with: # cmake -DPYBIND11_TEST_OVERRIDE= .. -if (PYBIND11_TEST_OVERRIDE) +if(PYBIND11_TEST_OVERRIDE) set(PYBIND11_TEST_FILES ${PYBIND11_TEST_OVERRIDE}) endif() +# You can also filter tests: +if(PYBIND11_TEST_FILTER) + pybind11_filter_tests(PYBIND11_TEST_FILES ${PYBIND11_TEST_FILTER}) +endif() + +if(PYTHON_VERSION VERSION_LESS 3.5) + pybind11_filter_tests(PYBIND11_TEST_FILES test_async.cpp MESSAGE + "Skipping test_async on Python 2") +endif() + +# Skip tests for CUDA check: +# /pybind11/tests/test_constants_and_functions.cpp(125): +# error: incompatible exception specifications +if(PYBIND11_CUDA_TESTS) + pybind11_filter_tests( + PYBIND11_TEST_FILES test_constants_and_functions.cpp MESSAGE + "Skipping test_constants_and_functions due to incompatible exception specifications") +endif() + string(REPLACE ".cpp" ".py" PYBIND11_PYTEST_FILES "${PYBIND11_TEST_FILES}") # Contains the set of test files that require pybind11_cross_module_tests to be # built; if none of these are built (i.e. because TEST_OVERRIDE is used and # doesn't include them) the second module doesn't get built. -set(PYBIND11_CROSS_MODULE_TESTS - test_exceptions.py - test_local_bindings.py - test_stl.py - test_stl_binders.py -) +set(PYBIND11_CROSS_MODULE_TESTS test_exceptions.py test_local_bindings.py test_stl.py + test_stl_binders.py) + +set(PYBIND11_CROSS_MODULE_GIL_TESTS test_gil_scoped.py) # Check if Eigen is available; if not, remove from PYBIND11_TEST_FILES (but # keep it in PYBIND11_PYTEST_FILES, so that we get the "eigen is not installed" @@ -88,21 +169,45 @@ if(PYBIND11_TEST_FILES_EIGEN_I GREATER -1) # Try loading via newer Eigen's Eigen3Config first (bypassing tools/FindEigen3.cmake). # Eigen 3.3.1+ exports a cmake 3.0+ target for handling dependency requirements, but also # produces a fatal error if loaded from a pre-3.0 cmake. - if (NOT CMAKE_VERSION VERSION_LESS 3.0) - find_package(Eigen3 QUIET CONFIG) - if (EIGEN3_FOUND) - if (EIGEN3_VERSION_STRING AND NOT EIGEN3_VERSION_STRING VERSION_LESS 3.3.1) - set(PYBIND11_EIGEN_VIA_TARGET 1) - endif() + if(DOWNLOAD_EIGEN) + if(CMAKE_VERSION VERSION_LESS 3.11) + message(FATAL_ERROR "CMake 3.11+ required when using DOWNLOAD_EIGEN") + endif() + + set(EIGEN3_VERSION_STRING "3.3.8") + + include(FetchContent) + FetchContent_Declare( + eigen + GIT_REPOSITORY https://gitlab.com/libeigen/eigen.git + GIT_TAG ${EIGEN3_VERSION_STRING}) + + FetchContent_GetProperties(eigen) + if(NOT eigen_POPULATED) + message(STATUS "Downloading Eigen") + FetchContent_Populate(eigen) + endif() + + set(EIGEN3_INCLUDE_DIR ${eigen_SOURCE_DIR}) + set(EIGEN3_FOUND TRUE) + + else() + find_package(Eigen3 3.2.7 QUIET CONFIG) + + if(NOT EIGEN3_FOUND) + # Couldn't load via target, so fall back to allowing module mode finding, which will pick up + # tools/FindEigen3.cmake + find_package(Eigen3 3.2.7 QUIET) endif() - endif() - if (NOT EIGEN3_FOUND) - # Couldn't load via target, so fall back to allowing module mode finding, which will pick up - # tools/FindEigen3.cmake - find_package(Eigen3 QUIET) endif() if(EIGEN3_FOUND) + if(NOT TARGET Eigen3::Eigen) + add_library(Eigen3::Eigen IMPORTED INTERFACE) + set_property(TARGET Eigen3::Eigen PROPERTY INTERFACE_INCLUDE_DIRECTORIES + "${EIGEN3_INCLUDE_DIR}") + endif() + # Eigen 3.3.1+ cmake sets EIGEN3_VERSION_STRING (and hard codes the version when installed # rather than looking it up in the cmake script); older versions, and the # tools/FindEigen3.cmake, set EIGEN3_VERSION instead. @@ -112,28 +217,63 @@ if(PYBIND11_TEST_FILES_EIGEN_I GREATER -1) message(STATUS "Building tests with Eigen v${EIGEN3_VERSION}") else() list(REMOVE_AT PYBIND11_TEST_FILES ${PYBIND11_TEST_FILES_EIGEN_I}) - message(STATUS "Building tests WITHOUT Eigen") + message(STATUS "Building tests WITHOUT Eigen, use -DDOWNLOAD_EIGEN on CMake 3.11+ to download") endif() endif() # Optional dependency for some tests (boost::variant is only supported with version >= 1.56) find_package(Boost 1.56) +if(Boost_FOUND) + if(NOT TARGET Boost::headers) + add_library(Boost::headers IMPORTED INTERFACE) + if(TARGET Boost::boost) + # Classic FindBoost + set_property(TARGET Boost::boost PROPERTY INTERFACE_LINK_LIBRARIES Boost::boost) + else() + # Very old FindBoost, or newer Boost than CMake in older CMakes + set_property(TARGET Boost::headers PROPERTY INTERFACE_INCLUDE_DIRECTORIES + ${Boost_INCLUDE_DIRS}) + endif() + endif() +endif() + # Compile with compiler warnings turned on function(pybind11_enable_warnings target_name) if(MSVC) target_compile_options(${target_name} PRIVATE /W4) - else() - target_compile_options(${target_name} PRIVATE -Wall -Wextra -Wconversion -Wcast-qual) + elseif(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Intel|Clang)" AND NOT PYBIND11_CUDA_TESTS) + target_compile_options( + ${target_name} + PRIVATE -Wall + -Wextra + -Wconversion + -Wcast-qual + -Wdeprecated + -Wundef + -Wnon-virtual-dtor) endif() if(PYBIND11_WERROR) if(MSVC) target_compile_options(${target_name} PRIVATE /WX) - else() + elseif(PYBIND11_CUDA_TESTS) + target_compile_options(${target_name} PRIVATE "SHELL:-Werror all-warnings") + elseif(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Intel|Clang)") target_compile_options(${target_name} PRIVATE -Werror) endif() endif() + + # Needs to be readded since the ordering requires these to be after the ones above + if(CMAKE_CXX_STANDARD + AND CMAKE_CXX_COMPILER_ID MATCHES "Clang" + AND PYTHON_VERSION VERSION_LESS 3.0) + if(CMAKE_CXX_STANDARD LESS 17) + target_compile_options(${target_name} PUBLIC -Wno-deprecated-register) + else() + target_compile_options(${target_name} PUBLIC -Wno-register) + endif() + endif() endfunction() set(test_targets pybind11_tests) @@ -141,78 +281,109 @@ set(test_targets pybind11_tests) # Build pybind11_cross_module_tests if any test_whatever.py are being built that require it foreach(t ${PYBIND11_CROSS_MODULE_TESTS}) list(FIND PYBIND11_PYTEST_FILES ${t} i) - if (i GREATER -1) + if(i GREATER -1) list(APPEND test_targets pybind11_cross_module_tests) break() endif() endforeach() -set(testdir ${CMAKE_CURRENT_SOURCE_DIR}) +foreach(t ${PYBIND11_CROSS_MODULE_GIL_TESTS}) + list(FIND PYBIND11_PYTEST_FILES ${t} i) + if(i GREATER -1) + list(APPEND test_targets cross_module_gil_utils) + break() + endif() +endforeach() + +# Support CUDA testing by forcing the target file to compile with NVCC +if(PYBIND11_CUDA_TESTS) + set_property(SOURCE ${PYBIND11_TEST_FILES} PROPERTY LANGUAGE CUDA) +endif() + foreach(target ${test_targets}) set(test_files ${PYBIND11_TEST_FILES}) - if(NOT target STREQUAL "pybind11_tests") + if(NOT "${target}" STREQUAL "pybind11_tests") set(test_files "") endif() + # Support CUDA testing by forcing the target file to compile with NVCC + if(PYBIND11_CUDA_TESTS) + set_property(SOURCE ${target}.cpp PROPERTY LANGUAGE CUDA) + endif() + # Create the binding library pybind11_add_module(${target} THIN_LTO ${target}.cpp ${test_files} ${PYBIND11_HEADERS}) pybind11_enable_warnings(${target}) + if(NOT CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR) + get_property( + suffix + TARGET ${target} + PROPERTY SUFFIX) + set(source_output "${CMAKE_CURRENT_SOURCE_DIR}/${target}${suffix}") + if(suffix AND EXISTS "${source_output}") + message(WARNING "Output file also in source directory; " + "please remove to avoid confusion: ${source_output}") + endif() + endif() + if(MSVC) target_compile_options(${target} PRIVATE /utf-8) endif() if(EIGEN3_FOUND) - if (PYBIND11_EIGEN_VIA_TARGET) - target_link_libraries(${target} PRIVATE Eigen3::Eigen) - else() - target_include_directories(${target} PRIVATE ${EIGEN3_INCLUDE_DIR}) - endif() + target_link_libraries(${target} PRIVATE Eigen3::Eigen) target_compile_definitions(${target} PRIVATE -DPYBIND11_TEST_EIGEN) endif() if(Boost_FOUND) - target_include_directories(${target} PRIVATE ${Boost_INCLUDE_DIRS}) + target_link_libraries(${target} PRIVATE Boost::headers) target_compile_definitions(${target} PRIVATE -DPYBIND11_TEST_BOOST) endif() # Always write the output file directly into the 'tests' directory (even on MSVC) if(NOT CMAKE_LIBRARY_OUTPUT_DIRECTORY) - set_target_properties(${target} PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${testdir}) + set_target_properties(${target} PROPERTIES LIBRARY_OUTPUT_DIRECTORY + "${CMAKE_CURRENT_BINARY_DIR}") foreach(config ${CMAKE_CONFIGURATION_TYPES}) string(TOUPPER ${config} config) - set_target_properties(${target} PROPERTIES LIBRARY_OUTPUT_DIRECTORY_${config} ${testdir}) + set_target_properties(${target} PROPERTIES LIBRARY_OUTPUT_DIRECTORY_${config} + "${CMAKE_CURRENT_BINARY_DIR}") endforeach() endif() endforeach() -# Make sure pytest is found or produce a fatal error -if(NOT PYBIND11_PYTEST_FOUND) - execute_process(COMMAND ${PYTHON_EXECUTABLE} -c "import pytest; print(pytest.__version__)" - RESULT_VARIABLE pytest_not_found OUTPUT_VARIABLE pytest_version ERROR_QUIET) - if(pytest_not_found) - message(FATAL_ERROR "Running the tests requires pytest. Please install it manually" - " (try: ${PYTHON_EXECUTABLE} -m pip install pytest)") - elseif(pytest_version VERSION_LESS 3.0) - message(FATAL_ERROR "Running the tests requires pytest >= 3.0. Found: ${pytest_version}" - "Please update it (try: ${PYTHON_EXECUTABLE} -m pip install -U pytest)") - endif() - set(PYBIND11_PYTEST_FOUND TRUE CACHE INTERNAL "") -endif() +# Make sure pytest is found or produce a warning +pybind11_find_import(pytest VERSION 3.1) + +if(NOT CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR) + # This is not used later in the build, so it's okay to regenerate each time. + configure_file("${CMAKE_CURRENT_SOURCE_DIR}/pytest.ini" "${CMAKE_CURRENT_BINARY_DIR}/pytest.ini" + COPYONLY) + file(APPEND "${CMAKE_CURRENT_BINARY_DIR}/pytest.ini" + "\ntestpaths = \"${CMAKE_CURRENT_SOURCE_DIR}\"") -if(CMAKE_VERSION VERSION_LESS 3.2) - set(PYBIND11_USES_TERMINAL "") -else() - set(PYBIND11_USES_TERMINAL "USES_TERMINAL") endif() +# cmake 3.12 added list(transform prepend +# but we can't use it yet +string(REPLACE "test_" "${CMAKE_CURRENT_SOURCE_DIR}/test_" PYBIND11_ABS_PYTEST_FILES + "${PYBIND11_PYTEST_FILES}") + # A single command to compile and run the tests -add_custom_target(pytest COMMAND ${PYTHON_EXECUTABLE} -m pytest ${PYBIND11_PYTEST_FILES} - DEPENDS ${test_targets} WORKING_DIRECTORY ${testdir} ${PYBIND11_USES_TERMINAL}) +add_custom_target( + pytest + COMMAND ${PYTHON_EXECUTABLE} -m pytest ${PYBIND11_ABS_PYTEST_FILES} + DEPENDS ${test_targets} + WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR} + USES_TERMINAL) if(PYBIND11_TEST_OVERRIDE) - add_custom_command(TARGET pytest POST_BUILD - COMMAND ${CMAKE_COMMAND} -E echo "Note: not all tests run: -DPYBIND11_TEST_OVERRIDE is in effect") + add_custom_command( + TARGET pytest + POST_BUILD + COMMAND ${CMAKE_COMMAND} -E echo + "Note: not all tests run: -DPYBIND11_TEST_OVERRIDE is in effect") endif() # Add a check target to run all the tests, starting with pytest (we add dependencies to this below) @@ -220,17 +391,23 @@ add_custom_target(check DEPENDS pytest) # The remaining tests only apply when being built as part of the pybind11 project, but not if the # tests are being built independently. -if (NOT PROJECT_NAME STREQUAL "pybind11") +if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR) return() endif() # Add a post-build comment to show the primary test suite .so size and, if a previous size, compare it: -add_custom_command(TARGET pybind11_tests POST_BUILD - COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/libsize.py - $ ${CMAKE_CURRENT_BINARY_DIR}/sosize-$.txt) +add_custom_command( + TARGET pybind11_tests + POST_BUILD + COMMAND + ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/../tools/libsize.py + $ + ${CMAKE_CURRENT_BINARY_DIR}/sosize-$.txt) -# Test embedding the interpreter. Provides the `cpptest` target. -add_subdirectory(test_embed) +if(NOT PYBIND11_CUDA_TESTS) + # Test embedding the interpreter. Provides the `cpptest` target. + add_subdirectory(test_embed) -# Test CMake build using functions and targets from subdirectory or installed location -add_subdirectory(test_cmake_build) + # Test CMake build using functions and targets from subdirectory or installed location + add_subdirectory(test_cmake_build) +endif() diff --git a/plugins/python/pybind11/tests/conftest.py b/plugins/python/pybind11/tests/conftest.py index f4c2282..362eb80 100644 --- a/plugins/python/pybind11/tests/conftest.py +++ b/plugins/python/pybind11/tests/conftest.py @@ -1,26 +1,36 @@ +# -*- coding: utf-8 -*- """pytest configuration Extends output capture as needed by pybind11: ignore constructors, optional unordered lines. Adds docstring and exceptions message sanitizers: ignore Python 2 vs 3 differences. """ -import pytest -import textwrap -import difflib -import re -import sys import contextlib -import platform +import difflib import gc +import re +import textwrap + +import pytest + +import env -_unicode_marker = re.compile(r'u(\'[^\']*\')') -_long_marker = re.compile(r'([0-9])L') -_hexadecimal = re.compile(r'0x[0-9a-fA-F]+') +# Early diagnostic for failed imports +import pybind11_tests # noqa: F401 + +_unicode_marker = re.compile(r"u(\'[^\']*\')") +_long_marker = re.compile(r"([0-9])L") +_hexadecimal = re.compile(r"0x[0-9a-fA-F]+") + +# Avoid collecting Python3 only files +collect_ignore = [] +if env.PY2: + collect_ignore.append("test_async.py") def _strip_and_dedent(s): """For triple-quote strings""" - return textwrap.dedent(s.lstrip('\n').rstrip()) + return textwrap.dedent(s.lstrip("\n").rstrip()) def _split_and_sort(s): @@ -30,11 +40,14 @@ def _split_and_sort(s): def _make_explanation(a, b): """Explanation for a failed assert -- the a and b arguments are List[str]""" - return ["--- actual / +++ expected"] + [line.strip('\n') for line in difflib.ndiff(a, b)] + return ["--- actual / +++ expected"] + [ + line.strip("\n") for line in difflib.ndiff(a, b) + ] class Output(object): """Basic output post-processing and comparison""" + def __init__(self, string): self.string = string self.explanation = [] @@ -44,7 +57,11 @@ def __str__(self): def __eq__(self, other): # Ignore constructor/destructor output which is prefixed with "###" - a = [line for line in self.string.strip().splitlines() if not line.startswith("###")] + a = [ + line + for line in self.string.strip().splitlines() + if not line.startswith("###") + ] b = _strip_and_dedent(other).splitlines() if a == b: return True @@ -55,6 +72,7 @@ def __eq__(self, other): class Unordered(Output): """Custom comparison for output without strict line ordering""" + def __eq__(self, other): a = _split_and_sort(self.string) b = _split_and_sort(other) @@ -75,7 +93,7 @@ def __enter__(self): self.capfd.readouterr() return self - def __exit__(self, *_): + def __exit__(self, *args): self.out, self.err = self.capfd.readouterr() def __eq__(self, other): @@ -165,7 +183,7 @@ def msg(): # noinspection PyUnusedLocal def pytest_assertrepr_compare(op, left, right): """Hook to insert custom failure explanation""" - if hasattr(left, 'explanation'): + if hasattr(left, "explanation"): return left.explanation @@ -179,63 +197,12 @@ def suppress(exception): def gc_collect(): - ''' Run the garbage collector twice (needed when running - reference counting tests with PyPy) ''' + """Run the garbage collector twice (needed when running + reference counting tests with PyPy)""" gc.collect() gc.collect() -def pytest_namespace(): - """Add import suppression and test requirements to `pytest` namespace""" - try: - import numpy as np - except ImportError: - np = None - try: - import scipy - except ImportError: - scipy = None - try: - from pybind11_tests.eigen import have_eigen - except ImportError: - have_eigen = False - pypy = platform.python_implementation() == "PyPy" - - skipif = pytest.mark.skipif - return { - 'suppress': suppress, - 'requires_numpy': skipif(not np, reason="numpy is not installed"), - 'requires_scipy': skipif(not np, reason="scipy is not installed"), - 'requires_eigen_and_numpy': skipif(not have_eigen or not np, - reason="eigen and/or numpy are not installed"), - 'requires_eigen_and_scipy': skipif(not have_eigen or not scipy, - reason="eigen and/or scipy are not installed"), - 'unsupported_on_pypy': skipif(pypy, reason="unsupported on PyPy"), - 'unsupported_on_py2': skipif(sys.version_info.major < 3, - reason="unsupported on Python 2.x"), - 'gc_collect': gc_collect - } - - -def _test_import_pybind11(): - """Early diagnostic for test module initialization errors - - When there is an error during initialization, the first import will report the - real error while all subsequent imports will report nonsense. This import test - is done early (in the pytest configuration file, before any tests) in order to - avoid the noise of having all tests fail with identical error messages. - - Any possible exception is caught here and reported manually *without* the stack - trace. This further reduces noise since the trace would only show pytest internals - which are not useful for debugging pybind11 module issues. - """ - # noinspection PyBroadException - try: - import pybind11_tests # noqa: F401 imported but unused - except Exception as e: - print("Failed to import pybind11_tests from pytest:") - print(" {}: {}".format(type(e).__name__, e)) - sys.exit(1) - - -_test_import_pybind11() +def pytest_configure(): + pytest.suppress = suppress + pytest.gc_collect = gc_collect diff --git a/plugins/python/pybind11/tests/constructor_stats.h b/plugins/python/pybind11/tests/constructor_stats.h index babded0..805968a 100644 --- a/plugins/python/pybind11/tests/constructor_stats.h +++ b/plugins/python/pybind11/tests/constructor_stats.h @@ -120,7 +120,7 @@ class ConstructorStats { throw py::error_already_set(); Py_DECREF(result); #else - py::module::import("gc").attr("collect")(); + py::module_::import("gc").attr("collect")(); #endif } @@ -180,7 +180,7 @@ class ConstructorStats { } } } - catch (std::out_of_range) {} + catch (const std::out_of_range&) {} if (!t1) throw std::runtime_error("Unknown class passed to ConstructorStats::get()"); auto &cs1 = get(*t1); // If we have both a t1 and t2 match, one is probably the trampoline class; return whichever @@ -273,4 +273,3 @@ template void print_values(T *inst, Values &&...va print_constr_details(inst, ":", values...); track_values(inst, values...); } - diff --git a/plugins/python/pybind11/tests/cross_module_gil_utils.cpp b/plugins/python/pybind11/tests/cross_module_gil_utils.cpp new file mode 100644 index 0000000..07db9f6 --- /dev/null +++ b/plugins/python/pybind11/tests/cross_module_gil_utils.cpp @@ -0,0 +1,73 @@ +/* + tests/cross_module_gil_utils.cpp -- tools for acquiring GIL from a different module + + Copyright (c) 2019 Google LLC + + All rights reserved. Use of this source code is governed by a + BSD-style license that can be found in the LICENSE file. +*/ +#include +#include + +// This file mimics a DSO that makes pybind11 calls but does not define a +// PYBIND11_MODULE. The purpose is to test that such a DSO can create a +// py::gil_scoped_acquire when the running thread is in a GIL-released state. +// +// Note that we define a Python module here for convenience, but in general +// this need not be the case. The typical scenario would be a DSO that implements +// shared logic used internally by multiple pybind11 modules. + +namespace { + +namespace py = pybind11; +void gil_acquire() { py::gil_scoped_acquire gil; } + +constexpr char kModuleName[] = "cross_module_gil_utils"; + +#if PY_MAJOR_VERSION >= 3 +struct PyModuleDef moduledef = { + PyModuleDef_HEAD_INIT, + kModuleName, + NULL, + 0, + NULL, + NULL, + NULL, + NULL, + NULL +}; +#else +PyMethodDef module_methods[] = { + {NULL, NULL, 0, NULL} +}; +#endif + +} // namespace + +extern "C" PYBIND11_EXPORT +#if PY_MAJOR_VERSION >= 3 +PyObject* PyInit_cross_module_gil_utils() +#else +void initcross_module_gil_utils() +#endif +{ + + PyObject* m = +#if PY_MAJOR_VERSION >= 3 + PyModule_Create(&moduledef); +#else + Py_InitModule(kModuleName, module_methods); +#endif + + if (m != NULL) { + static_assert( + sizeof(&gil_acquire) == sizeof(void*), + "Function pointer must have the same size as void*"); + PyModule_AddObject(m, "gil_acquire_funcaddr", + PyLong_FromVoidPtr(reinterpret_cast(&gil_acquire))); + } + +#if PY_MAJOR_VERSION >= 3 + return m; +#endif +} diff --git a/plugins/python/pybind11/tests/env.py b/plugins/python/pybind11/tests/env.py new file mode 100644 index 0000000..5cded44 --- /dev/null +++ b/plugins/python/pybind11/tests/env.py @@ -0,0 +1,14 @@ +# -*- coding: utf-8 -*- +import platform +import sys + +LINUX = sys.platform.startswith("linux") +MACOS = sys.platform.startswith("darwin") +WIN = sys.platform.startswith("win32") or sys.platform.startswith("cygwin") + +CPYTHON = platform.python_implementation() == "CPython" +PYPY = platform.python_implementation() == "PyPy" + +PY2 = sys.version_info.major == 2 + +PY = sys.version_info diff --git a/plugins/python/pybind11/tests/extra_python_package/pytest.ini b/plugins/python/pybind11/tests/extra_python_package/pytest.ini new file mode 100644 index 0000000..e69de29 diff --git a/plugins/python/pybind11/tests/extra_python_package/test_files.py b/plugins/python/pybind11/tests/extra_python_package/test_files.py new file mode 100644 index 0000000..cbd4bff --- /dev/null +++ b/plugins/python/pybind11/tests/extra_python_package/test_files.py @@ -0,0 +1,262 @@ +# -*- coding: utf-8 -*- +import contextlib +import os +import string +import subprocess +import sys +import tarfile +import zipfile + +# These tests must be run explicitly +# They require CMake 3.15+ (--install) + +DIR = os.path.abspath(os.path.dirname(__file__)) +MAIN_DIR = os.path.dirname(os.path.dirname(DIR)) + + +main_headers = { + "include/pybind11/attr.h", + "include/pybind11/buffer_info.h", + "include/pybind11/cast.h", + "include/pybind11/chrono.h", + "include/pybind11/common.h", + "include/pybind11/complex.h", + "include/pybind11/eigen.h", + "include/pybind11/embed.h", + "include/pybind11/eval.h", + "include/pybind11/functional.h", + "include/pybind11/iostream.h", + "include/pybind11/numpy.h", + "include/pybind11/operators.h", + "include/pybind11/options.h", + "include/pybind11/pybind11.h", + "include/pybind11/pytypes.h", + "include/pybind11/stl.h", + "include/pybind11/stl_bind.h", +} + +detail_headers = { + "include/pybind11/detail/class.h", + "include/pybind11/detail/common.h", + "include/pybind11/detail/descr.h", + "include/pybind11/detail/init.h", + "include/pybind11/detail/internals.h", + "include/pybind11/detail/typeid.h", +} + +cmake_files = { + "share/cmake/pybind11/FindPythonLibsNew.cmake", + "share/cmake/pybind11/pybind11Common.cmake", + "share/cmake/pybind11/pybind11Config.cmake", + "share/cmake/pybind11/pybind11ConfigVersion.cmake", + "share/cmake/pybind11/pybind11NewTools.cmake", + "share/cmake/pybind11/pybind11Targets.cmake", + "share/cmake/pybind11/pybind11Tools.cmake", +} + +py_files = { + "__init__.py", + "__main__.py", + "_version.py", + "_version.pyi", + "commands.py", + "py.typed", + "setup_helpers.py", + "setup_helpers.pyi", +} + +headers = main_headers | detail_headers +src_files = headers | cmake_files +all_files = src_files | py_files + + +sdist_files = { + "pybind11", + "pybind11/include", + "pybind11/include/pybind11", + "pybind11/include/pybind11/detail", + "pybind11/share", + "pybind11/share/cmake", + "pybind11/share/cmake/pybind11", + "pyproject.toml", + "setup.cfg", + "setup.py", + "LICENSE", + "MANIFEST.in", + "README.rst", + "PKG-INFO", +} + +local_sdist_files = { + ".egg-info", + ".egg-info/PKG-INFO", + ".egg-info/SOURCES.txt", + ".egg-info/dependency_links.txt", + ".egg-info/not-zip-safe", + ".egg-info/top_level.txt", +} + + +def test_build_sdist(monkeypatch, tmpdir): + + monkeypatch.chdir(MAIN_DIR) + + out = subprocess.check_output( + [ + sys.executable, + "setup.py", + "sdist", + "--formats=tar", + "--dist-dir", + str(tmpdir), + ] + ) + if hasattr(out, "decode"): + out = out.decode() + + (sdist,) = tmpdir.visit("*.tar") + + with tarfile.open(str(sdist)) as tar: + start = tar.getnames()[0] + "/" + version = start[9:-1] + simpler = set(n.split("/", 1)[-1] for n in tar.getnames()[1:]) + + with contextlib.closing( + tar.extractfile(tar.getmember(start + "setup.py")) + ) as f: + setup_py = f.read() + + with contextlib.closing( + tar.extractfile(tar.getmember(start + "pyproject.toml")) + ) as f: + pyproject_toml = f.read() + + files = set("pybind11/{}".format(n) for n in all_files) + files |= sdist_files + files |= set("pybind11{}".format(n) for n in local_sdist_files) + files.add("pybind11.egg-info/entry_points.txt") + files.add("pybind11.egg-info/requires.txt") + assert simpler == files + + with open(os.path.join(MAIN_DIR, "tools", "setup_main.py.in"), "rb") as f: + contents = ( + string.Template(f.read().decode()) + .substitute(version=version, extra_cmd="") + .encode() + ) + assert setup_py == contents + + with open(os.path.join(MAIN_DIR, "tools", "pyproject.toml"), "rb") as f: + contents = f.read() + assert pyproject_toml == contents + + +def test_build_global_dist(monkeypatch, tmpdir): + + monkeypatch.chdir(MAIN_DIR) + monkeypatch.setenv("PYBIND11_GLOBAL_SDIST", "1") + + out = subprocess.check_output( + [ + sys.executable, + "setup.py", + "sdist", + "--formats=tar", + "--dist-dir", + str(tmpdir), + ] + ) + if hasattr(out, "decode"): + out = out.decode() + + (sdist,) = tmpdir.visit("*.tar") + + with tarfile.open(str(sdist)) as tar: + start = tar.getnames()[0] + "/" + version = start[16:-1] + simpler = set(n.split("/", 1)[-1] for n in tar.getnames()[1:]) + + with contextlib.closing( + tar.extractfile(tar.getmember(start + "setup.py")) + ) as f: + setup_py = f.read() + + with contextlib.closing( + tar.extractfile(tar.getmember(start + "pyproject.toml")) + ) as f: + pyproject_toml = f.read() + + files = set("pybind11/{}".format(n) for n in all_files) + files |= sdist_files + files |= set("pybind11_global{}".format(n) for n in local_sdist_files) + assert simpler == files + + with open(os.path.join(MAIN_DIR, "tools", "setup_global.py.in"), "rb") as f: + contents = ( + string.Template(f.read().decode()) + .substitute(version=version, extra_cmd="") + .encode() + ) + assert setup_py == contents + + with open(os.path.join(MAIN_DIR, "tools", "pyproject.toml"), "rb") as f: + contents = f.read() + assert pyproject_toml == contents + + +def tests_build_wheel(monkeypatch, tmpdir): + monkeypatch.chdir(MAIN_DIR) + + subprocess.check_output( + [sys.executable, "-m", "pip", "wheel", ".", "-w", str(tmpdir)] + ) + + (wheel,) = tmpdir.visit("*.whl") + + files = set("pybind11/{}".format(n) for n in all_files) + files |= { + "dist-info/LICENSE", + "dist-info/METADATA", + "dist-info/RECORD", + "dist-info/WHEEL", + "dist-info/entry_points.txt", + "dist-info/top_level.txt", + } + + with zipfile.ZipFile(str(wheel)) as z: + names = z.namelist() + + trimmed = set(n for n in names if "dist-info" not in n) + trimmed |= set( + "dist-info/{}".format(n.split("/", 1)[-1]) for n in names if "dist-info" in n + ) + assert files == trimmed + + +def tests_build_global_wheel(monkeypatch, tmpdir): + monkeypatch.chdir(MAIN_DIR) + monkeypatch.setenv("PYBIND11_GLOBAL_SDIST", "1") + + subprocess.check_output( + [sys.executable, "-m", "pip", "wheel", ".", "-w", str(tmpdir)] + ) + + (wheel,) = tmpdir.visit("*.whl") + + files = set("data/data/{}".format(n) for n in src_files) + files |= set("data/headers/{}".format(n[8:]) for n in headers) + files |= { + "dist-info/LICENSE", + "dist-info/METADATA", + "dist-info/WHEEL", + "dist-info/top_level.txt", + "dist-info/RECORD", + } + + with zipfile.ZipFile(str(wheel)) as z: + names = z.namelist() + + beginning = names[0].split("/", 1)[0].rsplit(".", 1)[0] + trimmed = set(n[len(beginning) + 1 :] for n in names) + + assert files == trimmed diff --git a/plugins/python/pybind11/tests/extra_setuptools/pytest.ini b/plugins/python/pybind11/tests/extra_setuptools/pytest.ini new file mode 100644 index 0000000..e69de29 diff --git a/plugins/python/pybind11/tests/extra_setuptools/test_setuphelper.py b/plugins/python/pybind11/tests/extra_setuptools/test_setuphelper.py new file mode 100644 index 0000000..0d8bd0e --- /dev/null +++ b/plugins/python/pybind11/tests/extra_setuptools/test_setuphelper.py @@ -0,0 +1,101 @@ +# -*- coding: utf-8 -*- +import os +import sys +import subprocess +from textwrap import dedent + +import pytest + +DIR = os.path.abspath(os.path.dirname(__file__)) +MAIN_DIR = os.path.dirname(os.path.dirname(DIR)) + + +@pytest.mark.parametrize("parallel", [False, True]) +@pytest.mark.parametrize("std", [11, 0]) +def test_simple_setup_py(monkeypatch, tmpdir, parallel, std): + monkeypatch.chdir(tmpdir) + monkeypatch.syspath_prepend(MAIN_DIR) + + (tmpdir / "setup.py").write_text( + dedent( + u"""\ + import sys + sys.path.append({MAIN_DIR!r}) + + from setuptools import setup, Extension + from pybind11.setup_helpers import build_ext, Pybind11Extension + + std = {std} + + ext_modules = [ + Pybind11Extension( + "simple_setup", + sorted(["main.cpp"]), + cxx_std=std, + ), + ] + + cmdclass = dict() + if std == 0: + cmdclass["build_ext"] = build_ext + + + parallel = {parallel} + if parallel: + from pybind11.setup_helpers import ParallelCompile + ParallelCompile().install() + + setup( + name="simple_setup_package", + cmdclass=cmdclass, + ext_modules=ext_modules, + ) + """ + ).format(MAIN_DIR=MAIN_DIR, std=std, parallel=parallel), + encoding="ascii", + ) + + (tmpdir / "main.cpp").write_text( + dedent( + u"""\ + #include + + int f(int x) { + return x * 3; + } + PYBIND11_MODULE(simple_setup, m) { + m.def("f", &f); + } + """ + ), + encoding="ascii", + ) + + subprocess.check_call( + [sys.executable, "setup.py", "build_ext", "--inplace"], + stdout=sys.stdout, + stderr=sys.stderr, + ) + + # Debug helper printout, normally hidden + for item in tmpdir.listdir(): + print(item.basename) + + assert ( + len([f for f in tmpdir.listdir() if f.basename.startswith("simple_setup")]) == 1 + ) + assert len(list(tmpdir.listdir())) == 4 # two files + output + build_dir + + (tmpdir / "test.py").write_text( + dedent( + u"""\ + import simple_setup + assert simple_setup.f(3) == 9 + """ + ), + encoding="ascii", + ) + + subprocess.check_call( + [sys.executable, "test.py"], stdout=sys.stdout, stderr=sys.stderr + ) diff --git a/plugins/python/pybind11/tests/local_bindings.h b/plugins/python/pybind11/tests/local_bindings.h index b6afb80..22537b1 100644 --- a/plugins/python/pybind11/tests/local_bindings.h +++ b/plugins/python/pybind11/tests/local_bindings.h @@ -58,7 +58,7 @@ class Pet { std::string name_; const std::string &name() { return name_; } }; -} +} // namespace pets struct MixGL { int i; MixGL(int i) : i{i} {} }; struct MixGL2 { int i; MixGL2(int i) : i{i} {} }; diff --git a/plugins/python/pybind11/tests/pybind11_tests.cpp b/plugins/python/pybind11/tests/pybind11_tests.cpp index bc7d2c3..439cd40 100644 --- a/plugins/python/pybind11/tests/pybind11_tests.cpp +++ b/plugins/python/pybind11/tests/pybind11_tests.cpp @@ -26,23 +26,23 @@ productively. Instead, see the "How can I reduce the build time?" question in the "Frequently asked questions" section of the documentation for good practice on splitting binding code over multiple files. */ -std::list> &initializers() { - static std::list> inits; +std::list> &initializers() { + static std::list> inits; return inits; } test_initializer::test_initializer(Initializer init) { - initializers().push_back(init); + initializers().emplace_back(init); } test_initializer::test_initializer(const char *submodule_name, Initializer init) { - initializers().push_back([=](py::module &parent) { + initializers().emplace_back([=](py::module_ &parent) { auto m = parent.def_submodule(submodule_name); init(m); }); } -void bind_ConstructorStats(py::module &m) { +void bind_ConstructorStats(py::module_ &m) { py::class_(m, "ConstructorStats") .def("alive", &ConstructorStats::alive) .def("values", &ConstructorStats::values) @@ -88,6 +88,4 @@ PYBIND11_MODULE(pybind11_tests, m) { for (const auto &initializer : initializers()) initializer(m); - - if (!py::hasattr(m, "have_eigen")) m.attr("have_eigen") = false; } diff --git a/plugins/python/pybind11/tests/pybind11_tests.h b/plugins/python/pybind11/tests/pybind11_tests.h index 90963a5..4ff56c0 100644 --- a/plugins/python/pybind11/tests/pybind11_tests.h +++ b/plugins/python/pybind11/tests/pybind11_tests.h @@ -10,7 +10,7 @@ namespace py = pybind11; using namespace pybind11::literals; class test_initializer { - using Initializer = void (*)(py::module &); + using Initializer = void (*)(py::module_ &); public: test_initializer(Initializer init); @@ -18,9 +18,9 @@ class test_initializer { }; #define TEST_SUBMODULE(name, variable) \ - void test_submodule_##name(py::module &); \ + void test_submodule_##name(py::module_ &); \ test_initializer name(#name, test_submodule_##name); \ - void test_submodule_##name(py::module &variable) + void test_submodule_##name(py::module_ &variable) /// Dummy type which is not exported anywhere -- something to trigger a conversion error @@ -50,16 +50,22 @@ class IncType : public UserType { IncType &operator=(IncType &&) = delete; }; +/// A simple union for basic testing +union IntFloat { + int i; + float f; +}; + /// Custom cast-only type that casts to a string "rvalue" or "lvalue" depending on the cast context. /// Used to test recursive casters (e.g. std::tuple, stl containers). struct RValueCaster {}; -NAMESPACE_BEGIN(pybind11) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(pybind11) +PYBIND11_NAMESPACE_BEGIN(detail) template<> class type_caster { public: PYBIND11_TYPE_CASTER(RValueCaster, _("RValueCaster")); static handle cast(RValueCaster &&, return_value_policy, handle) { return py::str("rvalue").release(); } static handle cast(const RValueCaster &, return_value_policy, handle) { return py::str("lvalue").release(); } }; -NAMESPACE_END(detail) -NAMESPACE_END(pybind11) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(pybind11) diff --git a/plugins/python/pybind11/tests/pytest.ini b/plugins/python/pybind11/tests/pytest.ini index 1e44f0a..c47cbe9 100644 --- a/plugins/python/pybind11/tests/pytest.ini +++ b/plugins/python/pybind11/tests/pytest.ini @@ -1,11 +1,14 @@ [pytest] -minversion = 3.0 -norecursedirs = test_cmake_build test_embed +minversion = 3.1 +norecursedirs = test_* extra_* +xfail_strict = True addopts = # show summary of skipped tests -rs # capture only Python print and C++ py::print, but not C output (low-level Python errors) --capture=sys + # enable all warnings + -Wa filterwarnings = # make warnings into errors but ignore certain third-party extension issues error @@ -13,3 +16,4 @@ filterwarnings = ignore::ImportWarning # bogus numpy ABI warning (see numpy/#432) ignore:.*numpy.dtype size changed.*:RuntimeWarning + ignore:.*numpy.ufunc size changed.*:RuntimeWarning diff --git a/plugins/python/pybind11/tests/requirements.txt b/plugins/python/pybind11/tests/requirements.txt new file mode 100644 index 0000000..80ed617 --- /dev/null +++ b/plugins/python/pybind11/tests/requirements.txt @@ -0,0 +1,8 @@ +--extra-index-url https://antocuni.github.io/pypy-wheels/manylinux2010/ +numpy==1.16.6; python_version<"3.6" and sys_platform!="win32" +numpy==1.18.0; platform_python_implementation=="PyPy" and sys_platform=="darwin" and python_version>="3.6" +numpy==1.19.3; (platform_python_implementation!="PyPy" or sys_platform=="linux") and python_version>="3.6" and python_version<"3.10" +pytest==4.6.9; python_version<"3.5" +pytest==5.4.3; python_version>="3.5" +scipy==1.2.3; (platform_python_implementation!="PyPy" or sys_platform=="linux") and python_version<"3.6" +scipy==1.5.2; (platform_python_implementation!="PyPy" or sys_platform=="linux") and python_version>="3.6" and python_version<"3.9" diff --git a/plugins/python/pybind11/tests/test_async.cpp b/plugins/python/pybind11/tests/test_async.cpp new file mode 100644 index 0000000..e6e01d7 --- /dev/null +++ b/plugins/python/pybind11/tests/test_async.cpp @@ -0,0 +1,26 @@ +/* + tests/test_async.cpp -- __await__ support + + Copyright (c) 2019 Google Inc. + + All rights reserved. Use of this source code is governed by a + BSD-style license that can be found in the LICENSE file. +*/ + +#include "pybind11_tests.h" + +TEST_SUBMODULE(async_module, m) { + struct DoesNotSupportAsync {}; + py::class_(m, "DoesNotSupportAsync") + .def(py::init<>()); + struct SupportsAsync {}; + py::class_(m, "SupportsAsync") + .def(py::init<>()) + .def("__await__", [](const SupportsAsync& self) -> py::object { + static_cast(self); + py::object loop = py::module_::import("asyncio.events").attr("get_event_loop")(); + py::object f = loop.attr("create_future")(); + f.attr("set_result")(5); + return f.attr("__await__")(); + }); +} diff --git a/plugins/python/pybind11/tests/test_async.py b/plugins/python/pybind11/tests/test_async.py new file mode 100644 index 0000000..df4489c --- /dev/null +++ b/plugins/python/pybind11/tests/test_async.py @@ -0,0 +1,25 @@ +# -*- coding: utf-8 -*- +import pytest + +asyncio = pytest.importorskip("asyncio") +m = pytest.importorskip("pybind11_tests.async_module") + + +@pytest.fixture +def event_loop(): + loop = asyncio.new_event_loop() + yield loop + loop.close() + + +async def get_await_result(x): + return await x + + +def test_await(event_loop): + assert 5 == event_loop.run_until_complete(get_await_result(m.SupportsAsync())) + + +def test_await_missing(event_loop): + with pytest.raises(TypeError): + event_loop.run_until_complete(get_await_result(m.DoesNotSupportAsync())) diff --git a/plugins/python/pybind11/tests/test_buffers.cpp b/plugins/python/pybind11/tests/test_buffers.cpp index 5be7177..46eabf3 100644 --- a/plugins/python/pybind11/tests/test_buffers.cpp +++ b/plugins/python/pybind11/tests/test_buffers.cpp @@ -9,12 +9,13 @@ #include "pybind11_tests.h" #include "constructor_stats.h" +#include TEST_SUBMODULE(buffers, m) { // test_from_python / test_to_python: class Matrix { public: - Matrix(ssize_t rows, ssize_t cols) : m_rows(rows), m_cols(cols) { + Matrix(py::ssize_t rows, py::ssize_t cols) : m_rows(rows), m_cols(cols) { print_created(this, std::to_string(m_rows) + "x" + std::to_string(m_cols) + " matrix"); m_data = new float[(size_t) (rows*cols)]; memset(m_data, 0, sizeof(float) * (size_t) (rows * cols)); @@ -58,27 +59,27 @@ TEST_SUBMODULE(buffers, m) { return *this; } - float operator()(ssize_t i, ssize_t j) const { + float operator()(py::ssize_t i, py::ssize_t j) const { return m_data[(size_t) (i*m_cols + j)]; } - float &operator()(ssize_t i, ssize_t j) { + float &operator()(py::ssize_t i, py::ssize_t j) { return m_data[(size_t) (i*m_cols + j)]; } float *data() { return m_data; } - ssize_t rows() const { return m_rows; } - ssize_t cols() const { return m_cols; } + py::ssize_t rows() const { return m_rows; } + py::ssize_t cols() const { return m_cols; } private: - ssize_t m_rows; - ssize_t m_cols; + py::ssize_t m_rows; + py::ssize_t m_cols; float *m_data; }; py::class_(m, "Matrix", py::buffer_protocol()) - .def(py::init()) + .def(py::init()) /// Construct from a buffer - .def(py::init([](py::buffer b) { + .def(py::init([](py::buffer const b) { py::buffer_info info = b.request(); if (info.format != py::format_descriptor::format() || info.ndim != 2) throw std::runtime_error("Incompatible buffer format!"); @@ -92,12 +93,12 @@ TEST_SUBMODULE(buffers, m) { .def("cols", &Matrix::cols) /// Bare bones interface - .def("__getitem__", [](const Matrix &m, std::pair i) { + .def("__getitem__", [](const Matrix &m, std::pair i) { if (i.first >= m.rows() || i.second >= m.cols()) throw py::index_error(); return m(i.first, i.second); }) - .def("__setitem__", [](Matrix &m, std::pair i, float v) { + .def("__setitem__", [](Matrix &m, std::pair i, float v) { if (i.first >= m.rows() || i.second >= m.cols()) throw py::index_error(); m(i.first, i.second) = v; @@ -107,7 +108,7 @@ TEST_SUBMODULE(buffers, m) { return py::buffer_info( m.data(), /* Pointer to buffer */ { m.rows(), m.cols() }, /* Buffer dimensions */ - { sizeof(float) * size_t(m.rows()), /* Strides (in bytes) for each index */ + { sizeof(float) * size_t(m.cols()), /* Strides (in bytes) for each index */ sizeof(float) } ); }) @@ -117,11 +118,11 @@ TEST_SUBMODULE(buffers, m) { // test_inherited_protocol class SquareMatrix : public Matrix { public: - SquareMatrix(ssize_t n) : Matrix(n, n) { } + SquareMatrix(py::ssize_t n) : Matrix(n, n) { } }; // Derived classes inherit the buffer protocol and the buffer access function py::class_(m, "SquareMatrix") - .def(py::init()); + .def(py::init()); // test_pointer_to_member_fn @@ -166,4 +167,48 @@ TEST_SUBMODULE(buffers, m) { .def_readwrite("value", (int32_t DerivedBuffer::*) &DerivedBuffer::value) .def_buffer(&DerivedBuffer::get_buffer_info); + struct BufferReadOnly { + const uint8_t value = 0; + BufferReadOnly(uint8_t value): value(value) {} + + py::buffer_info get_buffer_info() { + return py::buffer_info(&value, 1); + } + }; + py::class_(m, "BufferReadOnly", py::buffer_protocol()) + .def(py::init()) + .def_buffer(&BufferReadOnly::get_buffer_info); + + struct BufferReadOnlySelect { + uint8_t value = 0; + bool readonly = false; + + py::buffer_info get_buffer_info() { + return py::buffer_info(&value, 1, readonly); + } + }; + py::class_(m, "BufferReadOnlySelect", py::buffer_protocol()) + .def(py::init<>()) + .def_readwrite("value", &BufferReadOnlySelect::value) + .def_readwrite("readonly", &BufferReadOnlySelect::readonly) + .def_buffer(&BufferReadOnlySelect::get_buffer_info); + + // Expose buffer_info for testing. + py::class_(m, "buffer_info") + .def(py::init<>()) + .def_readonly("itemsize", &py::buffer_info::itemsize) + .def_readonly("size", &py::buffer_info::size) + .def_readonly("format", &py::buffer_info::format) + .def_readonly("ndim", &py::buffer_info::ndim) + .def_readonly("shape", &py::buffer_info::shape) + .def_readonly("strides", &py::buffer_info::strides) + .def_readonly("readonly", &py::buffer_info::readonly) + .def("__repr__", [](py::handle self) { + return py::str("itemsize={0.itemsize!r}, size={0.size!r}, format={0.format!r}, ndim={0.ndim!r}, shape={0.shape!r}, strides={0.strides!r}, readonly={0.readonly!r}").format(self); + }) + ; + + m.def("get_buffer_info", [](py::buffer buffer) { + return buffer.request(); + }); } diff --git a/plugins/python/pybind11/tests/test_buffers.py b/plugins/python/pybind11/tests/test_buffers.py index c348be5..f0f3708 100644 --- a/plugins/python/pybind11/tests/test_buffers.py +++ b/plugins/python/pybind11/tests/test_buffers.py @@ -1,12 +1,16 @@ +# -*- coding: utf-8 -*- +import io import struct +import ctypes + import pytest + +import env # noqa: F401 + from pybind11_tests import buffers as m from pybind11_tests import ConstructorStats -pytestmark = pytest.requires_numpy - -with pytest.suppress(ImportError): - import numpy as np +np = pytest.importorskip("numpy") def test_from_python(): @@ -32,21 +36,23 @@ def test_from_python(): assert cstats.move_assignments == 0 -# PyPy: Memory leak in the "np.array(m, copy=False)" call -# https://bitbucket.org/pypy/pypy/issues/2444 -@pytest.unsupported_on_pypy +# https://foss.heptapod.net/pypy/pypy/-/issues/2444 def test_to_python(): - mat = m.Matrix(5, 5) - assert memoryview(mat).shape == (5, 5) + mat = m.Matrix(5, 4) + assert memoryview(mat).shape == (5, 4) assert mat[2, 3] == 0 - mat[2, 3] = 4 + mat[2, 3] = 4.0 + mat[3, 2] = 7.0 assert mat[2, 3] == 4 + assert mat[3, 2] == 7 + assert struct.unpack_from("f", mat, (3 * 4 + 2) * 4) == (7,) + assert struct.unpack_from("f", mat, (2 * 4 + 3) * 4) == (4,) mat2 = np.array(mat, copy=False) - assert mat2.shape == (5, 5) - assert abs(mat2).sum() == 4 - assert mat2[2, 3] == 4 + assert mat2.shape == (5, 4) + assert abs(mat2).sum() == 11 + assert mat2[2, 3] == 4 and mat2[3, 2] == 7 mat2[2, 3] = 5 assert mat2[2, 3] == 5 @@ -58,14 +64,13 @@ def test_to_python(): del mat2 # holds a mat reference pytest.gc_collect() assert cstats.alive() == 0 - assert cstats.values() == ["5x5 matrix"] + assert cstats.values() == ["5x4 matrix"] assert cstats.copy_constructions == 0 # assert cstats.move_constructions >= 0 # Don't invoke any assert cstats.copy_assignments == 0 assert cstats.move_assignments == 0 -@pytest.unsupported_on_pypy def test_inherited_protocol(): """SquareMatrix is derived from Matrix and inherits the buffer protocol""" @@ -74,10 +79,84 @@ def test_inherited_protocol(): assert np.asarray(matrix).shape == (5, 5) -@pytest.unsupported_on_pypy def test_pointer_to_member_fn(): for cls in [m.Buffer, m.ConstBuffer, m.DerivedBuffer]: buf = cls() buf.value = 0x12345678 - value = struct.unpack('i', bytearray(buf))[0] + value = struct.unpack("i", bytearray(buf))[0] assert value == 0x12345678 + + +def test_readonly_buffer(): + buf = m.BufferReadOnly(0x64) + view = memoryview(buf) + assert view[0] == b"d" if env.PY2 else 0x64 + assert view.readonly + + +def test_selective_readonly_buffer(): + buf = m.BufferReadOnlySelect() + + memoryview(buf)[0] = b"d" if env.PY2 else 0x64 + assert buf.value == 0x64 + + io.BytesIO(b"A").readinto(buf) + assert buf.value == ord(b"A") + + buf.readonly = True + with pytest.raises(TypeError): + memoryview(buf)[0] = b"\0" if env.PY2 else 0 + with pytest.raises(TypeError): + io.BytesIO(b"1").readinto(buf) + + +def test_ctypes_array_1d(): + char1d = (ctypes.c_char * 10)() + int1d = (ctypes.c_int * 15)() + long1d = (ctypes.c_long * 7)() + + for carray in (char1d, int1d, long1d): + info = m.get_buffer_info(carray) + assert info.itemsize == ctypes.sizeof(carray._type_) + assert info.size == len(carray) + assert info.ndim == 1 + assert info.shape == [info.size] + assert info.strides == [info.itemsize] + assert not info.readonly + + +def test_ctypes_array_2d(): + char2d = ((ctypes.c_char * 10) * 4)() + int2d = ((ctypes.c_int * 15) * 3)() + long2d = ((ctypes.c_long * 7) * 2)() + + for carray in (char2d, int2d, long2d): + info = m.get_buffer_info(carray) + assert info.itemsize == ctypes.sizeof(carray[0]._type_) + assert info.size == len(carray) * len(carray[0]) + assert info.ndim == 2 + assert info.shape == [len(carray), len(carray[0])] + assert info.strides == [info.itemsize * len(carray[0]), info.itemsize] + assert not info.readonly + + +@pytest.mark.skipif( + "env.PYPY and env.PY2", reason="PyPy2 bytes buffer not reported as readonly" +) +def test_ctypes_from_buffer(): + test_pystr = b"0123456789" + for pyarray in (test_pystr, bytearray(test_pystr)): + pyinfo = m.get_buffer_info(pyarray) + + if pyinfo.readonly: + cbytes = (ctypes.c_char * len(pyarray)).from_buffer_copy(pyarray) + cinfo = m.get_buffer_info(cbytes) + else: + cbytes = (ctypes.c_char * len(pyarray)).from_buffer(pyarray) + cinfo = m.get_buffer_info(cbytes) + + assert cinfo.size == pyinfo.size + assert cinfo.ndim == pyinfo.ndim + assert cinfo.shape == pyinfo.shape + assert cinfo.strides == pyinfo.strides + assert not cinfo.readonly diff --git a/plugins/python/pybind11/tests/test_builtin_casters.cpp b/plugins/python/pybind11/tests/test_builtin_casters.cpp index e5413c2..acc9f8f 100644 --- a/plugins/python/pybind11/tests/test_builtin_casters.cpp +++ b/plugins/python/pybind11/tests/test_builtin_casters.cpp @@ -30,7 +30,7 @@ TEST_SUBMODULE(builtin_casters, m) { else { wstr.push_back((wchar_t) mathbfA32); } // 𝐀, utf32 wstr.push_back(0x7a); // z - m.def("good_utf8_string", []() { return std::string(u8"Say utf8\u203d \U0001f382 \U0001d400"); }); // Say utf8‽ 🎂 𝐀 + m.def("good_utf8_string", []() { return std::string((const char*)u8"Say utf8\u203d \U0001f382 \U0001d400"); }); // Say utf8‽ 🎂 𝐀 m.def("good_utf16_string", [=]() { return std::u16string({ b16, ib16, cake16_1, cake16_2, mathbfA16_1, mathbfA16_2, z16 }); }); // b‽🎂𝐀z m.def("good_utf32_string", [=]() { return std::u32string({ a32, mathbfA32, cake32, ib32, z32 }); }); // a𝐀🎂‽z m.def("good_wchar_string", [=]() { return wstr; }); // a‽𝐀z @@ -60,6 +60,18 @@ TEST_SUBMODULE(builtin_casters, m) { m.def("strlen", [](char *s) { return strlen(s); }); m.def("string_length", [](std::string s) { return s.length(); }); +#ifdef PYBIND11_HAS_U8STRING + m.attr("has_u8string") = true; + m.def("good_utf8_u8string", []() { return std::u8string(u8"Say utf8\u203d \U0001f382 \U0001d400"); }); // Say utf8‽ 🎂 𝐀 + m.def("bad_utf8_u8string", []() { return std::u8string((const char8_t*)"abc\xd0" "def"); }); + + m.def("u8_char8_Z", []() -> char8_t { return u8'Z'; }); + + // test_single_char_arguments + m.def("ord_char8", [](char8_t c) -> int { return static_cast(c); }); + m.def("ord_char8_lv", [](char8_t &c) -> int { return static_cast(c); }); +#endif + // test_string_view #ifdef PYBIND11_HAS_STRING_VIEW m.attr("has_string_view") = true; @@ -69,9 +81,15 @@ TEST_SUBMODULE(builtin_casters, m) { m.def("string_view_chars", [](std::string_view s) { py::list l; for (auto c : s) l.append((std::uint8_t) c); return l; }); m.def("string_view16_chars", [](std::u16string_view s) { py::list l; for (auto c : s) l.append((int) c); return l; }); m.def("string_view32_chars", [](std::u32string_view s) { py::list l; for (auto c : s) l.append((int) c); return l; }); - m.def("string_view_return", []() { return std::string_view(u8"utf8 secret \U0001f382"); }); + m.def("string_view_return", []() { return std::string_view((const char*)u8"utf8 secret \U0001f382"); }); m.def("string_view16_return", []() { return std::u16string_view(u"utf16 secret \U0001f382"); }); m.def("string_view32_return", []() { return std::u32string_view(U"utf32 secret \U0001f382"); }); + +# ifdef PYBIND11_HAS_U8STRING + m.def("string_view8_print", [](std::u8string_view s) { py::print(s, s.size()); }); + m.def("string_view8_chars", [](std::u8string_view s) { py::list l; for (auto c : s) l.append((std::uint8_t) c); return l; }); + m.def("string_view8_return", []() { return std::u8string_view(u8"utf8 secret \U0001f382"); }); +# endif #endif // test_integer_casting @@ -99,12 +117,16 @@ TEST_SUBMODULE(builtin_casters, m) { return std::make_pair(RValueCaster{}, std::make_tuple(RValueCaster{}, std::make_pair(RValueCaster{}, RValueCaster{}))); }); m.def("lvalue_nested", []() -> const decltype(lvnested) & { return lvnested; }); + static std::pair int_string_pair{2, "items"}; + m.def("int_string_pair", []() { return &int_string_pair; }); + // test_builtins_cast_return_none m.def("return_none_string", []() -> std::string * { return nullptr; }); m.def("return_none_char", []() -> const char * { return nullptr; }); m.def("return_none_bool", []() -> bool * { return nullptr; }); m.def("return_none_int", []() -> int * { return nullptr; }); m.def("return_none_float", []() -> float * { return nullptr; }); + m.def("return_none_pair", []() -> std::pair * { return nullptr; }); // test_none_deferred m.def("defer_none_cstring", [](char *) { return false; }); @@ -155,4 +177,16 @@ TEST_SUBMODULE(builtin_casters, m) { // test_complex m.def("complex_cast", [](float x) { return "{}"_s.format(x); }); m.def("complex_cast", [](std::complex x) { return "({}, {})"_s.format(x.real(), x.imag()); }); + + // test int vs. long (Python 2) + m.def("int_cast", []() {return (int) 42;}); + m.def("long_cast", []() {return (long) 42;}); + m.def("longlong_cast", []() {return ULLONG_MAX;}); + + /// test void* cast operator + m.def("test_void_caster", []() -> bool { + void *v = (void *) 0xabcd; + py::object o = py::cast(v); + return py::cast(o) == v; + }); } diff --git a/plugins/python/pybind11/tests/test_builtin_casters.py b/plugins/python/pybind11/tests/test_builtin_casters.py index 2f311f1..bd7996b 100644 --- a/plugins/python/pybind11/tests/test_builtin_casters.py +++ b/plugins/python/pybind11/tests/test_builtin_casters.py @@ -1,6 +1,8 @@ -# Python < 3 needs this: coding=utf-8 +# -*- coding: utf-8 -*- import pytest +import env # noqa: F401 + from pybind11_tests import builtin_casters as m from pybind11_tests import UserType, IncType @@ -15,6 +17,8 @@ def test_unicode_conversion(): assert m.good_utf16_string() == u"b‽🎂𝐀z" assert m.good_utf32_string() == u"a𝐀🎂‽z" assert m.good_wchar_string() == u"a⸘𝐀z" + if hasattr(m, "has_u8string"): + assert m.good_utf8_u8string() == u"Say utf8‽ 🎂 𝐀" with pytest.raises(UnicodeDecodeError): m.bad_utf8_string() @@ -29,135 +33,198 @@ def test_unicode_conversion(): if hasattr(m, "bad_wchar_string"): with pytest.raises(UnicodeDecodeError): m.bad_wchar_string() + if hasattr(m, "has_u8string"): + with pytest.raises(UnicodeDecodeError): + m.bad_utf8_u8string() - assert m.u8_Z() == 'Z' - assert m.u8_eacute() == u'é' - assert m.u16_ibang() == u'‽' - assert m.u32_mathbfA() == u'𝐀' - assert m.wchar_heart() == u'♥' + assert m.u8_Z() == "Z" + assert m.u8_eacute() == u"é" + assert m.u16_ibang() == u"‽" + assert m.u32_mathbfA() == u"𝐀" + assert m.wchar_heart() == u"♥" + if hasattr(m, "has_u8string"): + assert m.u8_char8_Z() == "Z" def test_single_char_arguments(): """Tests failures for passing invalid inputs to char-accepting functions""" + def toobig_message(r): return "Character code point not in range({0:#x})".format(r) + toolong_message = "Expected a character, but multi-character string found" - assert m.ord_char(u'a') == 0x61 # simple ASCII - assert m.ord_char_lv(u'b') == 0x62 - assert m.ord_char(u'é') == 0xE9 # requires 2 bytes in utf-8, but can be stuffed in a char + assert m.ord_char(u"a") == 0x61 # simple ASCII + assert m.ord_char_lv(u"b") == 0x62 + assert ( + m.ord_char(u"é") == 0xE9 + ) # requires 2 bytes in utf-8, but can be stuffed in a char with pytest.raises(ValueError) as excinfo: - assert m.ord_char(u'Ā') == 0x100 # requires 2 bytes, doesn't fit in a char + assert m.ord_char(u"Ā") == 0x100 # requires 2 bytes, doesn't fit in a char assert str(excinfo.value) == toobig_message(0x100) with pytest.raises(ValueError) as excinfo: - assert m.ord_char(u'ab') + assert m.ord_char(u"ab") assert str(excinfo.value) == toolong_message - assert m.ord_char16(u'a') == 0x61 - assert m.ord_char16(u'é') == 0xE9 - assert m.ord_char16_lv(u'ê') == 0xEA - assert m.ord_char16(u'Ā') == 0x100 - assert m.ord_char16(u'‽') == 0x203d - assert m.ord_char16(u'♥') == 0x2665 - assert m.ord_char16_lv(u'♡') == 0x2661 + assert m.ord_char16(u"a") == 0x61 + assert m.ord_char16(u"é") == 0xE9 + assert m.ord_char16_lv(u"ê") == 0xEA + assert m.ord_char16(u"Ā") == 0x100 + assert m.ord_char16(u"‽") == 0x203D + assert m.ord_char16(u"♥") == 0x2665 + assert m.ord_char16_lv(u"♡") == 0x2661 with pytest.raises(ValueError) as excinfo: - assert m.ord_char16(u'🎂') == 0x1F382 # requires surrogate pair + assert m.ord_char16(u"🎂") == 0x1F382 # requires surrogate pair assert str(excinfo.value) == toobig_message(0x10000) with pytest.raises(ValueError) as excinfo: - assert m.ord_char16(u'aa') + assert m.ord_char16(u"aa") assert str(excinfo.value) == toolong_message - assert m.ord_char32(u'a') == 0x61 - assert m.ord_char32(u'é') == 0xE9 - assert m.ord_char32(u'Ā') == 0x100 - assert m.ord_char32(u'‽') == 0x203d - assert m.ord_char32(u'♥') == 0x2665 - assert m.ord_char32(u'🎂') == 0x1F382 + assert m.ord_char32(u"a") == 0x61 + assert m.ord_char32(u"é") == 0xE9 + assert m.ord_char32(u"Ā") == 0x100 + assert m.ord_char32(u"‽") == 0x203D + assert m.ord_char32(u"♥") == 0x2665 + assert m.ord_char32(u"🎂") == 0x1F382 with pytest.raises(ValueError) as excinfo: - assert m.ord_char32(u'aa') + assert m.ord_char32(u"aa") assert str(excinfo.value) == toolong_message - assert m.ord_wchar(u'a') == 0x61 - assert m.ord_wchar(u'é') == 0xE9 - assert m.ord_wchar(u'Ā') == 0x100 - assert m.ord_wchar(u'‽') == 0x203d - assert m.ord_wchar(u'♥') == 0x2665 + assert m.ord_wchar(u"a") == 0x61 + assert m.ord_wchar(u"é") == 0xE9 + assert m.ord_wchar(u"Ā") == 0x100 + assert m.ord_wchar(u"‽") == 0x203D + assert m.ord_wchar(u"♥") == 0x2665 if m.wchar_size == 2: with pytest.raises(ValueError) as excinfo: - assert m.ord_wchar(u'🎂') == 0x1F382 # requires surrogate pair + assert m.ord_wchar(u"🎂") == 0x1F382 # requires surrogate pair assert str(excinfo.value) == toobig_message(0x10000) else: - assert m.ord_wchar(u'🎂') == 0x1F382 + assert m.ord_wchar(u"🎂") == 0x1F382 with pytest.raises(ValueError) as excinfo: - assert m.ord_wchar(u'aa') + assert m.ord_wchar(u"aa") assert str(excinfo.value) == toolong_message + if hasattr(m, "has_u8string"): + assert m.ord_char8(u"a") == 0x61 # simple ASCII + assert m.ord_char8_lv(u"b") == 0x62 + assert ( + m.ord_char8(u"é") == 0xE9 + ) # requires 2 bytes in utf-8, but can be stuffed in a char + with pytest.raises(ValueError) as excinfo: + assert m.ord_char8(u"Ā") == 0x100 # requires 2 bytes, doesn't fit in a char + assert str(excinfo.value) == toobig_message(0x100) + with pytest.raises(ValueError) as excinfo: + assert m.ord_char8(u"ab") + assert str(excinfo.value) == toolong_message + def test_bytes_to_string(): """Tests the ability to pass bytes to C++ string-accepting functions. Note that this is one-way: the only way to return bytes to Python is via the pybind11::bytes class.""" # Issue #816 - import sys - byte = bytes if sys.version_info[0] < 3 else str - assert m.strlen(byte("hi")) == 2 - assert m.string_length(byte("world")) == 5 - assert m.string_length(byte("a\x00b")) == 3 - assert m.strlen(byte("a\x00b")) == 1 # C-string limitation + def to_bytes(s): + b = s if env.PY2 else s.encode("utf8") + assert isinstance(b, bytes) + return b + + assert m.strlen(to_bytes("hi")) == 2 + assert m.string_length(to_bytes("world")) == 5 + assert m.string_length(to_bytes("a\x00b")) == 3 + assert m.strlen(to_bytes("a\x00b")) == 1 # C-string limitation # passing in a utf8 encoded string should work - assert m.string_length(u'💩'.encode("utf8")) == 4 + assert m.string_length(u"💩".encode("utf8")) == 4 @pytest.mark.skipif(not hasattr(m, "has_string_view"), reason="no ") def test_string_view(capture): """Tests support for C++17 string_view arguments and return values""" assert m.string_view_chars("Hi") == [72, 105] - assert m.string_view_chars("Hi 🎂") == [72, 105, 32, 0xf0, 0x9f, 0x8e, 0x82] - assert m.string_view16_chars("Hi 🎂") == [72, 105, 32, 0xd83c, 0xdf82] - assert m.string_view32_chars("Hi 🎂") == [72, 105, 32, 127874] - - assert m.string_view_return() == "utf8 secret 🎂" - assert m.string_view16_return() == "utf16 secret 🎂" - assert m.string_view32_return() == "utf32 secret 🎂" + assert m.string_view_chars("Hi 🎂") == [72, 105, 32, 0xF0, 0x9F, 0x8E, 0x82] + assert m.string_view16_chars(u"Hi 🎂") == [72, 105, 32, 0xD83C, 0xDF82] + assert m.string_view32_chars(u"Hi 🎂") == [72, 105, 32, 127874] + if hasattr(m, "has_u8string"): + assert m.string_view8_chars("Hi") == [72, 105] + assert m.string_view8_chars(u"Hi 🎂") == [72, 105, 32, 0xF0, 0x9F, 0x8E, 0x82] + + assert m.string_view_return() == u"utf8 secret 🎂" + assert m.string_view16_return() == u"utf16 secret 🎂" + assert m.string_view32_return() == u"utf32 secret 🎂" + if hasattr(m, "has_u8string"): + assert m.string_view8_return() == u"utf8 secret 🎂" with capture: m.string_view_print("Hi") m.string_view_print("utf8 🎂") - m.string_view16_print("utf16 🎂") - m.string_view32_print("utf32 🎂") - assert capture == """ + m.string_view16_print(u"utf16 🎂") + m.string_view32_print(u"utf32 🎂") + assert ( + capture + == u""" Hi 2 utf8 🎂 9 utf16 🎂 8 utf32 🎂 7 """ + ) + if hasattr(m, "has_u8string"): + with capture: + m.string_view8_print("Hi") + m.string_view8_print(u"utf8 🎂") + assert ( + capture + == u""" + Hi 2 + utf8 🎂 9 + """ + ) with capture: m.string_view_print("Hi, ascii") m.string_view_print("Hi, utf8 🎂") - m.string_view16_print("Hi, utf16 🎂") - m.string_view32_print("Hi, utf32 🎂") - assert capture == """ + m.string_view16_print(u"Hi, utf16 🎂") + m.string_view32_print(u"Hi, utf32 🎂") + assert ( + capture + == u""" Hi, ascii 9 Hi, utf8 🎂 13 Hi, utf16 🎂 12 Hi, utf32 🎂 11 """ + ) + if hasattr(m, "has_u8string"): + with capture: + m.string_view8_print("Hi, ascii") + m.string_view8_print(u"Hi, utf8 🎂") + assert ( + capture + == u""" + Hi, ascii 9 + Hi, utf8 🎂 13 + """ + ) def test_integer_casting(): """Issue #929 - out-of-range integer values shouldn't be accepted""" - import sys assert m.i32_str(-1) == "-1" assert m.i64_str(-1) == "-1" assert m.i32_str(2000000000) == "2000000000" assert m.u32_str(2000000000) == "2000000000" - if sys.version_info < (3,): + if env.PY2: assert m.i32_str(long(-1)) == "-1" # noqa: F821 undefined name 'long' assert m.i64_str(long(-1)) == "-1" # noqa: F821 undefined name 'long' - assert m.i64_str(long(-999999999999)) == "-999999999999" # noqa: F821 undefined name - assert m.u64_str(long(999999999999)) == "999999999999" # noqa: F821 undefined name 'long' + assert ( + m.i64_str(long(-999999999999)) # noqa: F821 undefined name 'long' + == "-999999999999" + ) + assert ( + m.u64_str(long(999999999999)) # noqa: F821 undefined name 'long' + == "999999999999" + ) else: assert m.i64_str(-999999999999) == "-999999999999" assert m.u64_str(999999999999) == "999999999999" @@ -175,7 +242,7 @@ def test_integer_casting(): m.i32_str(3000000000) assert "incompatible function arguments" in str(excinfo.value) - if sys.version_info < (3,): + if env.PY2: with pytest.raises(TypeError) as excinfo: m.u32_str(long(-1)) # noqa: F821 undefined name 'long' assert "incompatible function arguments" in str(excinfo.value) @@ -193,16 +260,22 @@ def test_tuple(doc): assert m.tuple_passthrough([True, "test", 5]) == (5, "test", True) assert m.empty_tuple() == () - assert doc(m.pair_passthrough) == """ + assert ( + doc(m.pair_passthrough) + == """ pair_passthrough(arg0: Tuple[bool, str]) -> Tuple[str, bool] Return a pair in reversed order """ - assert doc(m.tuple_passthrough) == """ + ) + assert ( + doc(m.tuple_passthrough) + == """ tuple_passthrough(arg0: Tuple[bool, str, int]) -> Tuple[int, str, bool] Return a triple in reversed order """ + ) assert m.rvalue_pair() == ("rvalue", "rvalue") assert m.lvalue_pair() == ("lvalue", "lvalue") @@ -211,6 +284,8 @@ def test_tuple(doc): assert m.rvalue_nested() == ("rvalue", ("rvalue", ("rvalue", "rvalue"))) assert m.lvalue_nested() == ("lvalue", ("lvalue", ("lvalue", "lvalue"))) + assert m.int_string_pair() == (2, "items") + def test_builtins_cast_return_none(): """Casters produced with PYBIND11_TYPE_CASTER() should convert nullptr to None""" @@ -219,6 +294,7 @@ def test_builtins_cast_return_none(): assert m.return_none_bool() is None assert m.return_none_int() is None assert m.return_none_float() is None + assert m.return_none_pair() is None def test_none_deferred(): @@ -313,13 +389,35 @@ class B(object): assert convert(A(False)) is False -@pytest.requires_numpy def test_numpy_bool(): - import numpy as np + np = pytest.importorskip("numpy") + convert, noconvert = m.bool_passthrough, m.bool_passthrough_noconvert + def cant_convert(v): + pytest.raises(TypeError, convert, v) + # np.bool_ is not considered implicit assert convert(np.bool_(True)) is True assert convert(np.bool_(False)) is False assert noconvert(np.bool_(True)) is True assert noconvert(np.bool_(False)) is False + cant_convert(np.zeros(2, dtype="int")) + + +def test_int_long(): + """In Python 2, a C++ int should return a Python int rather than long + if possible: longs are not always accepted where ints are used (such + as the argument to sys.exit()). A C++ long long is always a Python + long.""" + + import sys + + must_be_long = type(getattr(sys, "maxint", 1) + 1) + assert isinstance(m.int_cast(), int) + assert isinstance(m.long_cast(), int) + assert isinstance(m.longlong_cast(), must_be_long) + + +def test_void_caster_2(): + assert m.test_void_caster() diff --git a/plugins/python/pybind11/tests/test_call_policies.cpp b/plugins/python/pybind11/tests/test_call_policies.cpp index 81fb170..26c83f8 100644 --- a/plugins/python/pybind11/tests/test_call_policies.cpp +++ b/plugins/python/pybind11/tests/test_call_policies.cpp @@ -8,7 +8,6 @@ */ #include "pybind11_tests.h" -#include "constructor_stats.h" struct CustomGuard { static bool enabled; @@ -37,6 +36,8 @@ TEST_SUBMODULE(call_policies, m) { class Child { public: Child() { py::print("Allocating child."); } + Child(const Child &) = default; + Child(Child &&) = default; ~Child() { py::print("Releasing child."); } }; py::class_(m, "Child") @@ -45,6 +46,7 @@ TEST_SUBMODULE(call_policies, m) { class Parent { public: Parent() { py::print("Allocating parent."); } + Parent(const Parent& parent) = default; ~Parent() { py::print("Releasing parent."); } void addChild(Child *) { } Child *returnChild() { return new Child(); } @@ -60,21 +62,6 @@ TEST_SUBMODULE(call_policies, m) { .def("returnNullChildKeepAliveChild", &Parent::returnNullChild, py::keep_alive<1, 0>()) .def("returnNullChildKeepAliveParent", &Parent::returnNullChild, py::keep_alive<0, 1>()); - // test_keep_alive_single - m.def("add_patient", [](py::object /*nurse*/, py::object /*patient*/) { }, py::keep_alive<1, 2>()); - m.def("get_patients", [](py::object nurse) { - py::list patients; - for (PyObject *p : pybind11::detail::get_internals().patients[nurse.ptr()]) - patients.append(py::reinterpret_borrow(p)); - return patients; - }); - m.def("refcount", [](py::handle h) { -#ifdef PYPY_VERSION - ConstructorStats::gc(); // PyPy doesn't update ref counts until GC occurs -#endif - return h.ref_count(); - }); - #if !defined(PYPY_VERSION) // test_alive_gc class ParentGC : public Parent { diff --git a/plugins/python/pybind11/tests/test_call_policies.py b/plugins/python/pybind11/tests/test_call_policies.py index 8d64afd..e0413d1 100644 --- a/plugins/python/pybind11/tests/test_call_policies.py +++ b/plugins/python/pybind11/tests/test_call_policies.py @@ -1,8 +1,13 @@ +# -*- coding: utf-8 -*- import pytest + +import env # noqa: F401 + from pybind11_tests import call_policies as m -from pybind11_tests import ConstructorStats, UserType +from pybind11_tests import ConstructorStats +@pytest.mark.xfail("env.PYPY", reason="sometimes comes out 1 off on PyPy", strict=False) def test_keep_alive_argument(capture): n_inst = ConstructorStats.detail_reg_inst() with capture: @@ -11,10 +16,13 @@ def test_keep_alive_argument(capture): with capture: p.addChild(m.Child()) assert ConstructorStats.detail_reg_inst() == n_inst + 1 - assert capture == """ + assert ( + capture + == """ Allocating child. Releasing child. """ + ) with capture: del p assert ConstructorStats.detail_reg_inst() == n_inst @@ -30,10 +38,13 @@ def test_keep_alive_argument(capture): with capture: del p assert ConstructorStats.detail_reg_inst() == n_inst - assert capture == """ + assert ( + capture + == """ Releasing parent. Releasing child. """ + ) def test_keep_alive_return_value(capture): @@ -44,10 +55,13 @@ def test_keep_alive_return_value(capture): with capture: p.returnChild() assert ConstructorStats.detail_reg_inst() == n_inst + 1 - assert capture == """ + assert ( + capture + == """ Allocating child. Releasing child. """ + ) with capture: del p assert ConstructorStats.detail_reg_inst() == n_inst @@ -63,57 +77,34 @@ def test_keep_alive_return_value(capture): with capture: del p assert ConstructorStats.detail_reg_inst() == n_inst - assert capture == """ + assert ( + capture + == """ Releasing parent. Releasing child. """ + ) -def test_keep_alive_single(): - """Issue #1251 - patients are stored multiple times when given to the same nurse""" - - nurse, p1, p2 = UserType(), UserType(), UserType() - b = m.refcount(nurse) - assert [m.refcount(nurse), m.refcount(p1), m.refcount(p2)] == [b, b, b] - m.add_patient(nurse, p1) - assert m.get_patients(nurse) == [p1, ] - assert [m.refcount(nurse), m.refcount(p1), m.refcount(p2)] == [b, b + 1, b] - m.add_patient(nurse, p1) - assert m.get_patients(nurse) == [p1, ] - assert [m.refcount(nurse), m.refcount(p1), m.refcount(p2)] == [b, b + 1, b] - m.add_patient(nurse, p1) - assert m.get_patients(nurse) == [p1, ] - assert [m.refcount(nurse), m.refcount(p1), m.refcount(p2)] == [b, b + 1, b] - m.add_patient(nurse, p2) - assert m.get_patients(nurse) == [p1, p2] - assert [m.refcount(nurse), m.refcount(p1), m.refcount(p2)] == [b, b + 1, b + 1] - m.add_patient(nurse, p2) - assert m.get_patients(nurse) == [p1, p2] - assert [m.refcount(nurse), m.refcount(p1), m.refcount(p2)] == [b, b + 1, b + 1] - m.add_patient(nurse, p2) - m.add_patient(nurse, p1) - assert m.get_patients(nurse) == [p1, p2] - assert [m.refcount(nurse), m.refcount(p1), m.refcount(p2)] == [b, b + 1, b + 1] - del nurse - assert [m.refcount(p1), m.refcount(p2)] == [b, b] - - -# https://bitbucket.org/pypy/pypy/issues/2447 -@pytest.unsupported_on_pypy +# https://foss.heptapod.net/pypy/pypy/-/issues/2447 +@pytest.mark.xfail("env.PYPY", reason="_PyObject_GetDictPtr is unimplemented") def test_alive_gc(capture): n_inst = ConstructorStats.detail_reg_inst() p = m.ParentGC() p.addChildKeepAlive(m.Child()) assert ConstructorStats.detail_reg_inst() == n_inst + 2 lst = [p] - lst.append(lst) # creates a circular reference + lst.append(lst) # creates a circular reference with capture: del p, lst assert ConstructorStats.detail_reg_inst() == n_inst - assert capture == """ + assert ( + capture + == """ Releasing parent. Releasing child. """ + ) def test_alive_gc_derived(capture): @@ -125,14 +116,17 @@ class Derived(m.Parent): p.addChildKeepAlive(m.Child()) assert ConstructorStats.detail_reg_inst() == n_inst + 2 lst = [p] - lst.append(lst) # creates a circular reference + lst.append(lst) # creates a circular reference with capture: del p, lst assert ConstructorStats.detail_reg_inst() == n_inst - assert capture == """ + assert ( + capture + == """ Releasing parent. Releasing child. """ + ) def test_alive_gc_multi_derived(capture): @@ -147,15 +141,18 @@ def __init__(self): # +3 rather than +2 because Derived corresponds to two registered instances assert ConstructorStats.detail_reg_inst() == n_inst + 3 lst = [p] - lst.append(lst) # creates a circular reference + lst.append(lst) # creates a circular reference with capture: del p, lst assert ConstructorStats.detail_reg_inst() == n_inst - assert capture == """ + assert ( + capture + == """ Releasing parent. Releasing child. Releasing child. """ + ) def test_return_none(capture): @@ -191,17 +188,23 @@ def test_keep_alive_constructor(capture): with capture: p = m.Parent(m.Child()) assert ConstructorStats.detail_reg_inst() == n_inst + 2 - assert capture == """ + assert ( + capture + == """ Allocating child. Allocating parent. """ + ) with capture: del p assert ConstructorStats.detail_reg_inst() == n_inst - assert capture == """ + assert ( + capture + == """ Releasing parent. Releasing child. """ + ) def test_call_guard(): diff --git a/plugins/python/pybind11/tests/test_callbacks.cpp b/plugins/python/pybind11/tests/test_callbacks.cpp index 273eacc..683dfb3 100644 --- a/plugins/python/pybind11/tests/test_callbacks.cpp +++ b/plugins/python/pybind11/tests/test_callbacks.cpp @@ -10,6 +10,7 @@ #include "pybind11_tests.h" #include "constructor_stats.h" #include +#include int dummy_function(int i) { return i + 1; } @@ -116,7 +117,11 @@ TEST_SUBMODULE(callbacks, m) { } }); - class AbstractBase { public: virtual unsigned int func() = 0; }; + class AbstractBase { + public: + virtual ~AbstractBase() = default; + virtual unsigned int func() = 0; + }; m.def("func_accepting_func_accepting_base", [](std::function) { }); struct MovableObject { @@ -146,4 +151,22 @@ TEST_SUBMODULE(callbacks, m) { py::class_(m, "CppBoundMethodTest") .def(py::init<>()) .def("triple", [](CppBoundMethodTest &, int val) { return 3 * val; }); + + // test async Python callbacks + using callback_f = std::function; + m.def("test_async_callback", [](callback_f f, py::list work) { + // make detached thread that calls `f` with piece of work after a little delay + auto start_f = [f](int j) { + auto invoke_f = [f, j] { + std::this_thread::sleep_for(std::chrono::milliseconds(50)); + f(j); + }; + auto t = std::thread(std::move(invoke_f)); + t.detach(); + }; + + // spawn worker threads + for (auto i : work) + start_f(py::cast(i)); + }); } diff --git a/plugins/python/pybind11/tests/test_callbacks.py b/plugins/python/pybind11/tests/test_callbacks.py index 93c42c2..039b877 100644 --- a/plugins/python/pybind11/tests/test_callbacks.py +++ b/plugins/python/pybind11/tests/test_callbacks.py @@ -1,5 +1,7 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import callbacks as m +from threading import Thread def test_callbacks(): @@ -40,17 +42,19 @@ def double(self, val): def test_keyword_args_and_generalized_unpacking(): - def f(*args, **kwargs): return args, kwargs assert m.test_tuple_unpacking(f) == (("positional", 1, 2, 3, 4, 5, 6), {}) - assert m.test_dict_unpacking(f) == (("positional", 1), {"key": "value", "a": 1, "b": 2}) + assert m.test_dict_unpacking(f) == ( + ("positional", 1), + {"key": "value", "a": 1, "b": 2}, + ) assert m.test_keyword_args(f) == ((), {"x": 10, "y": 20}) assert m.test_unpacking_and_keywords1(f) == ((1, 2), {"c": 3, "d": 4}) assert m.test_unpacking_and_keywords2(f) == ( ("positional", 1, 2, 3, 4, 5), - {"key": "value", "a": 1, "b": 2, "c": 3, "d": 4, "e": 5} + {"key": "value", "a": 1, "b": 2, "c": 3, "d": 4, "e": 5}, ) with pytest.raises(TypeError) as excinfo: @@ -81,12 +85,18 @@ def test_lambda_closure_cleanup(): def test_cpp_function_roundtrip(): """Test if passing a function pointer from C++ -> Python -> C++ yields the original pointer""" - assert m.test_dummy_function(m.dummy_function) == "matches dummy_function: eval(1) = 2" - assert (m.test_dummy_function(m.roundtrip(m.dummy_function)) == - "matches dummy_function: eval(1) = 2") + assert ( + m.test_dummy_function(m.dummy_function) == "matches dummy_function: eval(1) = 2" + ) + assert ( + m.test_dummy_function(m.roundtrip(m.dummy_function)) + == "matches dummy_function: eval(1) = 2" + ) assert m.roundtrip(None, expect_none=True) is None - assert (m.test_dummy_function(lambda x: x + 2) == - "can't convert to function pointer: eval(1) = 3") + assert ( + m.test_dummy_function(lambda x: x + 2) + == "can't convert to function pointer: eval(1) = 3" + ) with pytest.raises(TypeError) as excinfo: m.test_dummy_function(m.dummy_function2) @@ -94,8 +104,10 @@ def test_cpp_function_roundtrip(): with pytest.raises(TypeError) as excinfo: m.test_dummy_function(lambda x, y: x + y) - assert any(s in str(excinfo.value) for s in ("missing 1 required positional argument", - "takes exactly 2 arguments")) + assert any( + s in str(excinfo.value) + for s in ("missing 1 required positional argument", "takes exactly 2 arguments") + ) def test_function_signatures(doc): @@ -105,3 +117,32 @@ def test_function_signatures(doc): def test_movable_object(): assert m.callback_with_movable(lambda _: None) is True + + +def test_async_callbacks(): + # serves as state for async callback + class Item: + def __init__(self, value): + self.value = value + + res = [] + + # generate stateful lambda that will store result in `res` + def gen_f(): + s = Item(3) + return lambda j: res.append(s.value + j) + + # do some work async + work = [1, 2, 3, 4] + m.test_async_callback(gen_f(), work) + # wait until work is done + from time import sleep + + sleep(0.5) + assert sum(res) == sum([x + 3 for x in work]) + + +def test_async_async_callbacks(): + t = Thread(target=test_async_callbacks) + t.start() + t.join() diff --git a/plugins/python/pybind11/tests/test_chrono.cpp b/plugins/python/pybind11/tests/test_chrono.cpp index 195a93b..6537050 100644 --- a/plugins/python/pybind11/tests/test_chrono.cpp +++ b/plugins/python/pybind11/tests/test_chrono.cpp @@ -10,10 +10,33 @@ #include "pybind11_tests.h" #include +#include + +struct different_resolutions { + using time_point_h = std::chrono::time_point< + std::chrono::system_clock, std::chrono::hours>; + using time_point_m = std::chrono::time_point< + std::chrono::system_clock, std::chrono::minutes>; + using time_point_s = std::chrono::time_point< + std::chrono::system_clock, std::chrono::seconds>; + using time_point_ms = std::chrono::time_point< + std::chrono::system_clock, std::chrono::milliseconds>; + using time_point_us = std::chrono::time_point< + std::chrono::system_clock, std::chrono::microseconds>; + time_point_h timestamp_h; + time_point_m timestamp_m; + time_point_s timestamp_s; + time_point_ms timestamp_ms; + time_point_us timestamp_us; +}; TEST_SUBMODULE(chrono, m) { using system_time = std::chrono::system_clock::time_point; using steady_time = std::chrono::steady_clock::time_point; + + using timespan = std::chrono::duration; + using timestamp = std::chrono::time_point; + // test_chrono_system_clock // Return the current time off the wall clock m.def("test_chrono1", []() { return std::chrono::system_clock::now(); }); @@ -44,4 +67,18 @@ TEST_SUBMODULE(chrono, m) { // Float durations (issue #719) m.def("test_chrono_float_diff", [](std::chrono::duration a, std::chrono::duration b) { return a - b; }); + + m.def("test_nano_timepoint", [](timestamp start, timespan delta) -> timestamp { + return start + delta; + }); + + // Test different resolutions + py::class_(m, "different_resolutions") + .def(py::init<>()) + .def_readwrite("timestamp_h", &different_resolutions::timestamp_h) + .def_readwrite("timestamp_m", &different_resolutions::timestamp_m) + .def_readwrite("timestamp_s", &different_resolutions::timestamp_s) + .def_readwrite("timestamp_ms", &different_resolutions::timestamp_ms) + .def_readwrite("timestamp_us", &different_resolutions::timestamp_us) + ; } diff --git a/plugins/python/pybind11/tests/test_chrono.py b/plugins/python/pybind11/tests/test_chrono.py index 2b75bd1..e9e24e0 100644 --- a/plugins/python/pybind11/tests/test_chrono.py +++ b/plugins/python/pybind11/tests/test_chrono.py @@ -1,10 +1,15 @@ +# -*- coding: utf-8 -*- from pybind11_tests import chrono as m import datetime +import pytest + +import env # noqa: F401 def test_chrono_system_clock(): # Get the time from both c++ and datetime + date0 = datetime.datetime.today() date1 = m.test_chrono1() date2 = datetime.datetime.today() @@ -12,16 +17,15 @@ def test_chrono_system_clock(): assert isinstance(date1, datetime.datetime) # The numbers should vary by a very small amount (time it took to execute) + diff_python = abs(date2 - date0) diff = abs(date1 - date2) - # There should never be a days/seconds difference + # There should never be a days difference assert diff.days == 0 - assert diff.seconds == 0 - # We test that no more than about 0.5 seconds passes here - # This makes sure that the dates created are very close to the same - # but if the testing system is incredibly overloaded this should still pass - assert diff.microseconds < 500000 + # Since datetime.datetime.today() calls time.time(), and on some platforms + # that has 1 second accuracy, we compare this way + assert diff.seconds <= diff_python.seconds def test_chrono_system_clock_roundtrip(): @@ -40,6 +44,90 @@ def test_chrono_system_clock_roundtrip(): assert diff.microseconds == 0 +def test_chrono_system_clock_roundtrip_date(): + date1 = datetime.date.today() + + # Roundtrip the time + datetime2 = m.test_chrono2(date1) + date2 = datetime2.date() + time2 = datetime2.time() + + # The returned value should be a datetime + assert isinstance(datetime2, datetime.datetime) + assert isinstance(date2, datetime.date) + assert isinstance(time2, datetime.time) + + # They should be identical (no information lost on roundtrip) + diff = abs(date1 - date2) + assert diff.days == 0 + assert diff.seconds == 0 + assert diff.microseconds == 0 + + # Year, Month & Day should be the same after the round trip + assert date1.year == date2.year + assert date1.month == date2.month + assert date1.day == date2.day + + # There should be no time information + assert time2.hour == 0 + assert time2.minute == 0 + assert time2.second == 0 + assert time2.microsecond == 0 + + +SKIP_TZ_ENV_ON_WIN = pytest.mark.skipif( + "env.WIN", reason="TZ environment variable only supported on POSIX" +) + + +@pytest.mark.parametrize( + "time1", + [ + datetime.datetime.today().time(), + datetime.time(0, 0, 0), + datetime.time(0, 0, 0, 1), + datetime.time(0, 28, 45, 109827), + datetime.time(0, 59, 59, 999999), + datetime.time(1, 0, 0), + datetime.time(5, 59, 59, 0), + datetime.time(5, 59, 59, 1), + ], +) +@pytest.mark.parametrize( + "tz", + [ + None, + pytest.param("Europe/Brussels", marks=SKIP_TZ_ENV_ON_WIN), + pytest.param("Asia/Pyongyang", marks=SKIP_TZ_ENV_ON_WIN), + pytest.param("America/New_York", marks=SKIP_TZ_ENV_ON_WIN), + ], +) +def test_chrono_system_clock_roundtrip_time(time1, tz, monkeypatch): + if tz is not None: + monkeypatch.setenv("TZ", "/usr/share/zoneinfo/{}".format(tz)) + + # Roundtrip the time + datetime2 = m.test_chrono2(time1) + date2 = datetime2.date() + time2 = datetime2.time() + + # The returned value should be a datetime + assert isinstance(datetime2, datetime.datetime) + assert isinstance(date2, datetime.date) + assert isinstance(time2, datetime.time) + + # Hour, Minute, Second & Microsecond should be the same after the round trip + assert time1.hour == time2.hour + assert time1.minute == time2.minute + assert time1.second == time2.second + assert time1.microsecond == time2.microsecond + + # There should be no date information (i.e. date = python base date) + assert date2.year == 1970 + assert date2.month == 1 + assert date2.day == 1 + + def test_chrono_duration_roundtrip(): # Get the difference between two times (a timedelta) @@ -70,6 +158,19 @@ def test_chrono_duration_subtraction_equivalence(): assert cpp_diff.microseconds == diff.microseconds +def test_chrono_duration_subtraction_equivalence_date(): + + date1 = datetime.date.today() + date2 = datetime.date.today() + + diff = date2 - date1 + cpp_diff = m.test_chrono4(date2, date1) + + assert cpp_diff.days == diff.days + assert cpp_diff.seconds == diff.seconds + assert cpp_diff.microseconds == diff.microseconds + + def test_chrono_steady_clock(): time1 = m.test_chrono5() assert isinstance(time1, datetime.timedelta) @@ -99,3 +200,19 @@ def test_floating_point_duration(): diff = m.test_chrono_float_diff(43.789012, 1.123456) assert diff.seconds == 42 assert 665556 <= diff.microseconds <= 665557 + + +def test_nano_timepoint(): + time = datetime.datetime.now() + time1 = m.test_nano_timepoint(time, datetime.timedelta(seconds=60)) + assert time1 == time + datetime.timedelta(seconds=60) + + +def test_chrono_different_resolutions(): + resolutions = m.different_resolutions() + time = datetime.datetime.now() + resolutions.timestamp_h = time + resolutions.timestamp_m = time + resolutions.timestamp_s = time + resolutions.timestamp_ms = time + resolutions.timestamp_us = time diff --git a/plugins/python/pybind11/tests/test_class.cpp b/plugins/python/pybind11/tests/test_class.cpp index f0b5873..890fab7 100644 --- a/plugins/python/pybind11/tests/test_class.cpp +++ b/plugins/python/pybind11/tests/test_class.cpp @@ -12,6 +12,10 @@ #include "local_bindings.h" #include +#if defined(_MSC_VER) +# pragma warning(disable: 4324) // warning C4324: structure was padded due to alignment specifier +#endif + // test_brace_initialization struct NoBraceInitialization { NoBraceInitialization(std::vector v) : vec{std::move(v)} {} @@ -24,6 +28,9 @@ struct NoBraceInitialization { TEST_SUBMODULE(class_, m) { // test_instance struct NoConstructor { + NoConstructor() = default; + NoConstructor(const NoConstructor &) = default; + NoConstructor(NoConstructor &&) = default; static NoConstructor *new_instance() { auto *ptr = new NoConstructor(); print_created(ptr, "via new_instance"); @@ -92,7 +99,12 @@ TEST_SUBMODULE(class_, m) { m.def("dog_bark", [](const Dog &dog) { return dog.bark(); }); // test_automatic_upcasting - struct BaseClass { virtual ~BaseClass() {} }; + struct BaseClass { + BaseClass() = default; + BaseClass(const BaseClass &) = default; + BaseClass(BaseClass &&) = default; + virtual ~BaseClass() = default; + }; struct DerivedClass1 : BaseClass { }; struct DerivedClass2 : BaseClass { }; @@ -122,6 +134,32 @@ TEST_SUBMODULE(class_, m) { ); }); + struct Invalid {}; + + // test_type + m.def("check_type", [](int category) { + // Currently not supported (via a fail at compile time) + // See https://github.com/pybind/pybind11/issues/2486 + // if (category == 2) + // return py::type::of(); + if (category == 1) + return py::type::of(); + else + return py::type::of(); + }); + + m.def("get_type_of", [](py::object ob) { + return py::type::of(ob); + }); + + m.def("get_type_classic", [](py::handle h) { + return h.get_type(); + }); + + m.def("as_type", [](py::object ob) { + return py::type(ob); + }); + // test_mismatched_holder struct MismatchBase1 { }; struct MismatchDerived1 : MismatchBase1 { }; @@ -130,12 +168,12 @@ TEST_SUBMODULE(class_, m) { struct MismatchDerived2 : MismatchBase2 { }; m.def("mismatched_holder_1", []() { - auto mod = py::module::import("__main__"); + auto mod = py::module_::import("__main__"); py::class_>(mod, "MismatchBase1"); py::class_(mod, "MismatchDerived1"); }); m.def("mismatched_holder_2", []() { - auto mod = py::module::import("__main__"); + auto mod = py::module_::import("__main__"); py::class_(mod, "MismatchBase2"); py::class_, MismatchBase2>(mod, "MismatchDerived2"); @@ -215,6 +253,8 @@ TEST_SUBMODULE(class_, m) { static void *operator new(size_t s, void *ptr) { py::print("C placement-new", s); return ptr; } static void operator delete(void *p, size_t s) { py::print("C delete", s); return ::operator delete(p); } virtual ~AliasedHasOpNewDelSize() = default; + AliasedHasOpNewDelSize() = default; + AliasedHasOpNewDelSize(const AliasedHasOpNewDelSize&) = delete; }; struct PyAliasedHasOpNewDelSize : AliasedHasOpNewDelSize { PyAliasedHasOpNewDelSize() = default; @@ -265,6 +305,8 @@ TEST_SUBMODULE(class_, m) { class ProtectedB { public: virtual ~ProtectedB() = default; + ProtectedB() = default; + ProtectedB(const ProtectedB &) = delete; protected: virtual int foo() const { return value; } @@ -275,7 +317,7 @@ TEST_SUBMODULE(class_, m) { class TrampolineB : public ProtectedB { public: - int foo() const override { PYBIND11_OVERLOAD(int, ProtectedB, foo, ); } + int foo() const override { PYBIND11_OVERRIDE(int, ProtectedB, foo, ); } }; class PublicistB : public ProtectedB { @@ -311,7 +353,7 @@ TEST_SUBMODULE(class_, m) { // test_reentrant_implicit_conversion_failure // #1035: issue with runaway reentrant implicit conversion struct BogusImplicitConversion { - BogusImplicitConversion(const BogusImplicitConversion &) { } + BogusImplicitConversion(const BogusImplicitConversion &) = default; }; py::class_(m, "BogusImplicitConversion") @@ -333,19 +375,114 @@ TEST_SUBMODULE(class_, m) { "a"_a, "b"_a, "c"_a); base.def("g", [](NestBase &, Nested &) {}); base.def("h", []() { return NestBase(); }); + + // test_error_after_conversion + // The second-pass path through dispatcher() previously didn't + // remember which overload was used, and would crash trying to + // generate a useful error message + + struct NotRegistered {}; + struct StringWrapper { std::string str; }; + m.def("test_error_after_conversions", [](int) {}); + m.def("test_error_after_conversions", + [](StringWrapper) -> NotRegistered { return {}; }); + py::class_(m, "StringWrapper").def(py::init()); + py::implicitly_convertible(); + + #if defined(PYBIND11_CPP17) + struct alignas(1024) Aligned { + std::uintptr_t ptr() const { return (uintptr_t) this; } + }; + py::class_(m, "Aligned") + .def(py::init<>()) + .def("ptr", &Aligned::ptr); + #endif + + // test_final + struct IsFinal final {}; + py::class_(m, "IsFinal", py::is_final()); + + // test_non_final_final + struct IsNonFinalFinal {}; + py::class_(m, "IsNonFinalFinal", py::is_final()); + + // test_exception_rvalue_abort + struct PyPrintDestructor { + PyPrintDestructor() = default; + ~PyPrintDestructor() { + py::print("Print from destructor"); + } + void throw_something() { throw std::runtime_error("error"); } + }; + py::class_(m, "PyPrintDestructor") + .def(py::init<>()) + .def("throw_something", &PyPrintDestructor::throw_something); + + // test_multiple_instances_with_same_pointer + struct SamePointer {}; + static SamePointer samePointer; + py::class_>(m, "SamePointer") + .def(py::init([]() { return &samePointer; })) + .def("__del__", [](SamePointer&) { py::print("__del__ called"); }); + + struct Empty {}; + py::class_(m, "Empty") + .def(py::init<>()); + + // test_base_and_derived_nested_scope + struct BaseWithNested { + struct Nested {}; + }; + + struct DerivedWithNested : BaseWithNested { + struct Nested {}; + }; + + py::class_ baseWithNested_class(m, "BaseWithNested"); + py::class_ derivedWithNested_class(m, "DerivedWithNested"); + py::class_(baseWithNested_class, "Nested") + .def_static("get_name", []() { return "BaseWithNested::Nested"; }); + py::class_(derivedWithNested_class, "Nested") + .def_static("get_name", []() { return "DerivedWithNested::Nested"; }); + + // test_register_duplicate_class + struct Duplicate {}; + struct OtherDuplicate {}; + struct DuplicateNested {}; + struct OtherDuplicateNested {}; + m.def("register_duplicate_class_name", [](py::module_ m) { + py::class_(m, "Duplicate"); + py::class_(m, "Duplicate"); + }); + m.def("register_duplicate_class_type", [](py::module_ m) { + py::class_(m, "OtherDuplicate"); + py::class_(m, "YetAnotherDuplicate"); + }); + m.def("register_duplicate_nested_class_name", [](py::object gt) { + py::class_(gt, "DuplicateNested"); + py::class_(gt, "DuplicateNested"); + }); + m.def("register_duplicate_nested_class_type", [](py::object gt) { + py::class_(gt, "OtherDuplicateNested"); + py::class_(gt, "YetAnotherDuplicateNested"); + }); } -template class BreaksBase { public: virtual ~BreaksBase() = default; }; +template class BreaksBase { public: + virtual ~BreaksBase() = default; + BreaksBase() = default; + BreaksBase(const BreaksBase&) = delete; +}; template class BreaksTramp : public BreaksBase {}; // These should all compile just fine: -typedef py::class_, std::unique_ptr>, BreaksTramp<1>> DoesntBreak1; -typedef py::class_, BreaksTramp<2>, std::unique_ptr>> DoesntBreak2; -typedef py::class_, std::unique_ptr>> DoesntBreak3; -typedef py::class_, BreaksTramp<4>> DoesntBreak4; -typedef py::class_> DoesntBreak5; -typedef py::class_, std::shared_ptr>, BreaksTramp<6>> DoesntBreak6; -typedef py::class_, BreaksTramp<7>, std::shared_ptr>> DoesntBreak7; -typedef py::class_, std::shared_ptr>> DoesntBreak8; +using DoesntBreak1 = py::class_, std::unique_ptr>, BreaksTramp<1>>; +using DoesntBreak2 = py::class_, BreaksTramp<2>, std::unique_ptr>>; +using DoesntBreak3 = py::class_, std::unique_ptr>>; +using DoesntBreak4 = py::class_, BreaksTramp<4>>; +using DoesntBreak5 = py::class_>; +using DoesntBreak6 = py::class_, std::shared_ptr>, BreaksTramp<6>>; +using DoesntBreak7 = py::class_, BreaksTramp<7>, std::shared_ptr>>; +using DoesntBreak8 = py::class_, std::shared_ptr>>; #define CHECK_BASE(N) static_assert(std::is_same>::value, \ "DoesntBreak" #N " has wrong type!") CHECK_BASE(1); CHECK_BASE(2); CHECK_BASE(3); CHECK_BASE(4); CHECK_BASE(5); CHECK_BASE(6); CHECK_BASE(7); CHECK_BASE(8); diff --git a/plugins/python/pybind11/tests/test_class.py b/plugins/python/pybind11/tests/test_class.py index 8cf4757..bdcced9 100644 --- a/plugins/python/pybind11/tests/test_class.py +++ b/plugins/python/pybind11/tests/test_class.py @@ -1,5 +1,8 @@ +# -*- coding: utf-8 -*- import pytest +import env # noqa: F401 + from pybind11_tests import class_ as m from pybind11_tests import UserType, ConstructorStats @@ -23,6 +26,48 @@ def test_instance(msg): assert cstats.alive() == 0 +def test_type(): + assert m.check_type(1) == m.DerivedClass1 + with pytest.raises(RuntimeError) as execinfo: + m.check_type(0) + + assert "pybind11::detail::get_type_info: unable to find type info" in str( + execinfo.value + ) + assert "Invalid" in str(execinfo.value) + + # Currently not supported + # See https://github.com/pybind/pybind11/issues/2486 + # assert m.check_type(2) == int + + +def test_type_of_py(): + assert m.get_type_of(1) == int + assert m.get_type_of(m.DerivedClass1()) == m.DerivedClass1 + assert m.get_type_of(int) == type + + +def test_type_of_classic(): + assert m.get_type_classic(1) == int + assert m.get_type_classic(m.DerivedClass1()) == m.DerivedClass1 + assert m.get_type_classic(int) == type + + +def test_type_of_py_nodelete(): + # If the above test deleted the class, this will segfault + assert m.get_type_of(m.DerivedClass1()) == m.DerivedClass1 + + +def test_as_type_py(): + assert m.as_type(int) == int + + with pytest.raises(TypeError): + assert m.as_type(1) == int + + with pytest.raises(TypeError): + assert m.as_type(m.DerivedClass1()) == m.DerivedClass1 + + def test_docstrings(doc): assert doc(UserType) == "A `py::class_` type for testing" assert UserType.__name__ == "UserType" @@ -30,18 +75,24 @@ def test_docstrings(doc): assert UserType.get_value.__name__ == "get_value" assert UserType.get_value.__module__ == "pybind11_tests" - assert doc(UserType.get_value) == """ + assert ( + doc(UserType.get_value) + == """ get_value(self: m.UserType) -> int Get value using a method """ + ) assert doc(UserType.value) == "Get/set value using a property" - assert doc(m.NoConstructor.new_instance) == """ + assert ( + doc(m.NoConstructor.new_instance) + == """ new_instance() -> m.class_.NoConstructor Return an instance """ + ) def test_qualname(doc): @@ -50,57 +101,98 @@ def test_qualname(doc): assert m.NestBase.__qualname__ == "NestBase" assert m.NestBase.Nested.__qualname__ == "NestBase.Nested" - assert doc(m.NestBase.__init__) == """ + assert ( + doc(m.NestBase.__init__) + == """ __init__(self: m.class_.NestBase) -> None """ - assert doc(m.NestBase.g) == """ + ) + assert ( + doc(m.NestBase.g) + == """ g(self: m.class_.NestBase, arg0: m.class_.NestBase.Nested) -> None """ - assert doc(m.NestBase.Nested.__init__) == """ + ) + assert ( + doc(m.NestBase.Nested.__init__) + == """ __init__(self: m.class_.NestBase.Nested) -> None """ - assert doc(m.NestBase.Nested.fn) == """ + ) + assert ( + doc(m.NestBase.Nested.fn) + == """ fn(self: m.class_.NestBase.Nested, arg0: int, arg1: m.class_.NestBase, arg2: m.class_.NestBase.Nested) -> None """ # noqa: E501 line too long - assert doc(m.NestBase.Nested.fa) == """ + ) + assert ( + doc(m.NestBase.Nested.fa) + == """ fa(self: m.class_.NestBase.Nested, a: int, b: m.class_.NestBase, c: m.class_.NestBase.Nested) -> None """ # noqa: E501 line too long + ) assert m.NestBase.__module__ == "pybind11_tests.class_" assert m.NestBase.Nested.__module__ == "pybind11_tests.class_" def test_inheritance(msg): - roger = m.Rabbit('Rabbit') + roger = m.Rabbit("Rabbit") assert roger.name() + " is a " + roger.species() == "Rabbit is a parrot" assert m.pet_name_species(roger) == "Rabbit is a parrot" - polly = m.Pet('Polly', 'parrot') + polly = m.Pet("Polly", "parrot") assert polly.name() + " is a " + polly.species() == "Polly is a parrot" assert m.pet_name_species(polly) == "Polly is a parrot" - molly = m.Dog('Molly') + molly = m.Dog("Molly") assert molly.name() + " is a " + molly.species() == "Molly is a dog" assert m.pet_name_species(molly) == "Molly is a dog" - fred = m.Hamster('Fred') + fred = m.Hamster("Fred") assert fred.name() + " is a " + fred.species() == "Fred is a rodent" assert m.dog_bark(molly) == "Woof!" with pytest.raises(TypeError) as excinfo: m.dog_bark(polly) - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ dog_bark(): incompatible function arguments. The following argument types are supported: 1. (arg0: m.class_.Dog) -> str Invoked with: """ + ) with pytest.raises(TypeError) as excinfo: m.Chimera("lion", "goat") assert "No constructor defined!" in str(excinfo.value) +def test_inheritance_init(msg): + + # Single base + class Python(m.Pet): + def __init__(self): + pass + + with pytest.raises(TypeError) as exc_info: + Python() + expected = "m.class_.Pet.__init__() must be called when overriding __init__" + assert msg(exc_info.value) == expected + + # Multiple bases + class RabbitHamster(m.Rabbit, m.Hamster): + def __init__(self): + m.Rabbit.__init__(self, "RabbitHamster") + + with pytest.raises(TypeError) as exc_info: + RabbitHamster() + expected = "m.class_.Hamster.__init__() must be called when overriding __init__" + assert msg(exc_info.value) == expected + + def test_automatic_upcasting(): assert type(m.return_class_1()).__name__ == "DerivedClass1" assert type(m.return_class_2()).__name__ == "DerivedClass2" @@ -126,13 +218,19 @@ def test_mismatched_holder(): with pytest.raises(RuntimeError) as excinfo: m.mismatched_holder_1() - assert re.match('generic_type: type ".*MismatchDerived1" does not have a non-default ' - 'holder type while its base ".*MismatchBase1" does', str(excinfo.value)) + assert re.match( + 'generic_type: type ".*MismatchDerived1" does not have a non-default ' + 'holder type while its base ".*MismatchBase1" does', + str(excinfo.value), + ) with pytest.raises(RuntimeError) as excinfo: m.mismatched_holder_2() - assert re.match('generic_type: type ".*MismatchDerived2" has a non-default holder type ' - 'while its base ".*MismatchBase2" does not', str(excinfo.value)) + assert re.match( + 'generic_type: type ".*MismatchDerived2" has a non-default holder type ' + 'while its base ".*MismatchBase2" does not', + str(excinfo.value), + ) def test_override_static(): @@ -164,20 +262,20 @@ class SubAliased(m.AliasedHasOpNewDelSize): a = m.HasOpNewDel() b = m.HasOpNewDelSize() d = m.HasOpNewDelBoth() - assert capture == """ + assert ( + capture + == """ A new 8 B new 4 D new 32 """ + ) sz_alias = str(m.AliasedHasOpNewDelSize.size_alias) sz_noalias = str(m.AliasedHasOpNewDelSize.size_noalias) with capture: c = m.AliasedHasOpNewDelSize() c2 = SubAliased() - assert capture == ( - "C new " + sz_noalias + "\n" + - "C new " + sz_alias + "\n" - ) + assert capture == ("C new " + sz_noalias + "\n" + "C new " + sz_alias + "\n") with capture: del a @@ -186,21 +284,21 @@ class SubAliased(m.AliasedHasOpNewDelSize): pytest.gc_collect() del d pytest.gc_collect() - assert capture == """ + assert ( + capture + == """ A delete B delete 4 D delete """ + ) with capture: del c pytest.gc_collect() del c2 pytest.gc_collect() - assert capture == ( - "C delete " + sz_noalias + "\n" + - "C delete " + sz_alias + "\n" - ) + assert capture == ("C delete " + sz_noalias + "\n" + "C delete " + sz_alias + "\n") def test_bind_protected_functions(): @@ -235,7 +333,7 @@ def test_brace_initialization(): assert b.vec == [123, 456] -@pytest.unsupported_on_pypy +@pytest.mark.xfail("env.PYPY") def test_class_refcount(): """Instances must correctly increase/decrease the reference count of their types (#1029)""" from sys import getrefcount @@ -260,9 +358,109 @@ def test_reentrant_implicit_conversion_failure(msg): # ensure that there is no runaway reentrant implicit conversion (#1035) with pytest.raises(TypeError) as excinfo: m.BogusImplicitConversion(0) - assert msg(excinfo.value) == ''' + assert ( + msg(excinfo.value) + == """ __init__(): incompatible constructor arguments. The following argument types are supported: 1. m.class_.BogusImplicitConversion(arg0: m.class_.BogusImplicitConversion) Invoked with: 0 - ''' + """ + ) + + +def test_error_after_conversions(): + with pytest.raises(TypeError) as exc_info: + m.test_error_after_conversions("hello") + assert str(exc_info.value).startswith( + "Unable to convert function return value to a Python type!" + ) + + +def test_aligned(): + if hasattr(m, "Aligned"): + p = m.Aligned().ptr() + assert p % 1024 == 0 + + +# https://foss.heptapod.net/pypy/pypy/-/issues/2742 +@pytest.mark.xfail("env.PYPY") +def test_final(): + with pytest.raises(TypeError) as exc_info: + + class PyFinalChild(m.IsFinal): + pass + + assert str(exc_info.value).endswith("is not an acceptable base type") + + +# https://foss.heptapod.net/pypy/pypy/-/issues/2742 +@pytest.mark.xfail("env.PYPY") +def test_non_final_final(): + with pytest.raises(TypeError) as exc_info: + + class PyNonFinalFinalChild(m.IsNonFinalFinal): + pass + + assert str(exc_info.value).endswith("is not an acceptable base type") + + +# https://github.com/pybind/pybind11/issues/1878 +def test_exception_rvalue_abort(): + with pytest.raises(RuntimeError): + m.PyPrintDestructor().throw_something() + + +# https://github.com/pybind/pybind11/issues/1568 +def test_multiple_instances_with_same_pointer(capture): + n = 100 + instances = [m.SamePointer() for _ in range(n)] + for i in range(n): + # We need to reuse the same allocated memory for with a different type, + # to ensure the bug in `deregister_instance_impl` is detected. Otherwise + # `Py_TYPE(self) == Py_TYPE(it->second)` will still succeed, even though + # the `instance` is already deleted. + instances[i] = m.Empty() + # No assert: if this does not trigger the error + # pybind11_fail("pybind11_object_dealloc(): Tried to deallocate unregistered instance!"); + # and just completes without crashing, we're good. + + +# https://github.com/pybind/pybind11/issues/1624 +def test_base_and_derived_nested_scope(): + assert issubclass(m.DerivedWithNested, m.BaseWithNested) + assert m.BaseWithNested.Nested != m.DerivedWithNested.Nested + assert m.BaseWithNested.Nested.get_name() == "BaseWithNested::Nested" + assert m.DerivedWithNested.Nested.get_name() == "DerivedWithNested::Nested" + + +def test_register_duplicate_class(): + import types + + module_scope = types.ModuleType("module_scope") + with pytest.raises(RuntimeError) as exc_info: + m.register_duplicate_class_name(module_scope) + expected = ( + 'generic_type: cannot initialize type "Duplicate": ' + "an object with that name is already defined" + ) + assert str(exc_info.value) == expected + with pytest.raises(RuntimeError) as exc_info: + m.register_duplicate_class_type(module_scope) + expected = 'generic_type: type "YetAnotherDuplicate" is already registered!' + assert str(exc_info.value) == expected + + class ClassScope: + pass + + with pytest.raises(RuntimeError) as exc_info: + m.register_duplicate_nested_class_name(ClassScope) + expected = ( + 'generic_type: cannot initialize type "DuplicateNested": ' + "an object with that name is already defined" + ) + assert str(exc_info.value) == expected + with pytest.raises(RuntimeError) as exc_info: + m.register_duplicate_nested_class_type(ClassScope) + expected = 'generic_type: type "YetAnotherDuplicateNested" is already registered!' + assert str(exc_info.value) == expected diff --git a/plugins/python/pybind11/tests/test_cmake_build/CMakeLists.txt b/plugins/python/pybind11/tests/test_cmake_build/CMakeLists.txt index c9b5fcb..0c0578a 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_cmake_build/CMakeLists.txt @@ -1,56 +1,77 @@ -add_custom_target(test_cmake_build) +# Built-in in CMake 3.5+ +include(CMakeParseArguments) -if(CMAKE_VERSION VERSION_LESS 3.1) - # 3.0 needed for interface library for subdirectory_target/installed_target - # 3.1 needed for cmake -E env for testing - return() -endif() +add_custom_target(test_cmake_build) -include(CMakeParseArguments) function(pybind11_add_build_test name) cmake_parse_arguments(ARG "INSTALL" "" "" ${ARGN}) - set(build_options "-DCMAKE_PREFIX_PATH=${PROJECT_BINARY_DIR}/mock_install" - "-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}" - "-DPYTHON_EXECUTABLE:FILEPATH=${PYTHON_EXECUTABLE}" - "-DPYBIND11_CPP_STANDARD=${PYBIND11_CPP_STANDARD}") + set(build_options "-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}") + + if(PYBIND11_FINDPYTHON) + list(APPEND build_options "-DPYBIND11_FINDPYTHON=${PYBIND11_FINDPYTHON}") + + if(DEFINED Python_ROOT_DIR) + list(APPEND build_options "-DPython_ROOT_DIR=${Python_ROOT_DIR}") + endif() + + list(APPEND build_options "-DPython_EXECUTABLE=${Python_EXECUTABLE}") + else() + list(APPEND build_options "-DPYTHON_EXECUTABLE=${PYTHON_EXECUTABLE}") + endif() + + if(DEFINED CMAKE_CXX_STANDARD) + list(APPEND build_options "-DCMAKE_CXX_STANDARD=${CMAKE_CXX_STANDARD}") + endif() + if(NOT ARG_INSTALL) - list(APPEND build_options "-DPYBIND11_PROJECT_DIR=${PROJECT_SOURCE_DIR}") + list(APPEND build_options "-DPYBIND11_PROJECT_DIR=${pybind11_SOURCE_DIR}") + else() + list(APPEND build_options "-DCMAKE_PREFIX_PATH=${pybind11_BINARY_DIR}/mock_install") endif() - add_custom_target(test_${name} ${CMAKE_CTEST_COMMAND} - --quiet --output-log ${name}.log - --build-and-test "${CMAKE_CURRENT_SOURCE_DIR}/${name}" - "${CMAKE_CURRENT_BINARY_DIR}/${name}" - --build-config Release + add_custom_target( + test_build_${name} + ${CMAKE_CTEST_COMMAND} + --build-and-test + "${CMAKE_CURRENT_SOURCE_DIR}/${name}" + "${CMAKE_CURRENT_BINARY_DIR}/${name}" + --build-config + Release --build-noclean - --build-generator ${CMAKE_GENERATOR} - $<$:--build-generator-platform> ${CMAKE_GENERATOR_PLATFORM} - --build-makeprogram ${CMAKE_MAKE_PROGRAM} - --build-target check - --build-options ${build_options} - ) + --build-generator + ${CMAKE_GENERATOR} + $<$:--build-generator-platform> + ${CMAKE_GENERATOR_PLATFORM} + --build-makeprogram + ${CMAKE_MAKE_PROGRAM} + --build-target + check_${name} + --build-options + ${build_options}) if(ARG_INSTALL) - add_dependencies(test_${name} mock_install) + add_dependencies(test_build_${name} mock_install) endif() - add_dependencies(test_cmake_build test_${name}) + add_dependencies(test_cmake_build test_build_${name}) endfunction() pybind11_add_build_test(subdirectory_function) pybind11_add_build_test(subdirectory_target) -if(NOT ${PYTHON_MODULE_EXTENSION} MATCHES "pypy") +if("${PYTHON_MODULE_EXTENSION}" MATCHES "pypy" OR "${Python_INTERPRETER_ID}" STREQUAL "PyPy") + message(STATUS "Skipping embed test on PyPy") +else() pybind11_add_build_test(subdirectory_embed) endif() if(PYBIND11_INSTALL) - add_custom_target(mock_install ${CMAKE_COMMAND} - "-DCMAKE_INSTALL_PREFIX=${PROJECT_BINARY_DIR}/mock_install" - -P "${PROJECT_BINARY_DIR}/cmake_install.cmake" - ) + add_custom_target( + mock_install ${CMAKE_COMMAND} "-DCMAKE_INSTALL_PREFIX=${pybind11_BINARY_DIR}/mock_install" -P + "${pybind11_BINARY_DIR}/cmake_install.cmake") pybind11_add_build_test(installed_function INSTALL) pybind11_add_build_test(installed_target INSTALL) - if(NOT ${PYTHON_MODULE_EXTENSION} MATCHES "pypy") + if(NOT ("${PYTHON_MODULE_EXTENSION}" MATCHES "pypy" OR "${Python_INTERPRETER_ID}" STREQUAL "PyPy" + )) pybind11_add_build_test(installed_embed INSTALL) endif() endif() diff --git a/plugins/python/pybind11/tests/test_cmake_build/embed.cpp b/plugins/python/pybind11/tests/test_cmake_build/embed.cpp index b9581d2..a3abc8a 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/embed.cpp +++ b/plugins/python/pybind11/tests/test_cmake_build/embed.cpp @@ -12,10 +12,10 @@ int main(int argc, char *argv[]) { py::scoped_interpreter guard{}; - auto m = py::module::import("test_cmake_build"); + auto m = py::module_::import("test_cmake_build"); if (m.attr("add")(1, 2).cast() != 3) throw std::runtime_error("embed.cpp failed"); - py::module::import("sys").attr("argv") = py::make_tuple("test.py", "embed.cpp"); + py::module_::import("sys").attr("argv") = py::make_tuple("test.py", "embed.cpp"); py::eval_file(test_py_file, py::globals()); } diff --git a/plugins/python/pybind11/tests/test_cmake_build/installed_embed/CMakeLists.txt b/plugins/python/pybind11/tests/test_cmake_build/installed_embed/CMakeLists.txt index f7fc09c..64ae5c4 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/installed_embed/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_cmake_build/installed_embed/CMakeLists.txt @@ -1,15 +1,26 @@ -cmake_minimum_required(VERSION 3.0) +cmake_minimum_required(VERSION 3.4) + +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) +endif() + project(test_installed_embed CXX) -set(CMAKE_MODULE_PATH "") find_package(pybind11 CONFIG REQUIRED) message(STATUS "Found pybind11 v${pybind11_VERSION}: ${pybind11_INCLUDE_DIRS}") -add_executable(test_cmake_build ../embed.cpp) -target_link_libraries(test_cmake_build PRIVATE pybind11::embed) +add_executable(test_installed_embed ../embed.cpp) +target_link_libraries(test_installed_embed PRIVATE pybind11::embed) +set_target_properties(test_installed_embed PROPERTIES OUTPUT_NAME test_cmake_build) # Do not treat includes from IMPORTED target as SYSTEM (Python headers in pybind11::embed). # This may be needed to resolve header conflicts, e.g. between Python release and debug headers. -set_target_properties(test_cmake_build PROPERTIES NO_SYSTEM_FROM_IMPORTED ON) +set_target_properties(test_installed_embed PROPERTIES NO_SYSTEM_FROM_IMPORTED ON) -add_custom_target(check $ ${PROJECT_SOURCE_DIR}/../test.py) +add_custom_target(check_installed_embed $ + ${PROJECT_SOURCE_DIR}/../test.py) diff --git a/plugins/python/pybind11/tests/test_cmake_build/installed_function/CMakeLists.txt b/plugins/python/pybind11/tests/test_cmake_build/installed_function/CMakeLists.txt index e0c20a8..1a50286 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/installed_function/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_cmake_build/installed_function/CMakeLists.txt @@ -1,12 +1,38 @@ -cmake_minimum_required(VERSION 2.8.12) +cmake_minimum_required(VERSION 3.4) project(test_installed_module CXX) -set(CMAKE_MODULE_PATH "") +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) +endif() + +project(test_installed_function CXX) find_package(pybind11 CONFIG REQUIRED) -message(STATUS "Found pybind11 v${pybind11_VERSION}: ${pybind11_INCLUDE_DIRS}") +message( + STATUS "Found pybind11 v${pybind11_VERSION} ${pybind11_VERSION_TYPE}: ${pybind11_INCLUDE_DIRS}") + +pybind11_add_module(test_installed_function SHARED NO_EXTRAS ../main.cpp) +set_target_properties(test_installed_function PROPERTIES OUTPUT_NAME test_cmake_build) -pybind11_add_module(test_cmake_build SHARED NO_EXTRAS ../main.cpp) +if(DEFINED Python_EXECUTABLE) + set(_Python_EXECUTABLE "${Python_EXECUTABLE}") +elseif(DEFINED PYTHON_EXECUTABLE) + set(_Python_EXECUTABLE "${PYTHON_EXECUTABLE}") +else() + message(FATAL_ERROR "No Python executable defined (should not be possible at this stage)") +endif() -add_custom_target(check ${CMAKE_COMMAND} -E env PYTHONPATH=$ - ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/../test.py ${PROJECT_NAME}) +add_custom_target( + check_installed_function + ${CMAKE_COMMAND} + -E + env + PYTHONPATH=$ + ${_Python_EXECUTABLE} + ${PROJECT_SOURCE_DIR}/../test.py + ${PROJECT_NAME}) diff --git a/plugins/python/pybind11/tests/test_cmake_build/installed_target/CMakeLists.txt b/plugins/python/pybind11/tests/test_cmake_build/installed_target/CMakeLists.txt index cd3ae6f..b38eb77 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/installed_target/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_cmake_build/installed_target/CMakeLists.txt @@ -1,22 +1,45 @@ -cmake_minimum_required(VERSION 3.0) -project(test_installed_target CXX) +cmake_minimum_required(VERSION 3.4) + +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) +endif() -set(CMAKE_MODULE_PATH "") +project(test_installed_target CXX) find_package(pybind11 CONFIG REQUIRED) message(STATUS "Found pybind11 v${pybind11_VERSION}: ${pybind11_INCLUDE_DIRS}") -add_library(test_cmake_build MODULE ../main.cpp) +add_library(test_installed_target MODULE ../main.cpp) -target_link_libraries(test_cmake_build PRIVATE pybind11::module) +target_link_libraries(test_installed_target PRIVATE pybind11::module) +set_target_properties(test_installed_target PROPERTIES OUTPUT_NAME test_cmake_build) -# make sure result is, for example, test_installed_target.so, not libtest_installed_target.dylib -set_target_properties(test_cmake_build PROPERTIES PREFIX "${PYTHON_MODULE_PREFIX}" - SUFFIX "${PYTHON_MODULE_EXTENSION}") +# Make sure result is, for example, test_installed_target.so, not libtest_installed_target.dylib +pybind11_extension(test_installed_target) # Do not treat includes from IMPORTED target as SYSTEM (Python headers in pybind11::module). # This may be needed to resolve header conflicts, e.g. between Python release and debug headers. -set_target_properties(test_cmake_build PROPERTIES NO_SYSTEM_FROM_IMPORTED ON) +set_target_properties(test_installed_target PROPERTIES NO_SYSTEM_FROM_IMPORTED ON) + +if(DEFINED Python_EXECUTABLE) + set(_Python_EXECUTABLE "${Python_EXECUTABLE}") +elseif(DEFINED PYTHON_EXECUTABLE) + set(_Python_EXECUTABLE "${PYTHON_EXECUTABLE}") +else() + message(FATAL_ERROR "No Python executable defined (should not be possible at this stage)") +endif() -add_custom_target(check ${CMAKE_COMMAND} -E env PYTHONPATH=$ - ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/../test.py ${PROJECT_NAME}) +add_custom_target( + check_installed_target + ${CMAKE_COMMAND} + -E + env + PYTHONPATH=$ + ${_Python_EXECUTABLE} + ${PROJECT_SOURCE_DIR}/../test.py + ${PROJECT_NAME}) diff --git a/plugins/python/pybind11/tests/test_cmake_build/subdirectory_embed/CMakeLists.txt b/plugins/python/pybind11/tests/test_cmake_build/subdirectory_embed/CMakeLists.txt index 88ba60d..c7df0cf 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/subdirectory_embed/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_cmake_build/subdirectory_embed/CMakeLists.txt @@ -1,25 +1,39 @@ -cmake_minimum_required(VERSION 3.0) +cmake_minimum_required(VERSION 3.4) + +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) +endif() + project(test_subdirectory_embed CXX) -set(PYBIND11_INSTALL ON CACHE BOOL "") +set(PYBIND11_INSTALL + ON + CACHE BOOL "") set(PYBIND11_EXPORT_NAME test_export) add_subdirectory(${PYBIND11_PROJECT_DIR} pybind11) # Test basic target functionality -add_executable(test_cmake_build ../embed.cpp) -target_link_libraries(test_cmake_build PRIVATE pybind11::embed) +add_executable(test_subdirectory_embed ../embed.cpp) +target_link_libraries(test_subdirectory_embed PRIVATE pybind11::embed) +set_target_properties(test_subdirectory_embed PROPERTIES OUTPUT_NAME test_cmake_build) -add_custom_target(check $ ${PROJECT_SOURCE_DIR}/../test.py) +add_custom_target(check_subdirectory_embed $ + ${PROJECT_SOURCE_DIR}/../test.py) # Test custom export group -- PYBIND11_EXPORT_NAME add_library(test_embed_lib ../embed.cpp) target_link_libraries(test_embed_lib PRIVATE pybind11::embed) -install(TARGETS test_embed_lib - EXPORT test_export - ARCHIVE DESTINATION bin - LIBRARY DESTINATION lib - RUNTIME DESTINATION lib) -install(EXPORT test_export - DESTINATION lib/cmake/test_export/test_export-Targets.cmake) +install( + TARGETS test_embed_lib + EXPORT test_export + ARCHIVE DESTINATION bin + LIBRARY DESTINATION lib + RUNTIME DESTINATION lib) +install(EXPORT test_export DESTINATION lib/cmake/test_export/test_export-Targets.cmake) diff --git a/plugins/python/pybind11/tests/test_cmake_build/subdirectory_function/CMakeLists.txt b/plugins/python/pybind11/tests/test_cmake_build/subdirectory_function/CMakeLists.txt index 278007a..624c600 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/subdirectory_function/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_cmake_build/subdirectory_function/CMakeLists.txt @@ -1,8 +1,34 @@ -cmake_minimum_required(VERSION 2.8.12) -project(test_subdirectory_module CXX) +cmake_minimum_required(VERSION 3.4) -add_subdirectory(${PYBIND11_PROJECT_DIR} pybind11) -pybind11_add_module(test_cmake_build THIN_LTO ../main.cpp) +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) +endif() -add_custom_target(check ${CMAKE_COMMAND} -E env PYTHONPATH=$ - ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/../test.py ${PROJECT_NAME}) +project(test_subdirectory_function CXX) + +add_subdirectory("${PYBIND11_PROJECT_DIR}" pybind11) +pybind11_add_module(test_subdirectory_function ../main.cpp) +set_target_properties(test_subdirectory_function PROPERTIES OUTPUT_NAME test_cmake_build) + +if(DEFINED Python_EXECUTABLE) + set(_Python_EXECUTABLE "${Python_EXECUTABLE}") +elseif(DEFINED PYTHON_EXECUTABLE) + set(_Python_EXECUTABLE "${PYTHON_EXECUTABLE}") +else() + message(FATAL_ERROR "No Python executable defined (should not be possible at this stage)") +endif() + +add_custom_target( + check_subdirectory_function + ${CMAKE_COMMAND} + -E + env + PYTHONPATH=$ + ${_Python_EXECUTABLE} + ${PROJECT_SOURCE_DIR}/../test.py + ${PROJECT_NAME}) diff --git a/plugins/python/pybind11/tests/test_cmake_build/subdirectory_target/CMakeLists.txt b/plugins/python/pybind11/tests/test_cmake_build/subdirectory_target/CMakeLists.txt index 6b142d6..2471941 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/subdirectory_target/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_cmake_build/subdirectory_target/CMakeLists.txt @@ -1,15 +1,40 @@ -cmake_minimum_required(VERSION 3.0) +cmake_minimum_required(VERSION 3.4) + +# The `cmake_minimum_required(VERSION 3.4...3.18)` syntax does not work with +# some versions of VS that have a patched CMake 3.11. This forces us to emulate +# the behavior using the following workaround: +if(${CMAKE_VERSION} VERSION_LESS 3.18) + cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) +else() + cmake_policy(VERSION 3.18) +endif() + project(test_subdirectory_target CXX) add_subdirectory(${PYBIND11_PROJECT_DIR} pybind11) -add_library(test_cmake_build MODULE ../main.cpp) +add_library(test_subdirectory_target MODULE ../main.cpp) +set_target_properties(test_subdirectory_target PROPERTIES OUTPUT_NAME test_cmake_build) + +target_link_libraries(test_subdirectory_target PRIVATE pybind11::module) -target_link_libraries(test_cmake_build PRIVATE pybind11::module) +# Make sure result is, for example, test_installed_target.so, not libtest_installed_target.dylib +pybind11_extension(test_subdirectory_target) -# make sure result is, for example, test_installed_target.so, not libtest_installed_target.dylib -set_target_properties(test_cmake_build PROPERTIES PREFIX "${PYTHON_MODULE_PREFIX}" - SUFFIX "${PYTHON_MODULE_EXTENSION}") +if(DEFINED Python_EXECUTABLE) + set(_Python_EXECUTABLE "${Python_EXECUTABLE}") +elseif(DEFINED PYTHON_EXECUTABLE) + set(_Python_EXECUTABLE "${PYTHON_EXECUTABLE}") +else() + message(FATAL_ERROR "No Python executable defined (should not be possible at this stage)") +endif() -add_custom_target(check ${CMAKE_COMMAND} -E env PYTHONPATH=$ - ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/../test.py ${PROJECT_NAME}) +add_custom_target( + check_subdirectory_target + ${CMAKE_COMMAND} + -E + env + PYTHONPATH=$ + ${_Python_EXECUTABLE} + ${PROJECT_SOURCE_DIR}/../test.py + ${PROJECT_NAME}) diff --git a/plugins/python/pybind11/tests/test_cmake_build/test.py b/plugins/python/pybind11/tests/test_cmake_build/test.py index 1467a61..87ed513 100644 --- a/plugins/python/pybind11/tests/test_cmake_build/test.py +++ b/plugins/python/pybind11/tests/test_cmake_build/test.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- import sys import test_cmake_build diff --git a/plugins/python/pybind11/tests/test_constants_and_functions.cpp b/plugins/python/pybind11/tests/test_constants_and_functions.cpp index 8c9ef7f..f607795 100644 --- a/plugins/python/pybind11/tests/test_constants_and_functions.cpp +++ b/plugins/python/pybind11/tests/test_constants_and_functions.cpp @@ -49,7 +49,14 @@ namespace test_exc_sp { int f1(int x) noexcept { return x+1; } int f2(int x) noexcept(true) { return x+2; } int f3(int x) noexcept(false) { return x+3; } +#if defined(__GNUG__) +# pragma GCC diagnostic push +# pragma GCC diagnostic ignored "-Wdeprecated" +#endif int f4(int x) throw() { return x+4; } // Deprecated equivalent to noexcept(true) +#if defined(__GNUG__) +# pragma GCC diagnostic pop +#endif struct C { int m1(int x) noexcept { return x-1; } int m2(int x) const noexcept { return x-2; } @@ -57,10 +64,17 @@ struct C { int m4(int x) const noexcept(true) { return x-4; } int m5(int x) noexcept(false) { return x-5; } int m6(int x) const noexcept(false) { return x-6; } +#if defined(__GNUG__) +# pragma GCC diagnostic push +# pragma GCC diagnostic ignored "-Wdeprecated" +#endif int m7(int x) throw() { return x-7; } int m8(int x) const throw() { return x-8; } +#if defined(__GNUG__) +# pragma GCC diagnostic pop +#endif }; -} +} // namespace test_exc_sp TEST_SUBMODULE(constants_and_functions, m) { diff --git a/plugins/python/pybind11/tests/test_constants_and_functions.py b/plugins/python/pybind11/tests/test_constants_and_functions.py index 472682d..b980ccf 100644 --- a/plugins/python/pybind11/tests/test_constants_and_functions.py +++ b/plugins/python/pybind11/tests/test_constants_and_functions.py @@ -1,4 +1,7 @@ -from pybind11_tests import constants_and_functions as m +# -*- coding: utf-8 -*- +import pytest + +m = pytest.importorskip("pybind11_tests.constants_and_functions") def test_constants(): diff --git a/plugins/python/pybind11/tests/test_copy_move.cpp b/plugins/python/pybind11/tests/test_copy_move.cpp index 94113e3..2704217 100644 --- a/plugins/python/pybind11/tests/test_copy_move.cpp +++ b/plugins/python/pybind11/tests/test_copy_move.cpp @@ -19,14 +19,14 @@ struct empty { }; struct lacking_copy_ctor : public empty { - lacking_copy_ctor() {} + lacking_copy_ctor() = default; lacking_copy_ctor(const lacking_copy_ctor& other) = delete; }; template <> lacking_copy_ctor empty::instance_ = {}; struct lacking_move_ctor : public empty { - lacking_move_ctor() {} + lacking_move_ctor() = default; lacking_move_ctor(const lacking_move_ctor& other) = delete; lacking_move_ctor(lacking_move_ctor&& other) = delete; }; @@ -68,8 +68,8 @@ class CopyOnlyInt { int value; }; -NAMESPACE_BEGIN(pybind11) -NAMESPACE_BEGIN(detail) +PYBIND11_NAMESPACE_BEGIN(pybind11) +PYBIND11_NAMESPACE_BEGIN(detail) template <> struct type_caster { PYBIND11_TYPE_CASTER(MoveOnlyInt, _("MoveOnlyInt")); bool load(handle src, bool) { value = MoveOnlyInt(src.cast()); return true; } @@ -86,7 +86,7 @@ template <> struct type_caster { protected: CopyOnlyInt value; public: - static PYBIND11_DESCR name() { return _("CopyOnlyInt"); } + static constexpr auto name = _("CopyOnlyInt"); bool load(handle src, bool) { value = CopyOnlyInt(src.cast()); return true; } static handle cast(const CopyOnlyInt &m, return_value_policy r, handle p) { return pybind11::cast(m.value, r, p); } static handle cast(const CopyOnlyInt *src, return_value_policy policy, handle parent) { @@ -97,8 +97,8 @@ template <> struct type_caster { operator CopyOnlyInt&() { return value; } template using cast_op_type = pybind11::detail::cast_op_type; }; -NAMESPACE_END(detail) -NAMESPACE_END(pybind11) +PYBIND11_NAMESPACE_END(detail) +PYBIND11_NAMESPACE_END(pybind11) TEST_SUBMODULE(copy_move_policies, m) { // test_lacking_copy_ctor @@ -116,9 +116,9 @@ TEST_SUBMODULE(copy_move_policies, m) { r += py::cast(o).value; /* moves */ r += py::cast(o).value; /* moves */ r += py::cast(o).value; /* copies */ - MoveOrCopyInt m1(py::cast(o)); /* moves */ - MoveOnlyInt m2(py::cast(o)); /* moves */ - CopyOnlyInt m3(py::cast(o)); /* copies */ + auto m1(py::cast(o)); /* moves */ + auto m2(py::cast(o)); /* moves */ + auto m3(py::cast(o)); /* copies */ r += m1.value + m2.value + m3.value; return r; @@ -175,14 +175,20 @@ TEST_SUBMODULE(copy_move_policies, m) { m.attr("has_optional") = false; #endif - // #70 compilation issue if operator new is not public + // #70 compilation issue if operator new is not public - simple body added + // but not needed on most compilers; MSVC and nvcc don't like a local + // struct not having a method defined when declared, since it can not be + // added later. struct PrivateOpNew { int value = 1; private: -#if defined(_MSC_VER) -# pragma warning(disable: 4822) // warning C4822: local class member function does not have a body -#endif - void *operator new(size_t bytes); + void *operator new(size_t bytes) { + void *ptr = std::malloc(bytes); + if (ptr) + return ptr; + else + throw std::bad_alloc{}; + } }; py::class_(m, "PrivateOpNew").def_readonly("value", &PrivateOpNew::value); m.def("private_op_new_value", []() { return PrivateOpNew(); }); diff --git a/plugins/python/pybind11/tests/test_copy_move.py b/plugins/python/pybind11/tests/test_copy_move.py index aff2d99..7e3cc16 100644 --- a/plugins/python/pybind11/tests/test_copy_move.py +++ b/plugins/python/pybind11/tests/test_copy_move.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import copy_move_policies as m @@ -5,20 +6,24 @@ def test_lacking_copy_ctor(): with pytest.raises(RuntimeError) as excinfo: m.lacking_copy_ctor.get_one() - assert "the object is non-copyable!" in str(excinfo.value) + assert "is non-copyable!" in str(excinfo.value) def test_lacking_move_ctor(): with pytest.raises(RuntimeError) as excinfo: m.lacking_move_ctor.get_one() - assert "the object is neither movable nor copyable!" in str(excinfo.value) + assert "is neither movable nor copyable!" in str(excinfo.value) def test_move_and_copy_casts(): """Cast some values in C++ via custom type casters and count the number of moves/copies.""" cstats = m.move_and_copy_cstats() - c_m, c_mc, c_c = cstats["MoveOnlyInt"], cstats["MoveOrCopyInt"], cstats["CopyOnlyInt"] + c_m, c_mc, c_c = ( + cstats["MoveOnlyInt"], + cstats["MoveOrCopyInt"], + cstats["CopyOnlyInt"], + ) # The type move constructions/assignments below each get incremented: the move assignment comes # from the type_caster load; the move construction happens when extracting that via a cast or @@ -42,7 +47,11 @@ def test_move_and_copy_loads(): moves/copies.""" cstats = m.move_and_copy_cstats() - c_m, c_mc, c_c = cstats["MoveOnlyInt"], cstats["MoveOrCopyInt"], cstats["CopyOnlyInt"] + c_m, c_mc, c_c = ( + cstats["MoveOnlyInt"], + cstats["MoveOrCopyInt"], + cstats["CopyOnlyInt"], + ) assert m.move_only(10) == 10 # 1 move, c_m assert m.move_or_copy(11) == 11 # 1 move, c_mc @@ -65,12 +74,16 @@ def test_move_and_copy_loads(): assert c_m.alive() + c_mc.alive() + c_c.alive() == 0 -@pytest.mark.skipif(not m.has_optional, reason='no ') +@pytest.mark.skipif(not m.has_optional, reason="no ") def test_move_and_copy_load_optional(): """Tests move/copy loads of std::optional arguments""" cstats = m.move_and_copy_cstats() - c_m, c_mc, c_c = cstats["MoveOnlyInt"], cstats["MoveOrCopyInt"], cstats["CopyOnlyInt"] + c_m, c_mc, c_c = ( + cstats["MoveOnlyInt"], + cstats["MoveOrCopyInt"], + cstats["CopyOnlyInt"], + ) # The extra move/copy constructions below come from the std::optional move (which has to move # its arguments): @@ -98,7 +111,7 @@ def test_private_op_new(): with pytest.raises(RuntimeError) as excinfo: m.private_op_new_value() - assert "the object is neither movable nor copyable" in str(excinfo.value) + assert "is neither movable nor copyable" in str(excinfo.value) assert m.private_op_new_reference().value == 1 diff --git a/plugins/python/pybind11/tests/test_custom_type_casters.cpp b/plugins/python/pybind11/tests/test_custom_type_casters.cpp new file mode 100644 index 0000000..d565add --- /dev/null +++ b/plugins/python/pybind11/tests/test_custom_type_casters.cpp @@ -0,0 +1,127 @@ +/* + tests/test_custom_type_casters.cpp -- tests type_caster + + Copyright (c) 2016 Wenzel Jakob + + All rights reserved. Use of this source code is governed by a + BSD-style license that can be found in the LICENSE file. +*/ + +#include "pybind11_tests.h" +#include "constructor_stats.h" + + +// py::arg/py::arg_v testing: these arguments just record their argument when invoked +class ArgInspector1 { public: std::string arg = "(default arg inspector 1)"; }; +class ArgInspector2 { public: std::string arg = "(default arg inspector 2)"; }; +class ArgAlwaysConverts { }; +namespace pybind11 { namespace detail { +template <> struct type_caster { +public: + PYBIND11_TYPE_CASTER(ArgInspector1, _("ArgInspector1")); + + bool load(handle src, bool convert) { + value.arg = "loading ArgInspector1 argument " + + std::string(convert ? "WITH" : "WITHOUT") + " conversion allowed. " + "Argument value = " + (std::string) str(src); + return true; + } + + static handle cast(const ArgInspector1 &src, return_value_policy, handle) { + return str(src.arg).release(); + } +}; +template <> struct type_caster { +public: + PYBIND11_TYPE_CASTER(ArgInspector2, _("ArgInspector2")); + + bool load(handle src, bool convert) { + value.arg = "loading ArgInspector2 argument " + + std::string(convert ? "WITH" : "WITHOUT") + " conversion allowed. " + "Argument value = " + (std::string) str(src); + return true; + } + + static handle cast(const ArgInspector2 &src, return_value_policy, handle) { + return str(src.arg).release(); + } +}; +template <> struct type_caster { +public: + PYBIND11_TYPE_CASTER(ArgAlwaysConverts, _("ArgAlwaysConverts")); + + bool load(handle, bool convert) { + return convert; + } + + static handle cast(const ArgAlwaysConverts &, return_value_policy, handle) { + return py::none().release(); + } +}; +} // namespace detail +} // namespace pybind11 + +// test_custom_caster_destruction +class DestructionTester { +public: + DestructionTester() { print_default_created(this); } + ~DestructionTester() { print_destroyed(this); } + DestructionTester(const DestructionTester &) { print_copy_created(this); } + DestructionTester(DestructionTester &&) { print_move_created(this); } + DestructionTester &operator=(const DestructionTester &) { print_copy_assigned(this); return *this; } + DestructionTester &operator=(DestructionTester &&) { print_move_assigned(this); return *this; } +}; +namespace pybind11 { namespace detail { +template <> struct type_caster { + PYBIND11_TYPE_CASTER(DestructionTester, _("DestructionTester")); + bool load(handle, bool) { return true; } + + static handle cast(const DestructionTester &, return_value_policy, handle) { + return py::bool_(true).release(); + } +}; +} // namespace detail +} // namespace pybind11 + +TEST_SUBMODULE(custom_type_casters, m) { + // test_custom_type_casters + + // test_noconvert_args + // + // Test converting. The ArgAlwaysConverts is just there to make the first no-conversion pass + // fail so that our call always ends up happening via the second dispatch (the one that allows + // some conversion). + class ArgInspector { + public: + ArgInspector1 f(ArgInspector1 a, ArgAlwaysConverts) { return a; } + std::string g(ArgInspector1 a, const ArgInspector1 &b, int c, ArgInspector2 *d, ArgAlwaysConverts) { + return a.arg + "\n" + b.arg + "\n" + std::to_string(c) + "\n" + d->arg; + } + static ArgInspector2 h(ArgInspector2 a, ArgAlwaysConverts) { return a; } + }; + py::class_(m, "ArgInspector") + .def(py::init<>()) + .def("f", &ArgInspector::f, py::arg(), py::arg() = ArgAlwaysConverts()) + .def("g", &ArgInspector::g, "a"_a.noconvert(), "b"_a, "c"_a.noconvert()=13, "d"_a=ArgInspector2(), py::arg() = ArgAlwaysConverts()) + .def_static("h", &ArgInspector::h, py::arg().noconvert(), py::arg() = ArgAlwaysConverts()) + ; + m.def("arg_inspect_func", [](ArgInspector2 a, ArgInspector1 b, ArgAlwaysConverts) { return a.arg + "\n" + b.arg; }, + py::arg().noconvert(false), py::arg_v(nullptr, ArgInspector1()).noconvert(true), py::arg() = ArgAlwaysConverts()); + + m.def("floats_preferred", [](double f) { return 0.5 * f; }, py::arg("f")); + m.def("floats_only", [](double f) { return 0.5 * f; }, py::arg("f").noconvert()); + m.def("ints_preferred", [](int i) { return i / 2; }, py::arg("i")); + m.def("ints_only", [](int i) { return i / 2; }, py::arg("i").noconvert()); + + // test_custom_caster_destruction + // Test that `take_ownership` works on types with a custom type caster when given a pointer + + // default policy: don't take ownership: + m.def("custom_caster_no_destroy", []() { static auto *dt = new DestructionTester(); return dt; }); + + m.def("custom_caster_destroy", []() { return new DestructionTester(); }, + py::return_value_policy::take_ownership); // Takes ownership: destroy when finished + m.def("custom_caster_destroy_const", []() -> const DestructionTester * { return new DestructionTester(); }, + py::return_value_policy::take_ownership); // Likewise (const doesn't inhibit destruction) + m.def("destruction_tester_cstats", &ConstructorStats::get, py::return_value_policy::reference); +} diff --git a/plugins/python/pybind11/tests/test_custom_type_casters.py b/plugins/python/pybind11/tests/test_custom_type_casters.py new file mode 100644 index 0000000..bb74d54 --- /dev/null +++ b/plugins/python/pybind11/tests/test_custom_type_casters.py @@ -0,0 +1,116 @@ +# -*- coding: utf-8 -*- +import pytest +from pybind11_tests import custom_type_casters as m + + +def test_noconvert_args(msg): + a = m.ArgInspector() + assert ( + msg(a.f("hi")) + == """ + loading ArgInspector1 argument WITH conversion allowed. Argument value = hi + """ + ) + assert ( + msg(a.g("this is a", "this is b")) + == """ + loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = this is a + loading ArgInspector1 argument WITH conversion allowed. Argument value = this is b + 13 + loading ArgInspector2 argument WITH conversion allowed. Argument value = (default arg inspector 2) + """ # noqa: E501 line too long + ) + assert ( + msg(a.g("this is a", "this is b", 42)) + == """ + loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = this is a + loading ArgInspector1 argument WITH conversion allowed. Argument value = this is b + 42 + loading ArgInspector2 argument WITH conversion allowed. Argument value = (default arg inspector 2) + """ # noqa: E501 line too long + ) + assert ( + msg(a.g("this is a", "this is b", 42, "this is d")) + == """ + loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = this is a + loading ArgInspector1 argument WITH conversion allowed. Argument value = this is b + 42 + loading ArgInspector2 argument WITH conversion allowed. Argument value = this is d + """ + ) + assert ( + a.h("arg 1") + == "loading ArgInspector2 argument WITHOUT conversion allowed. Argument value = arg 1" + ) + assert ( + msg(m.arg_inspect_func("A1", "A2")) + == """ + loading ArgInspector2 argument WITH conversion allowed. Argument value = A1 + loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = A2 + """ + ) + + assert m.floats_preferred(4) == 2.0 + assert m.floats_only(4.0) == 2.0 + with pytest.raises(TypeError) as excinfo: + m.floats_only(4) + assert ( + msg(excinfo.value) + == """ + floats_only(): incompatible function arguments. The following argument types are supported: + 1. (f: float) -> float + + Invoked with: 4 + """ + ) + + assert m.ints_preferred(4) == 2 + assert m.ints_preferred(True) == 0 + with pytest.raises(TypeError) as excinfo: + m.ints_preferred(4.0) + assert ( + msg(excinfo.value) + == """ + ints_preferred(): incompatible function arguments. The following argument types are supported: + 1. (i: int) -> int + + Invoked with: 4.0 + """ # noqa: E501 line too long + ) + + assert m.ints_only(4) == 2 + with pytest.raises(TypeError) as excinfo: + m.ints_only(4.0) + assert ( + msg(excinfo.value) + == """ + ints_only(): incompatible function arguments. The following argument types are supported: + 1. (i: int) -> int + + Invoked with: 4.0 + """ + ) + + +def test_custom_caster_destruction(): + """Tests that returning a pointer to a type that gets converted with a custom type caster gets + destroyed when the function has py::return_value_policy::take_ownership policy applied.""" + + cstats = m.destruction_tester_cstats() + # This one *doesn't* have take_ownership: the pointer should be used but not destroyed: + z = m.custom_caster_no_destroy() + assert cstats.alive() == 1 and cstats.default_constructions == 1 + assert z + + # take_ownership applied: this constructs a new object, casts it, then destroys it: + z = m.custom_caster_destroy() + assert z + assert cstats.default_constructions == 2 + + # Same, but with a const pointer return (which should *not* inhibit destruction): + z = m.custom_caster_destroy_const() + assert z + assert cstats.default_constructions == 3 + + # Make sure we still only have the original object (from ..._no_destroy()) alive: + assert cstats.alive() == 1 diff --git a/plugins/python/pybind11/tests/test_docstring_options.py b/plugins/python/pybind11/tests/test_docstring_options.py index 0dbca60..87d80d2 100644 --- a/plugins/python/pybind11/tests/test_docstring_options.py +++ b/plugins/python/pybind11/tests/test_docstring_options.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- from pybind11_tests import docstring_options as m @@ -17,10 +18,10 @@ def test_docstring_options(): assert m.test_overloaded3.__doc__ == "Overload docstr" # options.enable_function_signatures() - assert m.test_function3.__doc__ .startswith("test_function3(a: int, b: int) -> None") + assert m.test_function3.__doc__.startswith("test_function3(a: int, b: int) -> None") - assert m.test_function4.__doc__ .startswith("test_function4(a: int, b: int) -> None") - assert m.test_function4.__doc__ .endswith("A custom docstring\n") + assert m.test_function4.__doc__.startswith("test_function4(a: int, b: int) -> None") + assert m.test_function4.__doc__.endswith("A custom docstring\n") # options.disable_function_signatures() # options.disable_user_defined_docstrings() @@ -30,8 +31,8 @@ def test_docstring_options(): assert m.test_function6.__doc__ == "A custom docstring" # RAII destructor - assert m.test_function7.__doc__ .startswith("test_function7(a: int, b: int) -> None") - assert m.test_function7.__doc__ .endswith("A custom docstring\n") + assert m.test_function7.__doc__.startswith("test_function7(a: int, b: int) -> None") + assert m.test_function7.__doc__.endswith("A custom docstring\n") # Suppression of user-defined docstrings for non-function objects assert not m.DocstringTestFoo.__doc__ diff --git a/plugins/python/pybind11/tests/test_eigen.cpp b/plugins/python/pybind11/tests/test_eigen.cpp index 22141df..2cc2243 100644 --- a/plugins/python/pybind11/tests/test_eigen.cpp +++ b/plugins/python/pybind11/tests/test_eigen.cpp @@ -61,8 +61,9 @@ double get_elem(Eigen::Ref m) { return m(2, 1); }; // reference is referencing rows/columns correctly). template Eigen::MatrixXd adjust_matrix(MatrixArgType m) { Eigen::MatrixXd ret(m); - for (int c = 0; c < m.cols(); c++) for (int r = 0; r < m.rows(); r++) - ret(r, c) += 10*r + 100*c; + for (int c = 0; c < m.cols(); c++) + for (int r = 0; r < m.rows(); r++) + ret(r, c) += 10*r + 100*c; // NOLINT(clang-analyzer-core.uninitialized.Assign) return ret; } @@ -87,8 +88,6 @@ TEST_SUBMODULE(eigen, m) { using SparseMatrixR = Eigen::SparseMatrix; using SparseMatrixC = Eigen::SparseMatrix; - m.attr("have_eigen") = true; - // various tests m.def("double_col", [](const Eigen::VectorXf &x) -> Eigen::VectorXf { return 2.0f * x; }); m.def("double_row", [](const Eigen::RowVectorXf &x) -> Eigen::RowVectorXf { return 2.0f * x; }); @@ -124,7 +123,7 @@ TEST_SUBMODULE(eigen, m) { // This one accepts a matrix of any stride: m.def("add_any", [](py::EigenDRef x, int r, int c, double v) { x(r,c) += v; }); - // Return mutable references (numpy maps into eigen varibles) + // Return mutable references (numpy maps into eigen variables) m.def("get_cm_ref", []() { return Eigen::Ref(get_cm()); }); m.def("get_rm_ref", []() { return Eigen::Ref(get_rm()); }); // The same references, but non-mutable (numpy maps into eigen variables, but is !writeable) @@ -257,7 +256,7 @@ TEST_SUBMODULE(eigen, m) { m.def("dense_copy_r", [](const DenseMatrixR &m) -> DenseMatrixR { return m; }); m.def("dense_copy_c", [](const DenseMatrixC &m) -> DenseMatrixC { return m; }); // test_sparse, test_sparse_signature - m.def("sparse_r", [mat]() -> SparseMatrixR { return Eigen::SparseView(mat); }); + m.def("sparse_r", [mat]() -> SparseMatrixR { return Eigen::SparseView(mat); }); //NOLINT(clang-analyzer-core.uninitialized.UndefReturn) m.def("sparse_c", [mat]() -> SparseMatrixC { return Eigen::SparseView(mat); }); m.def("sparse_copy_r", [](const SparseMatrixR &m) -> SparseMatrixR { return m; }); m.def("sparse_copy_c", [](const SparseMatrixC &m) -> SparseMatrixC { return m; }); @@ -319,11 +318,11 @@ TEST_SUBMODULE(eigen, m) { // a new array (np.ones(10)) increases the chances that the temp array will be garbage // collected and/or that its memory will be overridden with different values. m.def("get_elem_direct", [](Eigen::Ref v) { - py::module::import("numpy").attr("ones")(10); + py::module_::import("numpy").attr("ones")(10); return v(5); }); m.def("get_elem_indirect", [](std::vector> v) { - py::module::import("numpy").attr("ones")(10); + py::module_::import("numpy").attr("ones")(10); return v[0](5); }); } diff --git a/plugins/python/pybind11/tests/test_eigen.py b/plugins/python/pybind11/tests/test_eigen.py index 45f64ca..a131dc1 100644 --- a/plugins/python/pybind11/tests/test_eigen.py +++ b/plugins/python/pybind11/tests/test_eigen.py @@ -1,17 +1,20 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import ConstructorStats -pytestmark = pytest.requires_eigen_and_numpy +np = pytest.importorskip("numpy") +m = pytest.importorskip("pybind11_tests.eigen") -with pytest.suppress(ImportError): - from pybind11_tests import eigen as m - import numpy as np - ref = np.array([[ 0., 3, 0, 0, 0, 11], - [22, 0, 0, 0, 17, 11], - [ 7, 5, 0, 1, 0, 11], - [ 0, 0, 0, 0, 0, 11], - [ 0, 0, 14, 0, 8, 11]]) +ref = np.array( + [ + [0.0, 3, 0, 0, 0, 11], + [22, 0, 0, 0, 17, 11], + [7, 5, 0, 1, 0, 11], + [0, 0, 0, 0, 0, 11], + [0, 0, 14, 0, 8, 11], + ] +) def assert_equal_ref(mat): @@ -41,28 +44,37 @@ def test_dense(): def test_partially_fixed(): - ref2 = np.array([[0., 1, 2, 3], [4, 5, 6, 7], [8, 9, 10, 11], [12, 13, 14, 15]]) + ref2 = np.array([[0.0, 1, 2, 3], [4, 5, 6, 7], [8, 9, 10, 11], [12, 13, 14, 15]]) np.testing.assert_array_equal(m.partial_copy_four_rm_r(ref2), ref2) np.testing.assert_array_equal(m.partial_copy_four_rm_c(ref2), ref2) np.testing.assert_array_equal(m.partial_copy_four_rm_r(ref2[:, 1]), ref2[:, [1]]) np.testing.assert_array_equal(m.partial_copy_four_rm_c(ref2[0, :]), ref2[[0], :]) - np.testing.assert_array_equal(m.partial_copy_four_rm_r(ref2[:, (0, 2)]), ref2[:, (0, 2)]) np.testing.assert_array_equal( - m.partial_copy_four_rm_c(ref2[(3, 1, 2), :]), ref2[(3, 1, 2), :]) + m.partial_copy_four_rm_r(ref2[:, (0, 2)]), ref2[:, (0, 2)] + ) + np.testing.assert_array_equal( + m.partial_copy_four_rm_c(ref2[(3, 1, 2), :]), ref2[(3, 1, 2), :] + ) np.testing.assert_array_equal(m.partial_copy_four_cm_r(ref2), ref2) np.testing.assert_array_equal(m.partial_copy_four_cm_c(ref2), ref2) np.testing.assert_array_equal(m.partial_copy_four_cm_r(ref2[:, 1]), ref2[:, [1]]) np.testing.assert_array_equal(m.partial_copy_four_cm_c(ref2[0, :]), ref2[[0], :]) - np.testing.assert_array_equal(m.partial_copy_four_cm_r(ref2[:, (0, 2)]), ref2[:, (0, 2)]) np.testing.assert_array_equal( - m.partial_copy_four_cm_c(ref2[(3, 1, 2), :]), ref2[(3, 1, 2), :]) + m.partial_copy_four_cm_r(ref2[:, (0, 2)]), ref2[:, (0, 2)] + ) + np.testing.assert_array_equal( + m.partial_copy_four_cm_c(ref2[(3, 1, 2), :]), ref2[(3, 1, 2), :] + ) # TypeError should be raise for a shape mismatch - functions = [m.partial_copy_four_rm_r, m.partial_copy_four_rm_c, - m.partial_copy_four_cm_r, m.partial_copy_four_cm_c] - matrix_with_wrong_shape = [[1, 2], - [3, 4]] + functions = [ + m.partial_copy_four_rm_r, + m.partial_copy_four_rm_c, + m.partial_copy_four_cm_r, + m.partial_copy_four_cm_c, + ] + matrix_with_wrong_shape = [[1, 2], [3, 4]] for f in functions: with pytest.raises(TypeError) as excinfo: f(matrix_with_wrong_shape) @@ -70,7 +82,7 @@ def test_partially_fixed(): def test_mutator_descriptors(): - zr = np.arange(30, dtype='float32').reshape(5, 6) # row-major + zr = np.arange(30, dtype="float32").reshape(5, 6) # row-major zc = zr.reshape(6, 5).transpose() # column-major m.fixed_mutator_r(zr) @@ -79,16 +91,21 @@ def test_mutator_descriptors(): m.fixed_mutator_a(zc) with pytest.raises(TypeError) as excinfo: m.fixed_mutator_r(zc) - assert ('(arg0: numpy.ndarray[float32[5, 6], flags.writeable, flags.c_contiguous]) -> None' - in str(excinfo.value)) + assert ( + "(arg0: numpy.ndarray[numpy.float32[5, 6]," + " flags.writeable, flags.c_contiguous]) -> None" in str(excinfo.value) + ) with pytest.raises(TypeError) as excinfo: m.fixed_mutator_c(zr) - assert ('(arg0: numpy.ndarray[float32[5, 6], flags.writeable, flags.f_contiguous]) -> None' - in str(excinfo.value)) + assert ( + "(arg0: numpy.ndarray[numpy.float32[5, 6]," + " flags.writeable, flags.f_contiguous]) -> None" in str(excinfo.value) + ) with pytest.raises(TypeError) as excinfo: - m.fixed_mutator_a(np.array([[1, 2], [3, 4]], dtype='float32')) - assert ('(arg0: numpy.ndarray[float32[5, 6], flags.writeable]) -> None' - in str(excinfo.value)) + m.fixed_mutator_a(np.array([[1, 2], [3, 4]], dtype="float32")) + assert "(arg0: numpy.ndarray[numpy.float32[5, 6], flags.writeable]) -> None" in str( + excinfo.value + ) zr.flags.writeable = False with pytest.raises(TypeError): m.fixed_mutator_r(zr) @@ -97,26 +114,26 @@ def test_mutator_descriptors(): def test_cpp_casting(): - assert m.cpp_copy(m.fixed_r()) == 22. - assert m.cpp_copy(m.fixed_c()) == 22. - z = np.array([[5., 6], [7, 8]]) - assert m.cpp_copy(z) == 7. - assert m.cpp_copy(m.get_cm_ref()) == 21. - assert m.cpp_copy(m.get_rm_ref()) == 21. - assert m.cpp_ref_c(m.get_cm_ref()) == 21. - assert m.cpp_ref_r(m.get_rm_ref()) == 21. + assert m.cpp_copy(m.fixed_r()) == 22.0 + assert m.cpp_copy(m.fixed_c()) == 22.0 + z = np.array([[5.0, 6], [7, 8]]) + assert m.cpp_copy(z) == 7.0 + assert m.cpp_copy(m.get_cm_ref()) == 21.0 + assert m.cpp_copy(m.get_rm_ref()) == 21.0 + assert m.cpp_ref_c(m.get_cm_ref()) == 21.0 + assert m.cpp_ref_r(m.get_rm_ref()) == 21.0 with pytest.raises(RuntimeError) as excinfo: # Can't reference m.fixed_c: it contains floats, m.cpp_ref_any wants doubles m.cpp_ref_any(m.fixed_c()) - assert 'Unable to cast Python instance' in str(excinfo.value) + assert "Unable to cast Python instance" in str(excinfo.value) with pytest.raises(RuntimeError) as excinfo: # Can't reference m.fixed_r: it contains floats, m.cpp_ref_any wants doubles m.cpp_ref_any(m.fixed_r()) - assert 'Unable to cast Python instance' in str(excinfo.value) - assert m.cpp_ref_any(m.ReturnTester.create()) == 1. + assert "Unable to cast Python instance" in str(excinfo.value) + assert m.cpp_ref_any(m.ReturnTester.create()) == 1.0 - assert m.cpp_ref_any(m.get_cm_ref()) == 21. - assert m.cpp_ref_any(m.get_cm_ref()) == 21. + assert m.cpp_ref_any(m.get_cm_ref()) == 21.0 + assert m.cpp_ref_any(m.get_cm_ref()) == 21.0 def test_pass_readonly_array(): @@ -141,14 +158,14 @@ def test_nonunit_stride_from_python(): counting_3d = np.arange(27.0, dtype=np.float32).reshape((3, 3, 3)) slices = [counting_3d[0, :, :], counting_3d[:, 0, :], counting_3d[:, :, 0]] - for slice_idx, ref_mat in enumerate(slices): + for ref_mat in slices: np.testing.assert_array_equal(m.double_mat_cm(ref_mat), 2.0 * ref_mat) np.testing.assert_array_equal(m.double_mat_rm(ref_mat), 2.0 * ref_mat) # Mutator: m.double_threer(second_row) m.double_threec(second_col) - np.testing.assert_array_equal(counting_mat, [[0., 2, 2], [6, 16, 10], [6, 14, 8]]) + np.testing.assert_array_equal(counting_mat, [[0.0, 2, 2], [6, 16, 10], [6, 14, 8]]) def test_negative_stride_from_python(msg): @@ -170,33 +187,43 @@ def test_negative_stride_from_python(msg): counting_3d = np.arange(27.0, dtype=np.float32).reshape((3, 3, 3)) counting_3d = counting_3d[::-1, ::-1, ::-1] slices = [counting_3d[0, :, :], counting_3d[:, 0, :], counting_3d[:, :, 0]] - for slice_idx, ref_mat in enumerate(slices): + for ref_mat in slices: np.testing.assert_array_equal(m.double_mat_cm(ref_mat), 2.0 * ref_mat) np.testing.assert_array_equal(m.double_mat_rm(ref_mat), 2.0 * ref_mat) # Mutator: with pytest.raises(TypeError) as excinfo: m.double_threer(second_row) - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ double_threer(): incompatible function arguments. The following argument types are supported: - 1. (arg0: numpy.ndarray[float32[1, 3], flags.writeable]) -> None + 1. (arg0: numpy.ndarray[numpy.float32[1, 3], flags.writeable]) -> None - Invoked with: """ + repr(np.array([ 5., 4., 3.], dtype='float32')) # noqa: E501 line too long + Invoked with: """ # noqa: E501 line too long + + repr(np.array([5.0, 4.0, 3.0], dtype="float32")) + ) with pytest.raises(TypeError) as excinfo: m.double_threec(second_col) - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ double_threec(): incompatible function arguments. The following argument types are supported: - 1. (arg0: numpy.ndarray[float32[3, 1], flags.writeable]) -> None + 1. (arg0: numpy.ndarray[numpy.float32[3, 1], flags.writeable]) -> None - Invoked with: """ + repr(np.array([ 7., 4., 1.], dtype='float32')) # noqa: E501 line too long + Invoked with: """ # noqa: E501 line too long + + repr(np.array([7.0, 4.0, 1.0], dtype="float32")) + ) def test_nonunit_stride_to_python(): assert np.all(m.diagonal(ref) == ref.diagonal()) assert np.all(m.diagonal_1(ref) == ref.diagonal(1)) for i in range(-5, 7): - assert np.all(m.diagonal_n(ref, i) == ref.diagonal(i)), "m.diagonal_n({})".format(i) + assert np.all( + m.diagonal_n(ref, i) == ref.diagonal(i) + ), "m.diagonal_n({})".format(i) assert np.all(m.block(ref, 2, 1, 3, 3) == ref[2:5, 1:4]) assert np.all(m.block(ref, 1, 4, 4, 2) == ref[1:, 4:]) @@ -206,8 +233,10 @@ def test_nonunit_stride_to_python(): def test_eigen_ref_to_python(): chols = [m.cholesky1, m.cholesky2, m.cholesky3, m.cholesky4] for i, chol in enumerate(chols, start=1): - mymat = chol(np.array([[1., 2, 4], [2, 13, 23], [4, 23, 77]])) - assert np.all(mymat == np.array([[1, 0, 0], [2, 3, 0], [4, 5, 6]])), "cholesky{}".format(i) + mymat = chol(np.array([[1.0, 2, 4], [2, 13, 23], [4, 23, 77]])) + assert np.all( + mymat == np.array([[1, 0, 0], [2, 3, 0], [4, 5, 6]]) + ), "cholesky{}".format(i) def assign_both(a1, a2, r, c, v): @@ -324,8 +353,12 @@ def test_eigen_return_references(): np.testing.assert_array_equal(a_block1, master[3:5, 3:5]) np.testing.assert_array_equal(a_block2, master[2:5, 2:4]) np.testing.assert_array_equal(a_block3, master[6:10, 7:10]) - np.testing.assert_array_equal(a_corn1, master[0::master.shape[0] - 1, 0::master.shape[1] - 1]) - np.testing.assert_array_equal(a_corn2, master[0::master.shape[0] - 1, 0::master.shape[1] - 1]) + np.testing.assert_array_equal( + a_corn1, master[0 :: master.shape[0] - 1, 0 :: master.shape[1] - 1] + ) + np.testing.assert_array_equal( + a_corn2, master[0 :: master.shape[0] - 1, 0 :: master.shape[1] - 1] + ) np.testing.assert_array_equal(a_copy1, c1want) np.testing.assert_array_equal(a_copy2, c2want) @@ -354,16 +387,28 @@ def test_eigen_keepalive(): cstats = ConstructorStats.get(m.ReturnTester) assert cstats.alive() == 1 unsafe = [a.ref(), a.ref_const(), a.block(1, 2, 3, 4)] - copies = [a.copy_get(), a.copy_view(), a.copy_ref(), a.copy_ref_const(), - a.copy_block(4, 3, 2, 1)] + copies = [ + a.copy_get(), + a.copy_view(), + a.copy_ref(), + a.copy_ref_const(), + a.copy_block(4, 3, 2, 1), + ] del a assert cstats.alive() == 0 del unsafe del copies - for meth in [m.ReturnTester.get, m.ReturnTester.get_ptr, m.ReturnTester.view, - m.ReturnTester.view_ptr, m.ReturnTester.ref_safe, m.ReturnTester.ref_const_safe, - m.ReturnTester.corners, m.ReturnTester.corners_const]: + for meth in [ + m.ReturnTester.get, + m.ReturnTester.get_ptr, + m.ReturnTester.view, + m.ReturnTester.view_ptr, + m.ReturnTester.ref_safe, + m.ReturnTester.ref_const_safe, + m.ReturnTester.corners, + m.ReturnTester.corners_const, + ]: assert_keeps_alive(m.ReturnTester, meth) for meth in [m.ReturnTester.block_safe, m.ReturnTester.block_const]: @@ -373,18 +418,18 @@ def test_eigen_keepalive(): def test_eigen_ref_mutators(): """Tests Eigen's ability to mutate numpy values""" - orig = np.array([[1., 2, 3], [4, 5, 6], [7, 8, 9]]) + orig = np.array([[1.0, 2, 3], [4, 5, 6], [7, 8, 9]]) zr = np.array(orig) - zc = np.array(orig, order='F') + zc = np.array(orig, order="F") m.add_rm(zr, 1, 0, 100) - assert np.all(zr == np.array([[1., 2, 3], [104, 5, 6], [7, 8, 9]])) + assert np.all(zr == np.array([[1.0, 2, 3], [104, 5, 6], [7, 8, 9]])) m.add_cm(zc, 1, 0, 200) - assert np.all(zc == np.array([[1., 2, 3], [204, 5, 6], [7, 8, 9]])) + assert np.all(zc == np.array([[1.0, 2, 3], [204, 5, 6], [7, 8, 9]])) m.add_any(zr, 1, 0, 20) - assert np.all(zr == np.array([[1., 2, 3], [124, 5, 6], [7, 8, 9]])) + assert np.all(zr == np.array([[1.0, 2, 3], [124, 5, 6], [7, 8, 9]])) m.add_any(zc, 1, 0, 10) - assert np.all(zc == np.array([[1., 2, 3], [214, 5, 6], [7, 8, 9]])) + assert np.all(zc == np.array([[1.0, 2, 3], [214, 5, 6], [7, 8, 9]])) # Can't reference a col-major array with a row-major Ref, and vice versa: with pytest.raises(TypeError): @@ -405,8 +450,8 @@ def test_eigen_ref_mutators(): cornersr = zr[0::2, 0::2] cornersc = zc[0::2, 0::2] - assert np.all(cornersr == np.array([[1., 3], [7, 9]])) - assert np.all(cornersc == np.array([[1., 3], [7, 9]])) + assert np.all(cornersr == np.array([[1.0, 3], [7, 9]])) + assert np.all(cornersc == np.array([[1.0, 3], [7, 9]])) with pytest.raises(TypeError): m.add_rm(cornersr, 0, 1, 25) @@ -418,8 +463,8 @@ def test_eigen_ref_mutators(): m.add_cm(cornersc, 0, 1, 25) m.add_any(cornersr, 0, 1, 25) m.add_any(cornersc, 0, 1, 44) - assert np.all(zr == np.array([[1., 2, 28], [4, 5, 6], [7, 8, 9]])) - assert np.all(zc == np.array([[1., 2, 47], [4, 5, 6], [7, 8, 9]])) + assert np.all(zr == np.array([[1.0, 2, 28], [4, 5, 6], [7, 8, 9]])) + assert np.all(zc == np.array([[1.0, 2, 47], [4, 5, 6], [7, 8, 9]])) # You shouldn't be allowed to pass a non-writeable array to a mutating Eigen method: zro = zr[0:4, 0:4] @@ -457,7 +502,7 @@ def test_numpy_ref_mutators(): assert not zrro.flags.owndata and not zrro.flags.writeable zc[1, 2] = 99 - expect = np.array([[11., 12, 13], [21, 22, 99], [31, 32, 33]]) + expect = np.array([[11.0, 12, 13], [21, 22, 99], [31, 32, 33]]) # We should have just changed zc, of course, but also zcro and the original eigen matrix assert np.all(zc == expect) assert np.all(zcro == expect) @@ -505,18 +550,20 @@ def test_both_ref_mutators(): assert np.all(z == z3) assert np.all(z == z4) assert np.all(z == z5) - expect = np.array([[0., 22, 20], [31, 37, 33], [41, 42, 38]]) + expect = np.array([[0.0, 22, 20], [31, 37, 33], [41, 42, 38]]) assert np.all(z == expect) - y = np.array(range(100), dtype='float64').reshape(10, 10) + y = np.array(range(100), dtype="float64").reshape(10, 10) y2 = m.incr_matrix_any(y, 10) # np -> eigen -> np - y3 = m.incr_matrix_any(y2[0::2, 0::2], -33) # np -> eigen -> np slice -> np -> eigen -> np + y3 = m.incr_matrix_any( + y2[0::2, 0::2], -33 + ) # np -> eigen -> np slice -> np -> eigen -> np y4 = m.even_rows(y3) # numpy -> eigen slice -> (... y3) y5 = m.even_cols(y4) # numpy -> eigen slice -> (... y4) y6 = m.incr_matrix_any(y5, 1000) # numpy -> eigen -> (... y5) # Apply same mutations using just numpy: - yexpect = np.array(range(100), dtype='float64').reshape(10, 10) + yexpect = np.array(range(100), dtype="float64").reshape(10, 10) yexpect += 10 yexpect[0::2, 0::2] -= 33 yexpect[0::4, 0::4] += 1000 @@ -531,10 +578,14 @@ def test_both_ref_mutators(): def test_nocopy_wrapper(): # get_elem requires a column-contiguous matrix reference, but should be # callable with other types of matrix (via copying): - int_matrix_colmajor = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]], order='F') - dbl_matrix_colmajor = np.array(int_matrix_colmajor, dtype='double', order='F', copy=True) - int_matrix_rowmajor = np.array(int_matrix_colmajor, order='C', copy=True) - dbl_matrix_rowmajor = np.array(int_matrix_rowmajor, dtype='double', order='C', copy=True) + int_matrix_colmajor = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]], order="F") + dbl_matrix_colmajor = np.array( + int_matrix_colmajor, dtype="double", order="F", copy=True + ) + int_matrix_rowmajor = np.array(int_matrix_colmajor, order="C", copy=True) + dbl_matrix_rowmajor = np.array( + int_matrix_rowmajor, dtype="double", order="C", copy=True + ) # All should be callable via get_elem: assert m.get_elem(int_matrix_colmajor) == 8 @@ -545,32 +596,38 @@ def test_nocopy_wrapper(): # All but the second should fail with m.get_elem_nocopy: with pytest.raises(TypeError) as excinfo: m.get_elem_nocopy(int_matrix_colmajor) - assert ('get_elem_nocopy(): incompatible function arguments.' in str(excinfo.value) and - ', flags.f_contiguous' in str(excinfo.value)) + assert "get_elem_nocopy(): incompatible function arguments." in str( + excinfo.value + ) and ", flags.f_contiguous" in str(excinfo.value) assert m.get_elem_nocopy(dbl_matrix_colmajor) == 8 with pytest.raises(TypeError) as excinfo: m.get_elem_nocopy(int_matrix_rowmajor) - assert ('get_elem_nocopy(): incompatible function arguments.' in str(excinfo.value) and - ', flags.f_contiguous' in str(excinfo.value)) + assert "get_elem_nocopy(): incompatible function arguments." in str( + excinfo.value + ) and ", flags.f_contiguous" in str(excinfo.value) with pytest.raises(TypeError) as excinfo: m.get_elem_nocopy(dbl_matrix_rowmajor) - assert ('get_elem_nocopy(): incompatible function arguments.' in str(excinfo.value) and - ', flags.f_contiguous' in str(excinfo.value)) + assert "get_elem_nocopy(): incompatible function arguments." in str( + excinfo.value + ) and ", flags.f_contiguous" in str(excinfo.value) # For the row-major test, we take a long matrix in row-major, so only the third is allowed: with pytest.raises(TypeError) as excinfo: m.get_elem_rm_nocopy(int_matrix_colmajor) - assert ('get_elem_rm_nocopy(): incompatible function arguments.' in str(excinfo.value) and - ', flags.c_contiguous' in str(excinfo.value)) + assert "get_elem_rm_nocopy(): incompatible function arguments." in str( + excinfo.value + ) and ", flags.c_contiguous" in str(excinfo.value) with pytest.raises(TypeError) as excinfo: m.get_elem_rm_nocopy(dbl_matrix_colmajor) - assert ('get_elem_rm_nocopy(): incompatible function arguments.' in str(excinfo.value) and - ', flags.c_contiguous' in str(excinfo.value)) + assert "get_elem_rm_nocopy(): incompatible function arguments." in str( + excinfo.value + ) and ", flags.c_contiguous" in str(excinfo.value) assert m.get_elem_rm_nocopy(int_matrix_rowmajor) == 8 with pytest.raises(TypeError) as excinfo: m.get_elem_rm_nocopy(dbl_matrix_rowmajor) - assert ('get_elem_rm_nocopy(): incompatible function arguments.' in str(excinfo.value) and - ', flags.c_contiguous' in str(excinfo.value)) + assert "get_elem_rm_nocopy(): incompatible function arguments." in str( + excinfo.value + ) and ", flags.c_contiguous" in str(excinfo.value) def test_eigen_ref_life_support(): @@ -588,12 +645,9 @@ def test_eigen_ref_life_support(): def test_special_matrix_objects(): - assert np.all(m.incr_diag(7) == np.diag([1., 2, 3, 4, 5, 6, 7])) + assert np.all(m.incr_diag(7) == np.diag([1.0, 2, 3, 4, 5, 6, 7])) - asymm = np.array([[ 1., 2, 3, 4], - [ 5, 6, 7, 8], - [ 9, 10, 11, 12], - [13, 14, 15, 16]]) + asymm = np.array([[1.0, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], [13, 14, 15, 16]]) symm_lower = np.array(asymm) symm_upper = np.array(asymm) for i in range(4): @@ -606,43 +660,55 @@ def test_special_matrix_objects(): def test_dense_signature(doc): - assert doc(m.double_col) == """ - double_col(arg0: numpy.ndarray[float32[m, 1]]) -> numpy.ndarray[float32[m, 1]] + assert ( + doc(m.double_col) + == """ + double_col(arg0: numpy.ndarray[numpy.float32[m, 1]]) -> numpy.ndarray[numpy.float32[m, 1]] """ - assert doc(m.double_row) == """ - double_row(arg0: numpy.ndarray[float32[1, n]]) -> numpy.ndarray[float32[1, n]] + ) + assert ( + doc(m.double_row) + == """ + double_row(arg0: numpy.ndarray[numpy.float32[1, n]]) -> numpy.ndarray[numpy.float32[1, n]] """ - assert doc(m.double_complex) == """ - double_complex(arg0: numpy.ndarray[complex64[m, 1]]) -> numpy.ndarray[complex64[m, 1]] + ) + assert doc(m.double_complex) == ( + """ + double_complex(arg0: numpy.ndarray[numpy.complex64[m, 1]])""" + """ -> numpy.ndarray[numpy.complex64[m, 1]] """ - assert doc(m.double_mat_rm) == """ - double_mat_rm(arg0: numpy.ndarray[float32[m, n]]) -> numpy.ndarray[float32[m, n]] + ) + assert doc(m.double_mat_rm) == ( + """ + double_mat_rm(arg0: numpy.ndarray[numpy.float32[m, n]])""" + """ -> numpy.ndarray[numpy.float32[m, n]] """ + ) def test_named_arguments(): a = np.array([[1.0, 2], [3, 4], [5, 6]]) b = np.ones((2, 1)) - assert np.all(m.matrix_multiply(a, b) == np.array([[3.], [7], [11]])) - assert np.all(m.matrix_multiply(A=a, B=b) == np.array([[3.], [7], [11]])) - assert np.all(m.matrix_multiply(B=b, A=a) == np.array([[3.], [7], [11]])) + assert np.all(m.matrix_multiply(a, b) == np.array([[3.0], [7], [11]])) + assert np.all(m.matrix_multiply(A=a, B=b) == np.array([[3.0], [7], [11]])) + assert np.all(m.matrix_multiply(B=b, A=a) == np.array([[3.0], [7], [11]])) with pytest.raises(ValueError) as excinfo: m.matrix_multiply(b, a) - assert str(excinfo.value) == 'Nonconformable matrices!' + assert str(excinfo.value) == "Nonconformable matrices!" with pytest.raises(ValueError) as excinfo: m.matrix_multiply(A=b, B=a) - assert str(excinfo.value) == 'Nonconformable matrices!' + assert str(excinfo.value) == "Nonconformable matrices!" with pytest.raises(ValueError) as excinfo: m.matrix_multiply(B=a, A=b) - assert str(excinfo.value) == 'Nonconformable matrices!' + assert str(excinfo.value) == "Nonconformable matrices!" -@pytest.requires_eigen_and_scipy def test_sparse(): + pytest.importorskip("scipy") assert_sparse_equal_ref(m.sparse_r()) assert_sparse_equal_ref(m.sparse_c()) assert_sparse_equal_ref(m.sparse_copy_r(m.sparse_r())) @@ -651,23 +717,33 @@ def test_sparse(): assert_sparse_equal_ref(m.sparse_copy_c(m.sparse_r())) -@pytest.requires_eigen_and_scipy def test_sparse_signature(doc): - assert doc(m.sparse_copy_r) == """ - sparse_copy_r(arg0: scipy.sparse.csr_matrix[float32]) -> scipy.sparse.csr_matrix[float32] + pytest.importorskip("scipy") + assert ( + doc(m.sparse_copy_r) + == """ + sparse_copy_r(arg0: scipy.sparse.csr_matrix[numpy.float32]) -> scipy.sparse.csr_matrix[numpy.float32] """ # noqa: E501 line too long - assert doc(m.sparse_copy_c) == """ - sparse_copy_c(arg0: scipy.sparse.csc_matrix[float32]) -> scipy.sparse.csc_matrix[float32] + ) + assert ( + doc(m.sparse_copy_c) + == """ + sparse_copy_c(arg0: scipy.sparse.csc_matrix[numpy.float32]) -> scipy.sparse.csc_matrix[numpy.float32] """ # noqa: E501 line too long + ) def test_issue738(): """Ignore strides on a length-1 dimension (even if they would be incompatible length > 1)""" - assert np.all(m.iss738_f1(np.array([[1., 2, 3]])) == np.array([[1., 102, 203]])) - assert np.all(m.iss738_f1(np.array([[1.], [2], [3]])) == np.array([[1.], [12], [23]])) + assert np.all(m.iss738_f1(np.array([[1.0, 2, 3]])) == np.array([[1.0, 102, 203]])) + assert np.all( + m.iss738_f1(np.array([[1.0], [2], [3]])) == np.array([[1.0], [12], [23]]) + ) - assert np.all(m.iss738_f2(np.array([[1., 2, 3]])) == np.array([[1., 102, 203]])) - assert np.all(m.iss738_f2(np.array([[1.], [2], [3]])) == np.array([[1.], [12], [23]])) + assert np.all(m.iss738_f2(np.array([[1.0, 2, 3]])) == np.array([[1.0, 102, 203]])) + assert np.all( + m.iss738_f2(np.array([[1.0], [2], [3]])) == np.array([[1.0], [12], [23]]) + ) def test_issue1105(): @@ -679,10 +755,10 @@ def test_issue1105(): # These should still fail (incompatible dimensions): with pytest.raises(TypeError) as excinfo: m.iss1105_row(np.ones((7, 1))) - assert "incompatible function arguments" in str(excinfo) + assert "incompatible function arguments" in str(excinfo.value) with pytest.raises(TypeError) as excinfo: m.iss1105_col(np.ones((1, 7))) - assert "incompatible function arguments" in str(excinfo) + assert "incompatible function arguments" in str(excinfo.value) def test_custom_operator_new(): diff --git a/plugins/python/pybind11/tests/test_embed/CMakeLists.txt b/plugins/python/pybind11/tests/test_embed/CMakeLists.txt index 8b4f1f8..fabcb24 100644 --- a/plugins/python/pybind11/tests/test_embed/CMakeLists.txt +++ b/plugins/python/pybind11/tests/test_embed/CMakeLists.txt @@ -1,41 +1,43 @@ -if(${PYTHON_MODULE_EXTENSION} MATCHES "pypy") - add_custom_target(cpptest) # Dummy target on PyPy. Embedding is not supported. +if("${PYTHON_MODULE_EXTENSION}" MATCHES "pypy" OR "${Python_INTERPRETER_ID}" STREQUAL "PyPy") + add_custom_target(cpptest) # Dummy target on PyPy. Embedding is not supported. set(_suppress_unused_variable_warning "${DOWNLOAD_CATCH}") return() endif() -find_package(Catch 1.9.3) +find_package(Catch 2.13.2) + if(CATCH_FOUND) message(STATUS "Building interpreter tests using Catch v${CATCH_VERSION}") else() message(STATUS "Catch not detected. Interpreter tests will be skipped. Install Catch headers" - " manually or use `cmake -DDOWNLOAD_CATCH=1` to fetch them automatically.") + " manually or use `cmake -DDOWNLOAD_CATCH=ON` to fetch them automatically.") return() endif() -add_executable(test_embed - catch.cpp - test_interpreter.cpp -) -target_include_directories(test_embed PRIVATE ${CATCH_INCLUDE_DIR}) +find_package(Threads REQUIRED) + +add_executable(test_embed catch.cpp test_interpreter.cpp) pybind11_enable_warnings(test_embed) -if(NOT CMAKE_VERSION VERSION_LESS 3.0) - target_link_libraries(test_embed PRIVATE pybind11::embed) -else() - target_include_directories(test_embed PRIVATE ${PYBIND11_INCLUDE_DIR} ${PYTHON_INCLUDE_DIRS}) - target_compile_options(test_embed PRIVATE ${PYBIND11_CPP_STANDARD}) - target_link_libraries(test_embed PRIVATE ${PYTHON_LIBRARIES}) -endif() +target_link_libraries(test_embed PRIVATE pybind11::embed Catch2::Catch2 Threads::Threads) -find_package(Threads REQUIRED) -target_link_libraries(test_embed PUBLIC ${CMAKE_THREAD_LIBS_INIT}) +if(NOT CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR) + file(COPY test_interpreter.py DESTINATION "${CMAKE_CURRENT_BINARY_DIR}") +endif() -add_custom_target(cpptest COMMAND $ - WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}) +add_custom_target( + cpptest + COMMAND "$" + WORKING_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}") pybind11_add_module(external_module THIN_LTO external_module.cpp) -set_target_properties(external_module PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}) +set_target_properties(external_module PROPERTIES LIBRARY_OUTPUT_DIRECTORY + "${CMAKE_CURRENT_BINARY_DIR}") +foreach(config ${CMAKE_CONFIGURATION_TYPES}) + string(TOUPPER ${config} config) + set_target_properties(external_module PROPERTIES LIBRARY_OUTPUT_DIRECTORY_${config} + "${CMAKE_CURRENT_BINARY_DIR}") +endforeach() add_dependencies(cpptest external_module) add_dependencies(check cpptest) diff --git a/plugins/python/pybind11/tests/test_embed/test_interpreter.cpp b/plugins/python/pybind11/tests/test_embed/test_interpreter.cpp index 222bd56..944334c 100644 --- a/plugins/python/pybind11/tests/test_embed/test_interpreter.cpp +++ b/plugins/python/pybind11/tests/test_embed/test_interpreter.cpp @@ -30,7 +30,7 @@ class Widget { class PyWidget final : public Widget { using Widget::Widget; - int the_answer() const override { PYBIND11_OVERLOAD_PURE(int, Widget, the_answer); } + int the_answer() const override { PYBIND11_OVERRIDE_PURE(int, Widget, the_answer); } }; PYBIND11_EMBEDDED_MODULE(widget_module, m) { @@ -51,17 +51,17 @@ PYBIND11_EMBEDDED_MODULE(throw_error_already_set, ) { } TEST_CASE("Pass classes and data between modules defined in C++ and Python") { - auto module = py::module::import("test_interpreter"); - REQUIRE(py::hasattr(module, "DerivedWidget")); + auto module_ = py::module_::import("test_interpreter"); + REQUIRE(py::hasattr(module_, "DerivedWidget")); - auto locals = py::dict("hello"_a="Hello, World!", "x"_a=5, **module.attr("__dict__")); + auto locals = py::dict("hello"_a="Hello, World!", "x"_a=5, **module_.attr("__dict__")); py::exec(R"( widget = DerivedWidget("{} - {}".format(hello, x)) message = widget.the_message )", py::globals(), locals); REQUIRE(locals["message"].cast() == "Hello, World! - 5"); - auto py_widget = module.attr("DerivedWidget")("The question"); + auto py_widget = module_.attr("DerivedWidget")("The question"); auto message = py_widget.attr("the_message"); REQUIRE(message.cast() == "The question"); @@ -70,10 +70,10 @@ TEST_CASE("Pass classes and data between modules defined in C++ and Python") { } TEST_CASE("Import error handling") { - REQUIRE_NOTHROW(py::module::import("widget_module")); - REQUIRE_THROWS_WITH(py::module::import("throw_exception"), + REQUIRE_NOTHROW(py::module_::import("widget_module")); + REQUIRE_THROWS_WITH(py::module_::import("throw_exception"), "ImportError: C++ Error"); - REQUIRE_THROWS_WITH(py::module::import("throw_error_already_set"), + REQUIRE_THROWS_WITH(py::module_::import("throw_error_already_set"), Catch::Contains("ImportError: KeyError")); } @@ -107,14 +107,14 @@ bool has_pybind11_internals_static() { TEST_CASE("Restart the interpreter") { // Verify pre-restart state. - REQUIRE(py::module::import("widget_module").attr("add")(1, 2).cast() == 3); + REQUIRE(py::module_::import("widget_module").attr("add")(1, 2).cast() == 3); REQUIRE(has_pybind11_internals_builtin()); REQUIRE(has_pybind11_internals_static()); - REQUIRE(py::module::import("external_module").attr("A")(123).attr("value").cast() == 123); + REQUIRE(py::module_::import("external_module").attr("A")(123).attr("value").cast() == 123); // local and foreign module internals should point to the same internals: REQUIRE(reinterpret_cast(*py::detail::get_internals_pp()) == - py::module::import("external_module").attr("internals_at")().cast()); + py::module_::import("external_module").attr("internals_at")().cast()); // Restart the interpreter. py::finalize_interpreter(); @@ -130,14 +130,14 @@ TEST_CASE("Restart the interpreter") { REQUIRE(has_pybind11_internals_builtin()); REQUIRE(has_pybind11_internals_static()); REQUIRE(reinterpret_cast(*py::detail::get_internals_pp()) == - py::module::import("external_module").attr("internals_at")().cast()); + py::module_::import("external_module").attr("internals_at")().cast()); // Make sure that an interpreter with no get_internals() created until finalize still gets the // internals destroyed py::finalize_interpreter(); py::initialize_interpreter(); bool ran = false; - py::module::import("__main__").attr("internals_destroy_test") = + py::module_::import("__main__").attr("internals_destroy_test") = py::capsule(&ran, [](void *ran) { py::detail::get_internals(); *static_cast(ran) = true; }); REQUIRE_FALSE(has_pybind11_internals_builtin()); REQUIRE_FALSE(has_pybind11_internals_static()); @@ -149,20 +149,20 @@ TEST_CASE("Restart the interpreter") { REQUIRE_FALSE(has_pybind11_internals_static()); // C++ modules can be reloaded. - auto cpp_module = py::module::import("widget_module"); + auto cpp_module = py::module_::import("widget_module"); REQUIRE(cpp_module.attr("add")(1, 2).cast() == 3); // C++ type information is reloaded and can be used in python modules. - auto py_module = py::module::import("test_interpreter"); + auto py_module = py::module_::import("test_interpreter"); auto py_widget = py_module.attr("DerivedWidget")("Hello after restart"); REQUIRE(py_widget.attr("the_message").cast() == "Hello after restart"); } TEST_CASE("Subinterpreter") { // Add tags to the modules in the main interpreter and test the basics. - py::module::import("__main__").attr("main_tag") = "main interpreter"; + py::module_::import("__main__").attr("main_tag") = "main interpreter"; { - auto m = py::module::import("widget_module"); + auto m = py::module_::import("widget_module"); m.attr("extension_module_tag") = "added to module in main interpreter"; REQUIRE(m.attr("add")(1, 2).cast() == 3); @@ -181,9 +181,9 @@ TEST_CASE("Subinterpreter") { REQUIRE(has_pybind11_internals_static()); // Modules tags should be gone. - REQUIRE_FALSE(py::hasattr(py::module::import("__main__"), "tag")); + REQUIRE_FALSE(py::hasattr(py::module_::import("__main__"), "tag")); { - auto m = py::module::import("widget_module"); + auto m = py::module_::import("widget_module"); REQUIRE_FALSE(py::hasattr(m, "extension_module_tag")); // Function bindings should still work. @@ -194,8 +194,8 @@ TEST_CASE("Subinterpreter") { Py_EndInterpreter(sub_tstate); PyThreadState_Swap(main_tstate); - REQUIRE(py::hasattr(py::module::import("__main__"), "main_tag")); - REQUIRE(py::hasattr(py::module::import("widget_module"), "extension_module_tag")); + REQUIRE(py::hasattr(py::module_::import("__main__"), "main_tag")); + REQUIRE(py::hasattr(py::module_::import("widget_module"), "extension_module_tag")); } TEST_CASE("Execution frame") { @@ -245,7 +245,7 @@ TEST_CASE("Reload module from file") { // Disable generation of cached bytecode (.pyc files) for this test, otherwise // Python might pick up an old version from the cache instead of the new versions // of the .py files generated below - auto sys = py::module::import("sys"); + auto sys = py::module_::import("sys"); bool dont_write_bytecode = sys.attr("dont_write_bytecode").cast(); sys.attr("dont_write_bytecode") = true; // Reset the value at scope exit @@ -267,8 +267,8 @@ TEST_CASE("Reload module from file") { }); // Import the module from file - auto module = py::module::import(module_name.c_str()); - int result = module.attr("test")().cast(); + auto module_ = py::module_::import(module_name.c_str()); + int result = module_.attr("test")().cast(); REQUIRE(result == 1); // Update the module .py file with a small change @@ -278,7 +278,7 @@ TEST_CASE("Reload module from file") { test_module.close(); // Reload the module - module.reload(); - result = module.attr("test")().cast(); + module_.reload(); + result = module_.attr("test")().cast(); REQUIRE(result == 2); } diff --git a/plugins/python/pybind11/tests/test_embed/test_interpreter.py b/plugins/python/pybind11/tests/test_embed/test_interpreter.py index 26a0479..6174ede 100644 --- a/plugins/python/pybind11/tests/test_embed/test_interpreter.py +++ b/plugins/python/pybind11/tests/test_embed/test_interpreter.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- from widget_module import Widget diff --git a/plugins/python/pybind11/tests/test_enum.cpp b/plugins/python/pybind11/tests/test_enum.cpp index 49f31ba..3153089 100644 --- a/plugins/python/pybind11/tests/test_enum.cpp +++ b/plugins/python/pybind11/tests/test_enum.cpp @@ -13,11 +13,13 @@ TEST_SUBMODULE(enums, m) { // test_unscoped_enum enum UnscopedEnum { EOne = 1, - ETwo + ETwo, + EThree }; - py::enum_(m, "UnscopedEnum", py::arithmetic()) - .value("EOne", EOne) - .value("ETwo", ETwo) + py::enum_(m, "UnscopedEnum", py::arithmetic(), "An unscoped enumeration") + .value("EOne", EOne, "Docstring for EOne") + .value("ETwo", ETwo, "Docstring for ETwo") + .value("EThree", EThree, "Docstring for EThree") .export_values(); // test_scoped_enum @@ -68,4 +70,18 @@ TEST_SUBMODULE(enums, m) { m.def("test_enum_to_int", [](int) { }); m.def("test_enum_to_uint", [](uint32_t) { }); m.def("test_enum_to_long_long", [](long long) { }); + + // test_duplicate_enum_name + enum SimpleEnum + { + ONE, TWO, THREE + }; + + m.def("register_bad_enum", [m]() { + py::enum_(m, "SimpleEnum") + .value("ONE", SimpleEnum::ONE) //NOTE: all value function calls are called with the same first parameter value + .value("ONE", SimpleEnum::TWO) + .value("ONE", SimpleEnum::THREE) + .export_values(); + }); } diff --git a/plugins/python/pybind11/tests/test_enum.py b/plugins/python/pybind11/tests/test_enum.py index d8eff52..f6b24fc 100644 --- a/plugins/python/pybind11/tests/test_enum.py +++ b/plugins/python/pybind11/tests/test_enum.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import enums as m @@ -6,22 +7,91 @@ def test_unscoped_enum(): assert str(m.UnscopedEnum.EOne) == "UnscopedEnum.EOne" assert str(m.UnscopedEnum.ETwo) == "UnscopedEnum.ETwo" assert str(m.EOne) == "UnscopedEnum.EOne" + assert repr(m.UnscopedEnum.EOne) == "" + assert repr(m.UnscopedEnum.ETwo) == "" + assert repr(m.EOne) == "" + + # name property + assert m.UnscopedEnum.EOne.name == "EOne" + assert m.UnscopedEnum.ETwo.name == "ETwo" + assert m.EOne.name == "EOne" + # name readonly + with pytest.raises(AttributeError): + m.UnscopedEnum.EOne.name = "" + # name returns a copy + foo = m.UnscopedEnum.EOne.name + foo = "bar" + assert m.UnscopedEnum.EOne.name == "EOne" + # __members__ property - assert m.UnscopedEnum.__members__ == \ - {"EOne": m.UnscopedEnum.EOne, "ETwo": m.UnscopedEnum.ETwo} + assert m.UnscopedEnum.__members__ == { + "EOne": m.UnscopedEnum.EOne, + "ETwo": m.UnscopedEnum.ETwo, + "EThree": m.UnscopedEnum.EThree, + } # __members__ readonly with pytest.raises(AttributeError): m.UnscopedEnum.__members__ = {} # __members__ returns a copy foo = m.UnscopedEnum.__members__ foo["bar"] = "baz" - assert m.UnscopedEnum.__members__ == \ - {"EOne": m.UnscopedEnum.EOne, "ETwo": m.UnscopedEnum.ETwo} + assert m.UnscopedEnum.__members__ == { + "EOne": m.UnscopedEnum.EOne, + "ETwo": m.UnscopedEnum.ETwo, + "EThree": m.UnscopedEnum.EThree, + } + + for docstring_line in """An unscoped enumeration + +Members: + + EOne : Docstring for EOne + + ETwo : Docstring for ETwo + + EThree : Docstring for EThree""".split( + "\n" + ): + assert docstring_line in m.UnscopedEnum.__doc__ - # no TypeError exception for unscoped enum ==/!= int comparisons + # Unscoped enums will accept ==/!= int comparisons y = m.UnscopedEnum.ETwo assert y == 2 + assert 2 == y assert y != 3 + assert 3 != y + # Compare with None + assert y != None # noqa: E711 + assert not (y == None) # noqa: E711 + # Compare with an object + assert y != object() + assert not (y == object()) + # Compare with string + assert y != "2" + assert "2" != y + assert not ("2" == y) + assert not (y == "2") + + with pytest.raises(TypeError): + y < object() + + with pytest.raises(TypeError): + y <= object() + + with pytest.raises(TypeError): + y > object() + + with pytest.raises(TypeError): + y >= object() + + with pytest.raises(TypeError): + y | object() + + with pytest.raises(TypeError): + y & object() + + with pytest.raises(TypeError): + y ^ object() assert int(m.UnscopedEnum.ETwo) == 2 assert str(m.UnscopedEnum(2)) == "UnscopedEnum.ETwo" @@ -40,17 +110,37 @@ def test_unscoped_enum(): assert not (m.UnscopedEnum.ETwo < m.UnscopedEnum.EOne) assert not (2 < m.UnscopedEnum.EOne) + # arithmetic + assert m.UnscopedEnum.EOne & m.UnscopedEnum.EThree == m.UnscopedEnum.EOne + assert m.UnscopedEnum.EOne | m.UnscopedEnum.ETwo == m.UnscopedEnum.EThree + assert m.UnscopedEnum.EOne ^ m.UnscopedEnum.EThree == m.UnscopedEnum.ETwo + def test_scoped_enum(): assert m.test_scoped_enum(m.ScopedEnum.Three) == "ScopedEnum::Three" z = m.ScopedEnum.Two assert m.test_scoped_enum(z) == "ScopedEnum::Two" - # expected TypeError exceptions for scoped enum ==/!= int comparisons + # Scoped enums will *NOT* accept ==/!= int comparisons (Will always return False) + assert not z == 3 + assert not 3 == z + assert z != 3 + assert 3 != z + # Compare with None + assert z != None # noqa: E711 + assert not (z == None) # noqa: E711 + # Compare with an object + assert z != object() + assert not (z == object()) + # Scoped enums will *NOT* accept >, <, >= and <= int comparisons (Will throw exceptions) + with pytest.raises(TypeError): + z > 3 with pytest.raises(TypeError): - assert z == 2 + z < 3 with pytest.raises(TypeError): - assert z != 3 + z >= 3 + with pytest.raises(TypeError): + z <= 3 # order assert m.ScopedEnum.Two < m.ScopedEnum.Three @@ -64,6 +154,8 @@ def test_scoped_enum(): def test_implicit_conversion(): assert str(m.ClassWithUnscopedEnum.EMode.EFirstMode) == "EMode.EFirstMode" assert str(m.ClassWithUnscopedEnum.EFirstMode) == "EMode.EFirstMode" + assert repr(m.ClassWithUnscopedEnum.EMode.EFirstMode) == "" + assert repr(m.ClassWithUnscopedEnum.EFirstMode) == "" f = m.ClassWithUnscopedEnum.test_function first = m.ClassWithUnscopedEnum.EFirstMode @@ -88,7 +180,7 @@ def test_implicit_conversion(): x[f(first)] = 3 x[f(second)] = 4 # Hashing test - assert str(x) == "{EMode.EFirstMode: 3, EMode.ESecondMode: 4}" + assert repr(x) == "{: 3, : 4}" def test_binary_operators(): @@ -100,6 +192,7 @@ def test_binary_operators(): assert int(m.Flags.Read | m.Flags.Execute) == 5 assert int(m.Flags.Write | m.Flags.Execute) == 3 assert int(m.Flags.Write | 1) == 3 + assert ~m.Flags.Write == -3 state = m.Flags.Read | m.Flags.Write assert (state & m.Flags.Read) != 0 @@ -119,3 +212,16 @@ def test_enum_to_int(): m.test_enum_to_uint(m.ClassWithUnscopedEnum.EMode.EFirstMode) m.test_enum_to_long_long(m.Flags.Read) m.test_enum_to_long_long(m.ClassWithUnscopedEnum.EMode.EFirstMode) + + +def test_duplicate_enum_name(): + with pytest.raises(ValueError) as excinfo: + m.register_bad_enum() + assert str(excinfo.value) == 'SimpleEnum: element "ONE" already exists!' + + +def test_docstring_signatures(): + for enum_type in [m.ScopedEnum, m.UnscopedEnum]: + for attr in enum_type.__dict__.values(): + # Issue #2623/PR #2637: Add argument names to enum_ methods + assert "arg0" not in (attr.__doc__ or "") diff --git a/plugins/python/pybind11/tests/test_eval.cpp b/plugins/python/pybind11/tests/test_eval.cpp index e094821..5416c2e 100644 --- a/plugins/python/pybind11/tests/test_eval.cpp +++ b/plugins/python/pybind11/tests/test_eval.cpp @@ -14,7 +14,7 @@ TEST_SUBMODULE(eval_, m) { // test_evals - auto global = py::dict(py::module::import("__main__").attr("__dict__")); + auto global = py::dict(py::module_::import("__main__").attr("__dict__")); m.def("test_eval_statements", [global]() { auto local = py::dict(); @@ -88,4 +88,12 @@ TEST_SUBMODULE(eval_, m) { } return false; }); + + // test_eval_empty_globals + m.def("eval_empty_globals", [](py::object global) { + if (global.is_none()) + global = py::dict(); + auto int_class = py::eval("isinstance(42, int)", global); + return global; + }); } diff --git a/plugins/python/pybind11/tests/test_eval.py b/plugins/python/pybind11/tests/test_eval.py index bda4ef6..1bb05af 100644 --- a/plugins/python/pybind11/tests/test_eval.py +++ b/plugins/python/pybind11/tests/test_eval.py @@ -1,4 +1,10 @@ +# -*- coding: utf-8 -*- import os + +import pytest + +import env # noqa: F401 + from pybind11_tests import eval_ as m @@ -10,8 +16,20 @@ def test_evals(capture): assert m.test_eval() assert m.test_eval_single_statement() + assert m.test_eval_failure() + + +@pytest.mark.xfail("env.PYPY and not env.PY2", raises=RuntimeError) +def test_eval_file(): filename = os.path.join(os.path.dirname(__file__), "test_eval_call.py") assert m.test_eval_file(filename) - assert m.test_eval_failure() assert m.test_eval_file_failure() + + +def test_eval_empty_globals(): + assert "__builtins__" in m.eval_empty_globals(None) + + g = {} + assert "__builtins__" in m.eval_empty_globals(g) + assert "__builtins__" in g diff --git a/plugins/python/pybind11/tests/test_eval_call.py b/plugins/python/pybind11/tests/test_eval_call.py index 53c7e72..373b67b 100644 --- a/plugins/python/pybind11/tests/test_eval_call.py +++ b/plugins/python/pybind11/tests/test_eval_call.py @@ -1,4 +1,5 @@ +# -*- coding: utf-8 -*- # This file is called from 'test_eval.py' -if 'call_test2' in locals(): +if "call_test2" in locals(): call_test2(y) # noqa: F821 undefined name diff --git a/plugins/python/pybind11/tests/test_exceptions.cpp b/plugins/python/pybind11/tests/test_exceptions.cpp index cf20214..e27c16d 100644 --- a/plugins/python/pybind11/tests/test_exceptions.cpp +++ b/plugins/python/pybind11/tests/test_exceptions.cpp @@ -13,7 +13,7 @@ class MyException : public std::exception { public: explicit MyException(const char * m) : message{m} {} - virtual const char * what() const noexcept override {return message.c_str();} + const char * what() const noexcept override {return message.c_str();} private: std::string message = ""; }; @@ -22,7 +22,7 @@ class MyException : public std::exception { class MyException2 : public std::exception { public: explicit MyException2(const char * m) : message{m} {} - virtual const char * what() const noexcept override {return message.c_str();} + const char * what() const noexcept override {return message.c_str();} private: std::string message = ""; }; @@ -32,6 +32,13 @@ class MyException3 { public: explicit MyException3(const char * m) : message{m} {} virtual const char * what() const noexcept {return message.c_str();} + // Rule of 5 BEGIN: to preempt compiler warnings. + MyException3(const MyException3&) = default; + MyException3(MyException3&&) = default; + MyException3& operator=(const MyException3&) = default; + MyException3& operator=(MyException3&&) = default; + virtual ~MyException3() = default; + // Rule of 5 END. private: std::string message = ""; }; @@ -41,7 +48,7 @@ class MyException3 { class MyException4 : public std::exception { public: explicit MyException4(const char * m) : message{m} {} - virtual const char * what() const noexcept override {return message.c_str();} + const char * what() const noexcept override {return message.c_str();} private: std::string message = ""; }; @@ -65,6 +72,25 @@ struct PythonCallInDestructor { py::dict d; }; + + +struct PythonAlreadySetInDestructor { + PythonAlreadySetInDestructor(const py::str &s) : s(s) {} + ~PythonAlreadySetInDestructor() { + py::dict foo; + try { + // Assign to a py::object to force read access of nonexistent dict entry + py::object o = foo["bar"]; + } + catch (py::error_already_set& ex) { + ex.discard_as_unraisable(s); + } + } + + py::str s; +}; + + TEST_SUBMODULE(exceptions, m) { m.def("throw_std_exception", []() { throw std::runtime_error("This exception was intentionally thrown."); @@ -116,12 +142,41 @@ TEST_SUBMODULE(exceptions, m) { m.def("throws5", []() { throw MyException5("this is a helper-defined translated exception"); }); m.def("throws5_1", []() { throw MyException5_1("MyException5 subclass"); }); m.def("throws_logic_error", []() { throw std::logic_error("this error should fall through to the standard handler"); }); + m.def("throws_overflow_error", []() {throw std::overflow_error(""); }); m.def("exception_matches", []() { py::dict foo; - try { foo["bar"]; } + try { + // Assign to a py::object to force read access of nonexistent dict entry + py::object o = foo["bar"]; + } catch (py::error_already_set& ex) { if (!ex.matches(PyExc_KeyError)) throw; + return true; } + return false; + }); + m.def("exception_matches_base", []() { + py::dict foo; + try { + // Assign to a py::object to force read access of nonexistent dict entry + py::object o = foo["bar"]; + } + catch (py::error_already_set &ex) { + if (!ex.matches(PyExc_Exception)) throw; + return true; + } + return false; + }); + m.def("modulenotfound_exception_matches_base", []() { + try { + // On Python >= 3.6, this raises a ModuleNotFoundError, a subclass of ImportError + py::module_::import("nonexistent"); + } + catch (py::error_already_set &ex) { + if (!ex.matches(PyExc_ImportError)) throw; + return true; + } + return false; }); m.def("throw_already_set", [](bool err) { @@ -154,6 +209,11 @@ TEST_SUBMODULE(exceptions, m) { return false; }); + m.def("python_alreadyset_in_destructor", [](py::str s) { + PythonAlreadySetInDestructor alreadyset_in_destructor(s); + return true; + }); + // test_nested_throws m.def("try_catch", [m](py::object exc_type, py::function f, py::args args) { try { f(*args); } @@ -165,4 +225,7 @@ TEST_SUBMODULE(exceptions, m) { } }); + // Test repr that cannot be displayed + m.def("simple_bool_passthrough", [](bool x) {return x;}); + } diff --git a/plugins/python/pybind11/tests/test_exceptions.py b/plugins/python/pybind11/tests/test_exceptions.py index 8d37c09..95eac70 100644 --- a/plugins/python/pybind11/tests/test_exceptions.py +++ b/plugins/python/pybind11/tests/test_exceptions.py @@ -1,3 +1,6 @@ +# -*- coding: utf-8 -*- +import sys + import pytest from pybind11_tests import exceptions as m @@ -47,8 +50,37 @@ def test_python_call_in_catch(): assert d["good"] is True +def test_python_alreadyset_in_destructor(monkeypatch, capsys): + hooked = False + triggered = [False] # mutable, so Python 2.7 closure can modify it + + if hasattr(sys, "unraisablehook"): # Python 3.8+ + hooked = True + default_hook = sys.unraisablehook + + def hook(unraisable_hook_args): + exc_type, exc_value, exc_tb, err_msg, obj = unraisable_hook_args + if obj == "already_set demo": + triggered[0] = True + default_hook(unraisable_hook_args) + return + + # Use monkeypatch so pytest can apply and remove the patch as appropriate + monkeypatch.setattr(sys, "unraisablehook", hook) + + assert m.python_alreadyset_in_destructor("already_set demo") is True + if hooked: + assert triggered[0] is True + + _, captured_stderr = capsys.readouterr() + # Error message is different in Python 2 and 3, check for words that appear in both + assert "ignored" in captured_stderr and "already_set demo" in captured_stderr + + def test_exception_matches(): - m.exception_matches() + assert m.exception_matches() + assert m.exception_matches_base() + assert m.modulenotfound_exception_matches_base() def test_custom(msg): @@ -75,7 +107,13 @@ def test_custom(msg): # Can we fall-through to the default handler? with pytest.raises(RuntimeError) as excinfo: m.throws_logic_error() - assert msg(excinfo.value) == "this error should fall through to the standard handler" + assert ( + msg(excinfo.value) == "this error should fall through to the standard handler" + ) + + # OverFlow error translation. + with pytest.raises(OverflowError) as excinfo: + m.throws_overflow_error() # Can we handle a helper-declared exception? with pytest.raises(m.MyException5) as excinfo: @@ -130,7 +168,13 @@ def pycatch(exctype, f, *args): # C++ -> Python -> C++ -> Python with capture: m.try_catch( - m.MyException5, pycatch, m.MyException, m.try_catch, m.MyException, throw_myex5) + m.MyException5, + pycatch, + m.MyException, + m.try_catch, + m.MyException, + throw_myex5, + ) assert str(capture).startswith("MyException5: nested error 5") # C++ -> Python -> C++ @@ -142,3 +186,13 @@ def pycatch(exctype, f, *args): with pytest.raises(m.MyException5) as excinfo: m.try_catch(m.MyException, pycatch, m.MyException, m.throws5) assert str(excinfo.value) == "this is a helper-defined translated exception" + + +# This can often happen if you wrap a pybind11 class in a Python wrapper +def test_invalid_repr(): + class MyRepr(object): + def __repr__(self): + raise AttributeError("Example error") + + with pytest.raises(TypeError): + m.simple_bool_passthrough(MyRepr()) diff --git a/plugins/python/pybind11/tests/test_factory_constructors.cpp b/plugins/python/pybind11/tests/test_factory_constructors.cpp index 687a5bf..f42d1f2 100644 --- a/plugins/python/pybind11/tests/test_factory_constructors.cpp +++ b/plugins/python/pybind11/tests/test_factory_constructors.cpp @@ -11,6 +11,7 @@ #include "pybind11_tests.h" #include "constructor_stats.h" #include +#include // Classes for testing python construction via C++ factory function: // Not publicly constructible, copyable, or movable: @@ -57,13 +58,13 @@ class TestFactory4 : public TestFactory3 { public: TestFactory4() : TestFactory3() { print_default_created(this); } TestFactory4(int v) : TestFactory3(v) { print_created(this, v); } - virtual ~TestFactory4() { print_destroyed(this); } + ~TestFactory4() override { print_destroyed(this); } }; // Another class for an invalid downcast test class TestFactory5 : public TestFactory3 { public: TestFactory5(int i) : TestFactory3(i) { print_created(this, i); } - virtual ~TestFactory5() { print_destroyed(this); } + ~TestFactory5() override { print_destroyed(this); } }; class TestFactory6 { @@ -87,8 +88,8 @@ class PyTF6 : public TestFactory6 { PyTF6(PyTF6 &&f) : TestFactory6(std::move(f)) { print_move_created(this); } PyTF6(const PyTF6 &f) : TestFactory6(f) { print_copy_created(this); } PyTF6(std::string s) : TestFactory6((int) s.size()) { alias = true; print_created(this, s); } - virtual ~PyTF6() { print_destroyed(this); } - int get() override { PYBIND11_OVERLOAD(int, TestFactory6, get, /*no args*/); } + ~PyTF6() override { print_destroyed(this); } + int get() override { PYBIND11_OVERRIDE(int, TestFactory6, get, /*no args*/); } }; class TestFactory7 { @@ -108,8 +109,8 @@ class PyTF7 : public TestFactory7 { PyTF7(int i) : TestFactory7(i) { alias = true; print_created(this, i); } PyTF7(PyTF7 &&f) : TestFactory7(std::move(f)) { print_move_created(this); } PyTF7(const PyTF7 &f) : TestFactory7(f) { print_copy_created(this); } - virtual ~PyTF7() { print_destroyed(this); } - int get() override { PYBIND11_OVERLOAD(int, TestFactory7, get, /*no args*/); } + ~PyTF7() override { print_destroyed(this); } + int get() override { PYBIND11_OVERRIDE(int, TestFactory7, get, /*no args*/); } }; @@ -141,7 +142,7 @@ class TestFactoryHelper { TEST_SUBMODULE(factory_constructors, m) { // Define various trivial types to allow simpler overload resolution: - py::module m_tag = m.def_submodule("tag"); + py::module_ m_tag = m.def_submodule("tag"); #define MAKE_TAG_TYPE(Name) \ struct Name##_tag {}; \ py::class_(m_tag, #Name "_tag").def(py::init<>()); \ @@ -154,6 +155,8 @@ TEST_SUBMODULE(factory_constructors, m) { MAKE_TAG_TYPE(TF4); MAKE_TAG_TYPE(TF5); MAKE_TAG_TYPE(null_ptr); + MAKE_TAG_TYPE(null_unique_ptr); + MAKE_TAG_TYPE(null_shared_ptr); MAKE_TAG_TYPE(base); MAKE_TAG_TYPE(invalid_base); MAKE_TAG_TYPE(alias); @@ -194,6 +197,8 @@ TEST_SUBMODULE(factory_constructors, m) { // Returns nullptr: .def(py::init([](null_ptr_tag) { return (TestFactory3 *) nullptr; })) + .def(py::init([](null_unique_ptr_tag) { return std::unique_ptr(); })) + .def(py::init([](null_shared_ptr_tag) { return std::shared_ptr(); })) .def_readwrite("value", &TestFactory3::value) ; @@ -285,6 +290,7 @@ TEST_SUBMODULE(factory_constructors, m) { // test_reallocations // Class that has verbose operator_new/operator_delete calls struct NoisyAlloc { + NoisyAlloc(const NoisyAlloc &) = default; NoisyAlloc(int i) { py::print(py::str("NoisyAlloc(int {})").format(i)); } NoisyAlloc(double d) { py::print(py::str("NoisyAlloc(double {})").format(d)); } ~NoisyAlloc() { py::print("~NoisyAlloc()"); } diff --git a/plugins/python/pybind11/tests/test_factory_constructors.py b/plugins/python/pybind11/tests/test_factory_constructors.py index 78a3910..ffcce6f 100644 --- a/plugins/python/pybind11/tests/test_factory_constructors.py +++ b/plugins/python/pybind11/tests/test_factory_constructors.py @@ -1,6 +1,9 @@ +# -*- coding: utf-8 -*- import pytest import re +import env # noqa: F401 + from pybind11_tests import factory_constructors as m from pybind11_tests.factory_constructors import tag from pybind11_tests import ConstructorStats @@ -9,7 +12,10 @@ def test_init_factory_basic(): """Tests py::init_factory() wrapper around various ways of returning the object""" - cstats = [ConstructorStats.get(c) for c in [m.TestFactory1, m.TestFactory2, m.TestFactory3]] + cstats = [ + ConstructorStats.get(c) + for c in [m.TestFactory1, m.TestFactory2, m.TestFactory3] + ] cstats[0].alive() # force gc n_inst = ConstructorStats.detail_reg_inst() @@ -38,9 +44,12 @@ def test_init_factory_basic(): z3 = m.TestFactory3("bye") assert z3.value == "bye" - with pytest.raises(TypeError) as excinfo: - m.TestFactory3(tag.null_ptr) - assert str(excinfo.value) == "pybind11::init(): factory function returned nullptr" + for null_ptr_kind in [tag.null_ptr, tag.null_unique_ptr, tag.null_shared_ptr]: + with pytest.raises(TypeError) as excinfo: + m.TestFactory3(null_ptr_kind) + assert ( + str(excinfo.value) == "pybind11::init(): factory function returned nullptr" + ) assert [i.alive() for i in cstats] == [3, 3, 3] assert ConstructorStats.detail_reg_inst() == n_inst + 9 @@ -55,7 +64,7 @@ def test_init_factory_basic(): assert [i.values() for i in cstats] == [ ["3", "hi!"], ["7", "hi again"], - ["42", "bye"] + ["42", "bye"], ] assert [i.default_constructions for i in cstats] == [1, 1, 1] @@ -63,7 +72,9 @@ def test_init_factory_basic(): def test_init_factory_signature(msg): with pytest.raises(TypeError) as excinfo: m.TestFactory1("invalid", "constructor", "arguments") - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ __init__(): incompatible constructor arguments. The following argument types are supported: 1. m.factory_constructors.TestFactory1(arg0: m.factory_constructors.tag.unique_ptr_tag, arg1: int) 2. m.factory_constructors.TestFactory1(arg0: str) @@ -72,8 +83,11 @@ def test_init_factory_signature(msg): Invoked with: 'invalid', 'constructor', 'arguments' """ # noqa: E501 line too long + ) - assert msg(m.TestFactory1.__init__.__doc__) == """ + assert ( + msg(m.TestFactory1.__init__.__doc__) + == """ __init__(*args, **kwargs) Overloaded function. @@ -85,12 +99,16 @@ def test_init_factory_signature(msg): 4. __init__(self: m.factory_constructors.TestFactory1, arg0: handle, arg1: int, arg2: handle) -> None """ # noqa: E501 line too long + ) def test_init_factory_casting(): """Tests py::init_factory() wrapper with various upcasting and downcasting returns""" - cstats = [ConstructorStats.get(c) for c in [m.TestFactory3, m.TestFactory4, m.TestFactory5]] + cstats = [ + ConstructorStats.get(c) + for c in [m.TestFactory3, m.TestFactory4, m.TestFactory5] + ] cstats[0].alive() # force gc n_inst = ConstructorStats.detail_reg_inst() @@ -128,7 +146,7 @@ def test_init_factory_casting(): assert [i.values() for i in cstats] == [ ["4", "5", "6", "7", "8"], ["4", "5", "8"], - ["6", "7"] + ["6", "7"], ] @@ -198,7 +216,7 @@ def get(self): assert [i.values() for i in cstats] == [ ["1", "8", "3", "4", "5", "6", "123", "10", "47"], - ["hi there", "3", "4", "6", "move", "123", "why hello!", "move", "47"] + ["hi there", "3", "4", "6", "move", "123", "why hello!", "move", "47"], ] @@ -262,9 +280,11 @@ def get(self): assert not g1.has_alias() with pytest.raises(TypeError) as excinfo: PythFactory7(tag.shared_ptr, tag.invalid_base, 14) - assert (str(excinfo.value) == - "pybind11::init(): construction failed: returned holder-wrapped instance is not an " - "alias instance") + assert ( + str(excinfo.value) + == "pybind11::init(): construction failed: returned holder-wrapped instance is not an " + "alias instance" + ) assert [i.alive() for i in cstats] == [13, 7] assert ConstructorStats.detail_reg_inst() == n_inst + 13 @@ -278,7 +298,7 @@ def get(self): assert [i.values() for i in cstats] == [ ["1", "2", "3", "4", "5", "6", "7", "8", "9", "100", "11", "12", "13", "14"], - ["2", "4", "6", "8", "9", "100", "12"] + ["2", "4", "6", "8", "9", "100", "12"], ] @@ -288,7 +308,7 @@ def test_no_placement_new(capture): with capture: a = m.NoPlacementNew(123) - found = re.search(r'^operator new called, returning (\d+)\n$', str(capture)) + found = re.search(r"^operator new called, returning (\d+)\n$", str(capture)) assert found assert a.i == 123 with capture: @@ -299,7 +319,7 @@ def test_no_placement_new(capture): with capture: b = m.NoPlacementNew() - found = re.search(r'^operator new called, returning (\d+)\n$', str(capture)) + found = re.search(r"^operator new called, returning (\d+)\n$", str(capture)) assert found assert b.i == 100 with capture: @@ -327,19 +347,21 @@ def create_and_destroy(*args): def strip_comments(s): - return re.sub(r'\s+#.*', '', s) + return re.sub(r"\s+#.*", "", s) -def test_reallocations(capture, msg): +def test_reallocation_a(capture, msg): """When the constructor is overloaded, previous overloads can require a preallocated value. This test makes sure that such preallocated values only happen when they might be necessary, - and that they are deallocated properly""" + and that they are deallocated properly.""" pytest.gc_collect() with capture: create_and_destroy(1) - assert msg(capture) == """ + assert ( + msg(capture) + == """ noisy new noisy placement new NoisyAlloc(int 1) @@ -347,9 +369,14 @@ def test_reallocations(capture, msg): ~NoisyAlloc() noisy delete """ + ) + + +def test_reallocation_b(capture, msg): with capture: create_and_destroy(1.5) - assert msg(capture) == strip_comments(""" + assert msg(capture) == strip_comments( + """ noisy new # allocation required to attempt first overload noisy delete # have to dealloc before considering factory init overload noisy new # pointer factory calling "new", part 1: allocation @@ -357,43 +384,59 @@ def test_reallocations(capture, msg): --- ~NoisyAlloc() # Destructor noisy delete # operator delete - """) + """ + ) + +def test_reallocation_c(capture, msg): with capture: create_and_destroy(2, 3) - assert msg(capture) == strip_comments(""" + assert msg(capture) == strip_comments( + """ noisy new # pointer factory calling "new", allocation NoisyAlloc(int 2) # constructor --- ~NoisyAlloc() # Destructor noisy delete # operator delete - """) + """ + ) + +def test_reallocation_d(capture, msg): with capture: create_and_destroy(2.5, 3) - assert msg(capture) == strip_comments(""" + assert msg(capture) == strip_comments( + """ NoisyAlloc(double 2.5) # construction (local func variable: operator_new not called) noisy new # return-by-value "new" part 1: allocation ~NoisyAlloc() # moved-away local func variable destruction --- ~NoisyAlloc() # Destructor noisy delete # operator delete - """) + """ + ) + +def test_reallocation_e(capture, msg): with capture: create_and_destroy(3.5, 4.5) - assert msg(capture) == strip_comments(""" + assert msg(capture) == strip_comments( + """ noisy new # preallocation needed before invoking placement-new overload noisy placement new # Placement new NoisyAlloc(double 3.5) # construction --- ~NoisyAlloc() # Destructor noisy delete # operator delete - """) + """ + ) + +def test_reallocation_f(capture, msg): with capture: create_and_destroy(4, 0.5) - assert msg(capture) == strip_comments(""" + assert msg(capture) == strip_comments( + """ noisy new # preallocation needed before invoking placement-new overload noisy delete # deallocation of preallocated storage noisy new # Factory pointer allocation @@ -401,11 +444,15 @@ def test_reallocations(capture, msg): --- ~NoisyAlloc() # Destructor noisy delete # operator delete - """) + """ + ) + +def test_reallocation_g(capture, msg): with capture: create_and_destroy(5, "hi") - assert msg(capture) == strip_comments(""" + assert msg(capture) == strip_comments( + """ noisy new # preallocation needed before invoking first placement new noisy delete # delete before considering new-style constructor noisy new # preallocation for second placement new @@ -414,13 +461,15 @@ def test_reallocations(capture, msg): --- ~NoisyAlloc() # Destructor noisy delete # operator delete - """) + """ + ) -@pytest.unsupported_on_py2 +@pytest.mark.skipif("env.PY2") def test_invalid_self(): """Tests invocation of the pybind-registered base class with an invalid `self` argument. You can only actually do this on Python 3: Python 2 raises an exception itself if you try.""" + class NotPybindDerived(object): pass @@ -444,16 +493,26 @@ def __init__(self, bad): a = m.TestFactory2(tag.pointer, 1) m.TestFactory6.__init__(a, tag.alias, 1) elif bad == 3: - m.TestFactory6.__init__(NotPybindDerived.__new__(NotPybindDerived), tag.base, 1) + m.TestFactory6.__init__( + NotPybindDerived.__new__(NotPybindDerived), tag.base, 1 + ) elif bad == 4: - m.TestFactory6.__init__(NotPybindDerived.__new__(NotPybindDerived), tag.alias, 1) + m.TestFactory6.__init__( + NotPybindDerived.__new__(NotPybindDerived), tag.alias, 1 + ) for arg in (1, 2): with pytest.raises(TypeError) as excinfo: BrokenTF1(arg) - assert str(excinfo.value) == "__init__(self, ...) called with invalid `self` argument" + assert ( + str(excinfo.value) + == "__init__(self, ...) called with invalid `self` argument" + ) for arg in (1, 2, 3, 4): with pytest.raises(TypeError) as excinfo: BrokenTF6(arg) - assert str(excinfo.value) == "__init__(self, ...) called with invalid `self` argument" + assert ( + str(excinfo.value) + == "__init__(self, ...) called with invalid `self` argument" + ) diff --git a/plugins/python/pybind11/tests/test_gil_scoped.cpp b/plugins/python/pybind11/tests/test_gil_scoped.cpp new file mode 100644 index 0000000..b6a45a5 --- /dev/null +++ b/plugins/python/pybind11/tests/test_gil_scoped.cpp @@ -0,0 +1,54 @@ +/* + tests/test_gil_scoped.cpp -- acquire and release gil + + Copyright (c) 2017 Borja Zarco (Google LLC) + + All rights reserved. Use of this source code is governed by a + BSD-style license that can be found in the LICENSE file. +*/ + +#include "pybind11_tests.h" +#include + + +class VirtClass { +public: + virtual ~VirtClass() = default; + VirtClass() = default; + VirtClass(const VirtClass&) = delete; + virtual void virtual_func() {} + virtual void pure_virtual_func() = 0; +}; + +class PyVirtClass : public VirtClass { + void virtual_func() override { + PYBIND11_OVERRIDE(void, VirtClass, virtual_func,); + } + void pure_virtual_func() override { + PYBIND11_OVERRIDE_PURE(void, VirtClass, pure_virtual_func,); + } +}; + +TEST_SUBMODULE(gil_scoped, m) { + py::class_(m, "VirtClass") + .def(py::init<>()) + .def("virtual_func", &VirtClass::virtual_func) + .def("pure_virtual_func", &VirtClass::pure_virtual_func); + + m.def("test_callback_py_obj", + [](py::object func) { func(); }); + m.def("test_callback_std_func", + [](const std::function &func) { func(); }); + m.def("test_callback_virtual_func", + [](VirtClass &virt) { virt.virtual_func(); }); + m.def("test_callback_pure_virtual_func", + [](VirtClass &virt) { virt.pure_virtual_func(); }); + m.def("test_cross_module_gil", + []() { + auto cm = py::module_::import("cross_module_gil_utils"); + auto gil_acquire = reinterpret_cast( + PyLong_AsVoidPtr(cm.attr("gil_acquire_funcaddr").ptr())); + py::gil_scoped_release gil_release; + gil_acquire(); + }); +} diff --git a/plugins/python/pybind11/tests/test_gil_scoped.py b/plugins/python/pybind11/tests/test_gil_scoped.py new file mode 100644 index 0000000..0a1d627 --- /dev/null +++ b/plugins/python/pybind11/tests/test_gil_scoped.py @@ -0,0 +1,94 @@ +# -*- coding: utf-8 -*- +import multiprocessing +import threading + +from pybind11_tests import gil_scoped as m + + +def _run_in_process(target, *args, **kwargs): + """Runs target in process and returns its exitcode after 10s (None if still alive).""" + process = multiprocessing.Process(target=target, args=args, kwargs=kwargs) + process.daemon = True + try: + process.start() + # Do not need to wait much, 10s should be more than enough. + process.join(timeout=10) + return process.exitcode + finally: + if process.is_alive(): + process.terminate() + + +def _python_to_cpp_to_python(): + """Calls different C++ functions that come back to Python.""" + + class ExtendedVirtClass(m.VirtClass): + def virtual_func(self): + pass + + def pure_virtual_func(self): + pass + + extended = ExtendedVirtClass() + m.test_callback_py_obj(lambda: None) + m.test_callback_std_func(lambda: None) + m.test_callback_virtual_func(extended) + m.test_callback_pure_virtual_func(extended) + + +def _python_to_cpp_to_python_from_threads(num_threads, parallel=False): + """Calls different C++ functions that come back to Python, from Python threads.""" + threads = [] + for _ in range(num_threads): + thread = threading.Thread(target=_python_to_cpp_to_python) + thread.daemon = True + thread.start() + if parallel: + threads.append(thread) + else: + thread.join() + for thread in threads: + thread.join() + + +# TODO: FIXME, sometimes returns -11 (segfault) instead of 0 on macOS Python 3.9 +def test_python_to_cpp_to_python_from_thread(): + """Makes sure there is no GIL deadlock when running in a thread. + + It runs in a separate process to be able to stop and assert if it deadlocks. + """ + assert _run_in_process(_python_to_cpp_to_python_from_threads, 1) == 0 + + +# TODO: FIXME on macOS Python 3.9 +def test_python_to_cpp_to_python_from_thread_multiple_parallel(): + """Makes sure there is no GIL deadlock when running in a thread multiple times in parallel. + + It runs in a separate process to be able to stop and assert if it deadlocks. + """ + assert _run_in_process(_python_to_cpp_to_python_from_threads, 8, parallel=True) == 0 + + +# TODO: FIXME on macOS Python 3.9 +def test_python_to_cpp_to_python_from_thread_multiple_sequential(): + """Makes sure there is no GIL deadlock when running in a thread multiple times sequentially. + + It runs in a separate process to be able to stop and assert if it deadlocks. + """ + assert ( + _run_in_process(_python_to_cpp_to_python_from_threads, 8, parallel=False) == 0 + ) + + +# TODO: FIXME on macOS Python 3.9 +def test_python_to_cpp_to_python_from_process(): + """Makes sure there is no GIL deadlock when using processes. + + This test is for completion, but it was never an issue. + """ + assert _run_in_process(_python_to_cpp_to_python) == 0 + + +def test_cross_module_gil(): + """Makes sure that the GIL can be acquired by another module from a GIL-released state.""" + m.test_cross_module_gil() # Should not raise a SIGSEGV diff --git a/plugins/python/pybind11/tests/test_iostream.cpp b/plugins/python/pybind11/tests/test_iostream.cpp index e67f88a..e916150 100644 --- a/plugins/python/pybind11/tests/test_iostream.cpp +++ b/plugins/python/pybind11/tests/test_iostream.cpp @@ -37,7 +37,7 @@ TEST_SUBMODULE(iostream, m) { }); m.def("captured_output", [](std::string msg) { - py::scoped_ostream_redirect redir(std::cout, py::module::import("sys").attr("stdout")); + py::scoped_ostream_redirect redir(std::cout, py::module_::import("sys").attr("stdout")); std::cout << msg << std::flush; }); @@ -46,7 +46,7 @@ TEST_SUBMODULE(iostream, m) { py::arg("msg"), py::arg("flush")=true); m.def("captured_err", [](std::string msg) { - py::scoped_ostream_redirect redir(std::cerr, py::module::import("sys").attr("stderr")); + py::scoped_ostream_redirect redir(std::cerr, py::module_::import("sys").attr("stderr")); std::cerr << msg << std::flush; }); @@ -65,8 +65,8 @@ TEST_SUBMODULE(iostream, m) { }); m.def("captured_dual", [](std::string msg, std::string emsg) { - py::scoped_ostream_redirect redirout(std::cout, py::module::import("sys").attr("stdout")); - py::scoped_ostream_redirect redirerr(std::cerr, py::module::import("sys").attr("stderr")); + py::scoped_ostream_redirect redirout(std::cout, py::module_::import("sys").attr("stdout")); + py::scoped_ostream_redirect redirerr(std::cerr, py::module_::import("sys").attr("stderr")); std::cout << msg << std::flush; std::cerr << emsg << std::flush; }); diff --git a/plugins/python/pybind11/tests/test_iostream.py b/plugins/python/pybind11/tests/test_iostream.py index 27095b2..506db42 100644 --- a/plugins/python/pybind11/tests/test_iostream.py +++ b/plugins/python/pybind11/tests/test_iostream.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- from pybind11_tests import iostream as m import sys @@ -17,6 +18,7 @@ # Python 3.4 from contextlib import redirect_stdout except ImportError: + @contextmanager def redirect_stdout(target): original = sys.stdout @@ -24,10 +26,12 @@ def redirect_stdout(target): yield sys.stdout = original + try: # Python 3.5 from contextlib import redirect_stderr except ImportError: + @contextmanager def redirect_stderr(target): original = sys.stderr @@ -41,16 +45,16 @@ def test_captured(capsys): m.captured_output(msg) stdout, stderr = capsys.readouterr() assert stdout == msg - assert stderr == '' + assert stderr == "" m.captured_output_default(msg) stdout, stderr = capsys.readouterr() assert stdout == msg - assert stderr == '' + assert stderr == "" m.captured_err(msg) stdout, stderr = capsys.readouterr() - assert stdout == '' + assert stdout == "" assert stderr == msg @@ -62,7 +66,7 @@ def test_captured_large_string(capsys): m.captured_output_default(msg) stdout, stderr = capsys.readouterr() assert stdout == msg - assert stderr == '' + assert stderr == "" def test_guard_capture(capsys): @@ -70,7 +74,7 @@ def test_guard_capture(capsys): m.guard_output(msg) stdout, stderr = capsys.readouterr() assert stdout == msg - assert stderr == '' + assert stderr == "" def test_series_captured(capture): @@ -87,7 +91,7 @@ def test_flush(capfd): with m.ostream_redirect(): m.noisy_function(msg, flush=False) stdout, stderr = capfd.readouterr() - assert stdout == '' + assert stdout == "" m.noisy_function(msg2, flush=True) stdout, stderr = capfd.readouterr() @@ -106,15 +110,15 @@ def test_not_captured(capfd): m.raw_output(msg) stdout, stderr = capfd.readouterr() assert stdout == msg - assert stderr == '' - assert stream.getvalue() == '' + assert stderr == "" + assert stream.getvalue() == "" stream = StringIO() with redirect_stdout(stream): m.captured_output(msg) stdout, stderr = capfd.readouterr() - assert stdout == '' - assert stderr == '' + assert stdout == "" + assert stderr == "" assert stream.getvalue() == msg @@ -124,16 +128,16 @@ def test_err(capfd): with redirect_stderr(stream): m.raw_err(msg) stdout, stderr = capfd.readouterr() - assert stdout == '' + assert stdout == "" assert stderr == msg - assert stream.getvalue() == '' + assert stream.getvalue() == "" stream = StringIO() with redirect_stderr(stream): m.captured_err(msg) stdout, stderr = capfd.readouterr() - assert stdout == '' - assert stderr == '' + assert stdout == "" + assert stderr == "" assert stream.getvalue() == msg @@ -145,8 +149,8 @@ def test_multi_captured(capfd): m.captured_output("c") m.raw_output("d") stdout, stderr = capfd.readouterr() - assert stdout == 'bd' - assert stream.getvalue() == 'ac' + assert stdout == "bd" + assert stream.getvalue() == "ac" def test_dual(capsys): @@ -163,14 +167,14 @@ def test_redirect(capfd): m.raw_output(msg) stdout, stderr = capfd.readouterr() assert stdout == msg - assert stream.getvalue() == '' + assert stream.getvalue() == "" stream = StringIO() with redirect_stdout(stream): with m.ostream_redirect(): m.raw_output(msg) stdout, stderr = capfd.readouterr() - assert stdout == '' + assert stdout == "" assert stream.getvalue() == msg stream = StringIO() @@ -178,7 +182,7 @@ def test_redirect(capfd): m.raw_output(msg) stdout, stderr = capfd.readouterr() assert stdout == msg - assert stream.getvalue() == '' + assert stream.getvalue() == "" def test_redirect_err(capfd): @@ -192,7 +196,7 @@ def test_redirect_err(capfd): m.raw_err(msg2) stdout, stderr = capfd.readouterr() assert stdout == msg - assert stderr == '' + assert stderr == "" assert stream.getvalue() == msg2 @@ -208,7 +212,7 @@ def test_redirect_both(capfd): m.raw_output(msg) m.raw_err(msg2) stdout, stderr = capfd.readouterr() - assert stdout == '' - assert stderr == '' + assert stdout == "" + assert stderr == "" assert stream.getvalue() == msg assert stream2.getvalue() == msg2 diff --git a/plugins/python/pybind11/tests/test_kwargs_and_defaults.cpp b/plugins/python/pybind11/tests/test_kwargs_and_defaults.cpp index 2263b6b..627a796 100644 --- a/plugins/python/pybind11/tests/test_kwargs_and_defaults.cpp +++ b/plugins/python/pybind11/tests/test_kwargs_and_defaults.cpp @@ -34,7 +34,9 @@ TEST_SUBMODULE(kwargs_and_defaults, m) { m.def("kw_func_udl_z", kw_func, "x"_a, "y"_a=0); // test_args_and_kwargs - m.def("args_function", [](py::args args) -> py::tuple { return args; }); + m.def("args_function", [](py::args args) -> py::tuple { + return std::move(args); + }); m.def("args_kwargs_function", [](py::args args, py::kwargs kwargs) { return py::make_tuple(args, kwargs); }); @@ -69,7 +71,7 @@ TEST_SUBMODULE(kwargs_and_defaults, m) { py::tuple t(a.size()); for (size_t i = 0; i < a.size(); i++) // Use raw Python API here to avoid an extra, intermediate incref on the tuple item: - t[i] = (int) Py_REFCNT(PyTuple_GET_ITEM(a.ptr(), static_cast(i))); + t[i] = (int) Py_REFCNT(PyTuple_GET_ITEM(a.ptr(), static_cast(i))); return t; }); m.def("mixed_args_refcount", [](py::object o, py::args a) { @@ -78,7 +80,7 @@ TEST_SUBMODULE(kwargs_and_defaults, m) { t[0] = o.ref_count(); for (size_t i = 0; i < a.size(); i++) // Use raw Python API here to avoid an extra, intermediate incref on the tuple item: - t[i + 1] = (int) Py_REFCNT(PyTuple_GET_ITEM(a.ptr(), static_cast(i))); + t[i + 1] = (int) Py_REFCNT(PyTuple_GET_ITEM(a.ptr(), static_cast(i))); return t; }); @@ -92,9 +94,49 @@ TEST_SUBMODULE(kwargs_and_defaults, m) { // m.def("bad_args6", [](py::args, py::args) {}); // m.def("bad_args7", [](py::kwargs, py::kwargs) {}); + // test_keyword_only_args + m.def("kw_only_all", [](int i, int j) { return py::make_tuple(i, j); }, + py::kw_only(), py::arg("i"), py::arg("j")); + m.def("kw_only_some", [](int i, int j, int k) { return py::make_tuple(i, j, k); }, + py::arg(), py::kw_only(), py::arg("j"), py::arg("k")); + m.def("kw_only_with_defaults", [](int i, int j, int k, int z) { return py::make_tuple(i, j, k, z); }, + py::arg() = 3, "j"_a = 4, py::kw_only(), "k"_a = 5, "z"_a); + m.def("kw_only_mixed", [](int i, int j) { return py::make_tuple(i, j); }, + "i"_a, py::kw_only(), "j"_a); + m.def("kw_only_plus_more", [](int i, int j, int k, py::kwargs kwargs) { + return py::make_tuple(i, j, k, kwargs); }, + py::arg() /* positional */, py::arg("j") = -1 /* both */, py::kw_only(), py::arg("k") /* kw-only */); + + m.def("register_invalid_kw_only", [](py::module_ m) { + m.def("bad_kw_only", [](int i, int j) { return py::make_tuple(i, j); }, + py::kw_only(), py::arg() /* invalid unnamed argument */, "j"_a); + }); + + // test_positional_only_args + m.def("pos_only_all", [](int i, int j) { return py::make_tuple(i, j); }, + py::arg("i"), py::arg("j"), py::pos_only()); + m.def("pos_only_mix", [](int i, int j) { return py::make_tuple(i, j); }, + py::arg("i"), py::pos_only(), py::arg("j")); + m.def("pos_kw_only_mix", [](int i, int j, int k) { return py::make_tuple(i, j, k); }, + py::arg("i"), py::pos_only(), py::arg("j"), py::kw_only(), py::arg("k")); + m.def("pos_only_def_mix", [](int i, int j, int k) { return py::make_tuple(i, j, k); }, + py::arg("i"), py::arg("j") = 2, py::pos_only(), py::arg("k") = 3); + + + // These should fail to compile: + // argument annotations are required when using kw_only +// m.def("bad_kw_only1", [](int) {}, py::kw_only()); + // can't specify both `py::kw_only` and a `py::args` argument +// m.def("bad_kw_only2", [](int i, py::args) {}, py::kw_only(), "i"_a); + // test_function_signatures (along with most of the above) struct KWClass { void foo(int, float) {} }; py::class_(m, "KWClass") .def("foo0", &KWClass::foo) .def("foo1", &KWClass::foo, "x"_a, "y"_a); + + // Make sure a class (not an instance) can be used as a default argument. + // The return value doesn't matter, only that the module is importable. + m.def("class_default_argument", [](py::object a) { return py::repr(a); }, + "a"_a = py::module_::import("decimal").attr("Decimal")); } diff --git a/plugins/python/pybind11/tests/test_kwargs_and_defaults.py b/plugins/python/pybind11/tests/test_kwargs_and_defaults.py index 2695876..12fe705 100644 --- a/plugins/python/pybind11/tests/test_kwargs_and_defaults.py +++ b/plugins/python/pybind11/tests/test_kwargs_and_defaults.py @@ -1,21 +1,31 @@ +# -*- coding: utf-8 -*- import pytest + +import env # noqa: F401 + from pybind11_tests import kwargs_and_defaults as m def test_function_signatures(doc): assert doc(m.kw_func0) == "kw_func0(arg0: int, arg1: int) -> str" assert doc(m.kw_func1) == "kw_func1(x: int, y: int) -> str" - assert doc(m.kw_func2) == "kw_func2(x: int=100, y: int=200) -> str" - assert doc(m.kw_func3) == "kw_func3(data: str='Hello world!') -> None" - assert doc(m.kw_func4) == "kw_func4(myList: List[int]=[13, 17]) -> str" - assert doc(m.kw_func_udl) == "kw_func_udl(x: int, y: int=300) -> str" - assert doc(m.kw_func_udl_z) == "kw_func_udl_z(x: int, y: int=0) -> str" + assert doc(m.kw_func2) == "kw_func2(x: int = 100, y: int = 200) -> str" + assert doc(m.kw_func3) == "kw_func3(data: str = 'Hello world!') -> None" + assert doc(m.kw_func4) == "kw_func4(myList: List[int] = [13, 17]) -> str" + assert doc(m.kw_func_udl) == "kw_func_udl(x: int, y: int = 300) -> str" + assert doc(m.kw_func_udl_z) == "kw_func_udl_z(x: int, y: int = 0) -> str" assert doc(m.args_function) == "args_function(*args) -> tuple" - assert doc(m.args_kwargs_function) == "args_kwargs_function(*args, **kwargs) -> tuple" - assert doc(m.KWClass.foo0) == \ - "foo0(self: m.kwargs_and_defaults.KWClass, arg0: int, arg1: float) -> None" - assert doc(m.KWClass.foo1) == \ - "foo1(self: m.kwargs_and_defaults.KWClass, x: int, y: float) -> None" + assert ( + doc(m.args_kwargs_function) == "args_kwargs_function(*args, **kwargs) -> tuple" + ) + assert ( + doc(m.KWClass.foo0) + == "foo0(self: m.kwargs_and_defaults.KWClass, arg0: int, arg1: float) -> None" + ) + assert ( + doc(m.KWClass.foo1) + == "foo1(self: m.kwargs_and_defaults.KWClass, x: int, y: float) -> None" + ) def test_named_arguments(msg): @@ -36,7 +46,9 @@ def test_named_arguments(msg): # noinspection PyArgumentList m.kw_func2(x=5, y=10, z=12) assert excinfo.match( - r'(?s)^kw_func2\(\): incompatible.*Invoked with: kwargs: ((x=5|y=10|z=12)(, |$))' + '{3}$') + r"(?s)^kw_func2\(\): incompatible.*Invoked with: kwargs: ((x=5|y=10|z=12)(, |$))" + + "{3}$" + ) assert m.kw_func4() == "{13 17}" assert m.kw_func4(myList=[1, 2, 3]) == "{1 2 3}" @@ -46,11 +58,11 @@ def test_named_arguments(msg): def test_arg_and_kwargs(): - args = 'arg1_value', 'arg2_value', 3 + args = "arg1_value", "arg2_value", 3 assert m.args_function(*args) == args - args = 'a1', 'a2' - kwargs = dict(arg3='a3', arg4=4) + args = "a1", "a2" + kwargs = dict(arg3="a3", arg4=4) assert m.args_kwargs_function(*args, **kwargs) == (args, kwargs) @@ -64,49 +76,166 @@ def test_mixed_args_and_kwargs(msg): assert mpa(1, 2.5) == (1, 2.5, ()) with pytest.raises(TypeError) as excinfo: assert mpa(1) - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ mixed_plus_args(): incompatible function arguments. The following argument types are supported: 1. (arg0: int, arg1: float, *args) -> tuple Invoked with: 1 """ # noqa: E501 line too long + ) with pytest.raises(TypeError) as excinfo: assert mpa() - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ mixed_plus_args(): incompatible function arguments. The following argument types are supported: 1. (arg0: int, arg1: float, *args) -> tuple Invoked with: """ # noqa: E501 line too long + ) - assert mpk(-2, 3.5, pi=3.14159, e=2.71828) == (-2, 3.5, {'e': 2.71828, 'pi': 3.14159}) + assert mpk(-2, 3.5, pi=3.14159, e=2.71828) == ( + -2, + 3.5, + {"e": 2.71828, "pi": 3.14159}, + ) assert mpak(7, 7.7, 7.77, 7.777, 7.7777, minusseven=-7) == ( - 7, 7.7, (7.77, 7.777, 7.7777), {'minusseven': -7}) + 7, + 7.7, + (7.77, 7.777, 7.7777), + {"minusseven": -7}, + ) assert mpakd() == (1, 3.14159, (), {}) assert mpakd(3) == (3, 3.14159, (), {}) assert mpakd(j=2.71828) == (1, 2.71828, (), {}) - assert mpakd(k=42) == (1, 3.14159, (), {'k': 42}) + assert mpakd(k=42) == (1, 3.14159, (), {"k": 42}) assert mpakd(1, 1, 2, 3, 5, 8, then=13, followedby=21) == ( - 1, 1, (2, 3, 5, 8), {'then': 13, 'followedby': 21}) + 1, + 1, + (2, 3, 5, 8), + {"then": 13, "followedby": 21}, + ) # Arguments specified both positionally and via kwargs should fail: with pytest.raises(TypeError) as excinfo: assert mpakd(1, i=1) - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ mixed_plus_args_kwargs_defaults(): incompatible function arguments. The following argument types are supported: - 1. (i: int=1, j: float=3.14159, *args, **kwargs) -> tuple + 1. (i: int = 1, j: float = 3.14159, *args, **kwargs) -> tuple Invoked with: 1; kwargs: i=1 """ # noqa: E501 line too long + ) with pytest.raises(TypeError) as excinfo: assert mpakd(1, 2, j=1) - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ mixed_plus_args_kwargs_defaults(): incompatible function arguments. The following argument types are supported: - 1. (i: int=1, j: float=3.14159, *args, **kwargs) -> tuple + 1. (i: int = 1, j: float = 3.14159, *args, **kwargs) -> tuple Invoked with: 1, 2; kwargs: j=1 """ # noqa: E501 line too long + ) + + +def test_keyword_only_args(msg): + assert m.kw_only_all(i=1, j=2) == (1, 2) + assert m.kw_only_all(j=1, i=2) == (2, 1) + + with pytest.raises(TypeError) as excinfo: + assert m.kw_only_all(i=1) == (1,) + assert "incompatible function arguments" in str(excinfo.value) + + with pytest.raises(TypeError) as excinfo: + assert m.kw_only_all(1, 2) == (1, 2) + assert "incompatible function arguments" in str(excinfo.value) + + assert m.kw_only_some(1, k=3, j=2) == (1, 2, 3) + assert m.kw_only_with_defaults(z=8) == (3, 4, 5, 8) + assert m.kw_only_with_defaults(2, z=8) == (2, 4, 5, 8) + assert m.kw_only_with_defaults(2, j=7, k=8, z=9) == (2, 7, 8, 9) + assert m.kw_only_with_defaults(2, 7, z=9, k=8) == (2, 7, 8, 9) + + assert m.kw_only_mixed(1, j=2) == (1, 2) + assert m.kw_only_mixed(j=2, i=3) == (3, 2) + assert m.kw_only_mixed(i=2, j=3) == (2, 3) + + assert m.kw_only_plus_more(4, 5, k=6, extra=7) == (4, 5, 6, {"extra": 7}) + assert m.kw_only_plus_more(3, k=5, j=4, extra=6) == (3, 4, 5, {"extra": 6}) + assert m.kw_only_plus_more(2, k=3, extra=4) == (2, -1, 3, {"extra": 4}) + + with pytest.raises(TypeError) as excinfo: + assert m.kw_only_mixed(i=1) == (1,) + assert "incompatible function arguments" in str(excinfo.value) + + with pytest.raises(RuntimeError) as excinfo: + m.register_invalid_kw_only(m) + assert ( + msg(excinfo.value) + == """ + arg(): cannot specify an unnamed argument after an kw_only() annotation + """ + ) + + +def test_positional_only_args(msg): + assert m.pos_only_all(1, 2) == (1, 2) + assert m.pos_only_all(2, 1) == (2, 1) + + with pytest.raises(TypeError) as excinfo: + m.pos_only_all(i=1, j=2) + assert "incompatible function arguments" in str(excinfo.value) + assert m.pos_only_mix(1, 2) == (1, 2) + assert m.pos_only_mix(2, j=1) == (2, 1) + + with pytest.raises(TypeError) as excinfo: + m.pos_only_mix(i=1, j=2) + assert "incompatible function arguments" in str(excinfo.value) + + assert m.pos_kw_only_mix(1, 2, k=3) == (1, 2, 3) + assert m.pos_kw_only_mix(1, j=2, k=3) == (1, 2, 3) + + with pytest.raises(TypeError) as excinfo: + m.pos_kw_only_mix(i=1, j=2, k=3) + assert "incompatible function arguments" in str(excinfo.value) + + with pytest.raises(TypeError) as excinfo: + m.pos_kw_only_mix(1, 2, 3) + assert "incompatible function arguments" in str(excinfo.value) + + with pytest.raises(TypeError) as excinfo: + m.pos_only_def_mix() + assert "incompatible function arguments" in str(excinfo.value) + + assert m.pos_only_def_mix(1) == (1, 2, 3) + assert m.pos_only_def_mix(1, 4) == (1, 4, 3) + assert m.pos_only_def_mix(1, 4, 7) == (1, 4, 7) + assert m.pos_only_def_mix(1, 4, k=7) == (1, 4, 7) + + with pytest.raises(TypeError) as excinfo: + m.pos_only_def_mix(1, j=4) + assert "incompatible function arguments" in str(excinfo.value) + + +def test_signatures(): + assert "kw_only_all(*, i: int, j: int) -> tuple\n" == m.kw_only_all.__doc__ + assert "kw_only_mixed(i: int, *, j: int) -> tuple\n" == m.kw_only_mixed.__doc__ + assert "pos_only_all(i: int, j: int, /) -> tuple\n" == m.pos_only_all.__doc__ + assert "pos_only_mix(i: int, /, j: int) -> tuple\n" == m.pos_only_mix.__doc__ + assert ( + "pos_kw_only_mix(i: int, /, j: int, *, k: int) -> tuple\n" + == m.pos_kw_only_mix.__doc__ + ) + + +@pytest.mark.xfail("env.PYPY and env.PY2", reason="PyPy2 doesn't double count") def test_args_refcount(): """Issue/PR #1216 - py::args elements get double-inc_ref()ed when combined with regular arguments""" @@ -128,11 +257,18 @@ def test_args_refcount(): assert m.args_function(-1, myval) == (-1, myval) assert refcount(myval) == expected - assert m.mixed_plus_args_kwargs(5, 6.0, myval, a=myval) == (5, 6.0, (myval,), {"a": myval}) + assert m.mixed_plus_args_kwargs(5, 6.0, myval, a=myval) == ( + 5, + 6.0, + (myval,), + {"a": myval}, + ) assert refcount(myval) == expected - assert m.args_kwargs_function(7, 8, myval, a=1, b=myval) == \ - ((7, 8, myval), {"a": 1, "b": myval}) + assert m.args_kwargs_function(7, 8, myval, a=1, b=myval) == ( + (7, 8, myval), + {"a": 1, "b": myval}, + ) assert refcount(myval) == expected exp3 = refcount(myval, myval, myval) @@ -145,3 +281,5 @@ def test_args_refcount(): # tuple without having to inc_ref the individual elements, but here we can't, hence the extra # refs. assert m.mixed_args_refcount(myval, myval, myval) == (exp3 + 3, exp3 + 3, exp3 + 3) + + assert m.class_default_argument() == "" diff --git a/plugins/python/pybind11/tests/test_local_bindings.cpp b/plugins/python/pybind11/tests/test_local_bindings.cpp index 97c02db..c61e388 100644 --- a/plugins/python/pybind11/tests/test_local_bindings.cpp +++ b/plugins/python/pybind11/tests/test_local_bindings.cpp @@ -41,7 +41,7 @@ TEST_SUBMODULE(local_bindings, m) { // should raise a runtime error from the duplicate definition attempt. If test_class isn't // available it *also* throws a runtime error (with "test_class not enabled" as value). m.def("register_local_external", [m]() { - auto main = py::module::import("pybind11_tests"); + auto main = py::module_::import("pybind11_tests"); if (py::hasattr(main, "class_")) { bind_local(m, "LocalExternal", py::module_local()); } diff --git a/plugins/python/pybind11/tests/test_local_bindings.py b/plugins/python/pybind11/tests/test_local_bindings.py index b3dc361..d23c467 100644 --- a/plugins/python/pybind11/tests/test_local_bindings.py +++ b/plugins/python/pybind11/tests/test_local_bindings.py @@ -1,5 +1,8 @@ +# -*- coding: utf-8 -*- import pytest +import env # noqa: F401 + from pybind11_tests import local_bindings as m @@ -33,8 +36,8 @@ def test_local_bindings(): assert i2.get() == 11 assert i2.get2() == 12 - assert not hasattr(i1, 'get2') - assert not hasattr(i2, 'get3') + assert not hasattr(i1, "get2") + assert not hasattr(i2, "get3") # Loading within the local module assert m.local_value(i1) == 5 @@ -52,7 +55,9 @@ def test_nonlocal_failure(): with pytest.raises(RuntimeError) as excinfo: cm.register_nonlocal() - assert str(excinfo.value) == 'generic_type: type "NonLocalType" is already registered!' + assert ( + str(excinfo.value) == 'generic_type: type "NonLocalType" is already registered!' + ) def test_duplicate_local(): @@ -60,9 +65,12 @@ def test_duplicate_local(): with pytest.raises(RuntimeError) as excinfo: m.register_local_external() import pybind11_tests + assert str(excinfo.value) == ( 'generic_type: type "LocalExternal" is already registered!' - if hasattr(pybind11_tests, 'class_') else 'test_class not enabled') + if hasattr(pybind11_tests, "class_") + else "test_class not enabled" + ) def test_stl_bind_local(): @@ -95,8 +103,8 @@ def test_stl_bind_local(): d1["b"] = v1[1] d2["c"] = v2[0] d2["d"] = v2[1] - assert {i: d1[i].get() for i in d1} == {'a': 0, 'b': 1} - assert {i: d2[i].get() for i in d2} == {'c': 2, 'd': 3} + assert {i: d1[i].get() for i in d1} == {"a": 0, "b": 1} + assert {i: d2[i].get() for i in d2} == {"c": 2, "d": 3} def test_stl_bind_global(): @@ -104,15 +112,21 @@ def test_stl_bind_global(): with pytest.raises(RuntimeError) as excinfo: cm.register_nonlocal_map() - assert str(excinfo.value) == 'generic_type: type "NonLocalMap" is already registered!' + assert ( + str(excinfo.value) == 'generic_type: type "NonLocalMap" is already registered!' + ) with pytest.raises(RuntimeError) as excinfo: cm.register_nonlocal_vec() - assert str(excinfo.value) == 'generic_type: type "NonLocalVec" is already registered!' + assert ( + str(excinfo.value) == 'generic_type: type "NonLocalVec" is already registered!' + ) with pytest.raises(RuntimeError) as excinfo: cm.register_nonlocal_map2() - assert str(excinfo.value) == 'generic_type: type "NonLocalMap2" is already registered!' + assert ( + str(excinfo.value) == 'generic_type: type "NonLocalMap2" is already registered!' + ) def test_mixed_local_global(): @@ -120,6 +134,7 @@ def test_mixed_local_global(): type can be registered even if the type is already registered globally. With the module, casting will go to the local type; outside the module casting goes to the global type.""" import pybind11_cross_module_tests as cm + m.register_mixed_global() m.register_mixed_local() @@ -142,16 +157,30 @@ def test_mixed_local_global(): a.append(cm.get_mixed_gl(11)) a.append(cm.get_mixed_lg(12)) - assert [x.get() for x in a] == \ - [101, 1002, 103, 1004, 105, 1006, 207, 2008, 109, 1010, 211, 2012] + assert [x.get() for x in a] == [ + 101, + 1002, + 103, + 1004, + 105, + 1006, + 207, + 2008, + 109, + 1010, + 211, + 2012, + ] def test_internal_locals_differ(): """Makes sure the internal local type map differs across the two modules""" import pybind11_cross_module_tests as cm + assert m.local_cpp_types_addr() != cm.local_cpp_types_addr() +@pytest.mark.xfail("env.PYPY and sys.pypy_version_info < (7, 3, 2)") def test_stl_caster_vs_stl_bind(msg): """One module uses a generic vector caster from `` while the other exports `std::vector` via `py:bind_vector` and `py::module_local`""" @@ -165,12 +194,15 @@ def test_stl_caster_vs_stl_bind(msg): assert m.load_vector_via_caster(v2) == 6 with pytest.raises(TypeError) as excinfo: cm.load_vector_via_binding(v2) == 6 - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ load_vector_via_binding(): incompatible function arguments. The following argument types are supported: 1. (arg0: pybind11_cross_module_tests.VectorInt) -> int Invoked with: [1, 2, 3] """ # noqa: E501 line too long + ) def test_cross_module_calls(): @@ -220,7 +252,7 @@ def test_cross_module_calls(): c, d = m.MixGL2(3), cm.MixGL2(4) with pytest.raises(TypeError) as excinfo: m.get_gl_value(c) - assert "incompatible function arguments" in str(excinfo) + assert "incompatible function arguments" in str(excinfo.value) with pytest.raises(TypeError) as excinfo: m.get_gl_value(d) - assert "incompatible function arguments" in str(excinfo) + assert "incompatible function arguments" in str(excinfo.value) diff --git a/plugins/python/pybind11/tests/test_methods_and_attributes.cpp b/plugins/python/pybind11/tests/test_methods_and_attributes.cpp index cd15869..6a2cfb6 100644 --- a/plugins/python/pybind11/tests/test_methods_and_attributes.cpp +++ b/plugins/python/pybind11/tests/test_methods_and_attributes.cpp @@ -11,11 +11,17 @@ #include "pybind11_tests.h" #include "constructor_stats.h" +#if !defined(PYBIND11_OVERLOAD_CAST) +template +using overload_cast_ = pybind11::detail::overload_cast_impl; +#endif + class ExampleMandA { public: ExampleMandA() { print_default_created(this); } ExampleMandA(int value) : value(value) { print_created(this, value); } ExampleMandA(const ExampleMandA &e) : value(e.value) { print_copy_created(this); } + ExampleMandA(std::string&&) {} ExampleMandA(ExampleMandA &&e) : value(e.value) { print_move_created(this); } ~ExampleMandA() { print_destroyed(this); } @@ -38,6 +44,8 @@ class ExampleMandA { void add9(int *other) { value += *other; } // passing by pointer void add10(const int *other) { value += *other; } // passing by const pointer + void consume_str(std::string&&) {} + ExampleMandA self1() { return *this; } // return by value ExampleMandA &self2() { return *this; } // return by reference const ExampleMandA &self3() { return *this; } // return by const reference @@ -100,76 +108,6 @@ struct TestPropRVP { UserType TestPropRVP::sv1(1); UserType TestPropRVP::sv2(1); -// py::arg/py::arg_v testing: these arguments just record their argument when invoked -class ArgInspector1 { public: std::string arg = "(default arg inspector 1)"; }; -class ArgInspector2 { public: std::string arg = "(default arg inspector 2)"; }; -class ArgAlwaysConverts { }; -namespace pybind11 { namespace detail { -template <> struct type_caster { -public: - PYBIND11_TYPE_CASTER(ArgInspector1, _("ArgInspector1")); - - bool load(handle src, bool convert) { - value.arg = "loading ArgInspector1 argument " + - std::string(convert ? "WITH" : "WITHOUT") + " conversion allowed. " - "Argument value = " + (std::string) str(src); - return true; - } - - static handle cast(const ArgInspector1 &src, return_value_policy, handle) { - return str(src.arg).release(); - } -}; -template <> struct type_caster { -public: - PYBIND11_TYPE_CASTER(ArgInspector2, _("ArgInspector2")); - - bool load(handle src, bool convert) { - value.arg = "loading ArgInspector2 argument " + - std::string(convert ? "WITH" : "WITHOUT") + " conversion allowed. " - "Argument value = " + (std::string) str(src); - return true; - } - - static handle cast(const ArgInspector2 &src, return_value_policy, handle) { - return str(src.arg).release(); - } -}; -template <> struct type_caster { -public: - PYBIND11_TYPE_CASTER(ArgAlwaysConverts, _("ArgAlwaysConverts")); - - bool load(handle, bool convert) { - return convert; - } - - static handle cast(const ArgAlwaysConverts &, return_value_policy, handle) { - return py::none().release(); - } -}; -}} - -// test_custom_caster_destruction -class DestructionTester { -public: - DestructionTester() { print_default_created(this); } - ~DestructionTester() { print_destroyed(this); } - DestructionTester(const DestructionTester &) { print_copy_created(this); } - DestructionTester(DestructionTester &&) { print_move_created(this); } - DestructionTester &operator=(const DestructionTester &) { print_copy_assigned(this); return *this; } - DestructionTester &operator=(DestructionTester &&) { print_move_assigned(this); return *this; } -}; -namespace pybind11 { namespace detail { -template <> struct type_caster { - PYBIND11_TYPE_CASTER(DestructionTester, _("DestructionTester")); - bool load(handle, bool) { return true; } - - static handle cast(const DestructionTester &, return_value_policy, handle) { - return py::bool_(true).release(); - } -}; -}} - // Test None-allowed py::arg argument policy class NoneTester { public: int answer = 42; }; int none1(const NoneTester &obj) { return obj.answer; } @@ -202,11 +140,20 @@ class RegisteredDerived : public UnregisteredBase { double sum() const { return rw_value + ro_value; } }; +// Test explicit lvalue ref-qualification +struct RefQualified { + int value = 0; + + void refQualified(int other) & { value += other; } + int constRefQualified(int other) const & { return value + other; } +}; + TEST_SUBMODULE(methods_and_attributes, m) { // test_methods_and_attributes py::class_ emna(m, "ExampleMandA"); emna.def(py::init<>()) .def(py::init()) + .def(py::init()) .def(py::init()) .def("add1", &ExampleMandA::add1) .def("add2", &ExampleMandA::add2) @@ -218,6 +165,7 @@ TEST_SUBMODULE(methods_and_attributes, m) { .def("add8", &ExampleMandA::add8) .def("add9", &ExampleMandA::add9) .def("add10", &ExampleMandA::add10) + .def("consume_str", &ExampleMandA::consume_str) .def("self1", &ExampleMandA::self1) .def("self2", &ExampleMandA::self2) .def("self3", &ExampleMandA::self3) @@ -242,15 +190,16 @@ TEST_SUBMODULE(methods_and_attributes, m) { .def("overloaded_const", py::overload_cast(&ExampleMandA::overloaded, py::const_)) .def("overloaded_const", py::overload_cast(&ExampleMandA::overloaded, py::const_)) #else - .def("overloaded", static_cast(&ExampleMandA::overloaded)) - .def("overloaded", static_cast(&ExampleMandA::overloaded)) - .def("overloaded", static_cast(&ExampleMandA::overloaded)) + // Use both the traditional static_cast method and the C++11 compatible overload_cast_ + .def("overloaded", overload_cast_<>()(&ExampleMandA::overloaded)) + .def("overloaded", overload_cast_()(&ExampleMandA::overloaded)) + .def("overloaded", overload_cast_()(&ExampleMandA::overloaded)) .def("overloaded", static_cast(&ExampleMandA::overloaded)) .def("overloaded", static_cast(&ExampleMandA::overloaded)) .def("overloaded", static_cast(&ExampleMandA::overloaded)) - .def("overloaded_float", static_cast(&ExampleMandA::overloaded)) - .def("overloaded_const", static_cast(&ExampleMandA::overloaded)) - .def("overloaded_const", static_cast(&ExampleMandA::overloaded)) + .def("overloaded_float", overload_cast_()(&ExampleMandA::overloaded)) + .def("overloaded_const", overload_cast_()(&ExampleMandA::overloaded, py::const_)) + .def("overloaded_const", overload_cast_()(&ExampleMandA::overloaded, py::const_)) .def("overloaded_const", static_cast(&ExampleMandA::overloaded)) .def("overloaded_const", static_cast(&ExampleMandA::overloaded)) .def("overloaded_const", static_cast(&ExampleMandA::overloaded)) @@ -258,12 +207,12 @@ TEST_SUBMODULE(methods_and_attributes, m) { // test_no_mixed_overloads // Raise error if trying to mix static/non-static overloads on the same name: .def_static("add_mixed_overloads1", []() { - auto emna = py::reinterpret_borrow>(py::module::import("pybind11_tests.methods_and_attributes").attr("ExampleMandA")); + auto emna = py::reinterpret_borrow>(py::module_::import("pybind11_tests.methods_and_attributes").attr("ExampleMandA")); emna.def ("overload_mixed1", static_cast(&ExampleMandA::overloaded)) .def_static("overload_mixed1", static_cast(&ExampleMandA::overloaded)); }) .def_static("add_mixed_overloads2", []() { - auto emna = py::reinterpret_borrow>(py::module::import("pybind11_tests.methods_and_attributes").attr("ExampleMandA")); + auto emna = py::reinterpret_borrow>(py::module_::import("pybind11_tests.methods_and_attributes").attr("ExampleMandA")); emna.def_static("overload_mixed2", static_cast(&ExampleMandA::overloaded)) .def ("overload_mixed2", static_cast(&ExampleMandA::overloaded)); }) @@ -279,12 +228,20 @@ TEST_SUBMODULE(methods_and_attributes, m) { .def(py::init<>()) .def_readonly("def_readonly", &TestProperties::value) .def_readwrite("def_readwrite", &TestProperties::value) + .def_property("def_writeonly", nullptr, + [](TestProperties& s,int v) { s.value = v; } ) + .def_property("def_property_writeonly", nullptr, &TestProperties::set) .def_property_readonly("def_property_readonly", &TestProperties::get) .def_property("def_property", &TestProperties::get, &TestProperties::set) + .def_property("def_property_impossible", nullptr, nullptr) .def_readonly_static("def_readonly_static", &TestProperties::static_value) .def_readwrite_static("def_readwrite_static", &TestProperties::static_value) + .def_property_static("def_writeonly_static", nullptr, + [](py::object, int v) { TestProperties::static_value = v; }) .def_property_readonly_static("def_property_readonly_static", [](py::object) { return TestProperties::static_get(); }) + .def_property_static("def_property_writeonly_static", nullptr, + [](py::object, int v) { return TestProperties::static_set(v); }) .def_property_static("def_property_static", [](py::object) { return TestProperties::static_get(); }, [](py::object, int v) { TestProperties::static_set(v); }) @@ -327,11 +284,18 @@ TEST_SUBMODULE(methods_and_attributes, m) { py::class_(m, "MetaclassOverride", py::metaclass((PyObject *) &PyType_Type)) .def_property_readonly_static("readonly", [](py::object) { return 1; }); + // test_overload_ordering + m.def("overload_order", [](std::string) { return 1; }); + m.def("overload_order", [](std::string) { return 2; }); + m.def("overload_order", [](int) { return 3; }); + m.def("overload_order", [](int) { return 4; }, py::prepend{}); + #if !defined(PYPY_VERSION) // test_dynamic_attributes class DynamicClass { public: DynamicClass() { print_default_created(this); } + DynamicClass(const DynamicClass&) = delete; ~DynamicClass() { print_destroyed(this); } }; py::class_(m, "DynamicClass", py::dynamic_attr()) @@ -342,33 +306,6 @@ TEST_SUBMODULE(methods_and_attributes, m) { .def(py::init()); #endif - // test_noconvert_args - // - // Test converting. The ArgAlwaysConverts is just there to make the first no-conversion pass - // fail so that our call always ends up happening via the second dispatch (the one that allows - // some conversion). - class ArgInspector { - public: - ArgInspector1 f(ArgInspector1 a, ArgAlwaysConverts) { return a; } - std::string g(ArgInspector1 a, const ArgInspector1 &b, int c, ArgInspector2 *d, ArgAlwaysConverts) { - return a.arg + "\n" + b.arg + "\n" + std::to_string(c) + "\n" + d->arg; - } - static ArgInspector2 h(ArgInspector2 a, ArgAlwaysConverts) { return a; } - }; - py::class_(m, "ArgInspector") - .def(py::init<>()) - .def("f", &ArgInspector::f, py::arg(), py::arg() = ArgAlwaysConverts()) - .def("g", &ArgInspector::g, "a"_a.noconvert(), "b"_a, "c"_a.noconvert()=13, "d"_a=ArgInspector2(), py::arg() = ArgAlwaysConverts()) - .def_static("h", &ArgInspector::h, py::arg().noconvert(), py::arg() = ArgAlwaysConverts()) - ; - m.def("arg_inspect_func", [](ArgInspector2 a, ArgInspector1 b, ArgAlwaysConverts) { return a.arg + "\n" + b.arg; }, - py::arg().noconvert(false), py::arg_v(nullptr, ArgInspector1()).noconvert(true), py::arg() = ArgAlwaysConverts()); - - m.def("floats_preferred", [](double f) { return 0.5 * f; }, py::arg("f")); - m.def("floats_only", [](double f) { return 0.5 * f; }, py::arg("f").noconvert()); - m.def("ints_preferred", [](int i) { return i / 2; }, py::arg("i")); - m.def("ints_only", [](int i) { return i / 2; }, py::arg("i").noconvert()); - // test_bad_arg_default // Issue/PR #648: bad arg default debugging output #if !defined(NDEBUG) @@ -377,11 +314,11 @@ TEST_SUBMODULE(methods_and_attributes, m) { m.attr("debug_enabled") = false; #endif m.def("bad_arg_def_named", []{ - auto m = py::module::import("pybind11_tests"); + auto m = py::module_::import("pybind11_tests"); m.def("should_fail", [](int, UnregisteredType) {}, py::arg(), py::arg("a") = UnregisteredType()); }); m.def("bad_arg_def_unnamed", []{ - auto m = py::module::import("pybind11_tests"); + auto m = py::module_::import("pybind11_tests"); m.def("should_fail", [](int, UnregisteredType) {}, py::arg(), py::arg() = UnregisteredType()); }); @@ -399,6 +336,9 @@ TEST_SUBMODULE(methods_and_attributes, m) { m.def("ok_none4", &none4, py::arg().none(true)); m.def("ok_none5", &none5); + m.def("no_none_kwarg", &none2, py::arg("a").none(false)); + m.def("no_none_kwarg_kw_only", &none2, py::kw_only(), py::arg("a").none(false)); + // test_str_issue // Issue #283: __str__ called on uninitialized instance when constructor arguments invalid py::class_(m, "StrIssue") @@ -432,15 +372,10 @@ TEST_SUBMODULE(methods_and_attributes, m) { using Adapted = decltype(py::method_adaptor(&RegisteredDerived::do_nothing)); static_assert(std::is_same::value, ""); - // test_custom_caster_destruction - // Test that `take_ownership` works on types with a custom type caster when given a pointer - - // default policy: don't take ownership: - m.def("custom_caster_no_destroy", []() { static auto *dt = new DestructionTester(); return dt; }); - - m.def("custom_caster_destroy", []() { return new DestructionTester(); }, - py::return_value_policy::take_ownership); // Takes ownership: destroy when finished - m.def("custom_caster_destroy_const", []() -> const DestructionTester * { return new DestructionTester(); }, - py::return_value_policy::take_ownership); // Likewise (const doesn't inhibit destruction) - m.def("destruction_tester_cstats", &ConstructorStats::get, py::return_value_policy::reference); + // test_methods_and_attributes + py::class_(m, "RefQualified") + .def(py::init<>()) + .def_readonly("value", &RefQualified::value) + .def("refQualified", &RefQualified::refQualified) + .def("constRefQualified", &RefQualified::constRefQualified); } diff --git a/plugins/python/pybind11/tests/test_methods_and_attributes.py b/plugins/python/pybind11/tests/test_methods_and_attributes.py index 9fd9cb7..2aaf933 100644 --- a/plugins/python/pybind11/tests/test_methods_and_attributes.py +++ b/plugins/python/pybind11/tests/test_methods_and_attributes.py @@ -1,4 +1,8 @@ +# -*- coding: utf-8 -*- import pytest + +import env # noqa: F401 + from pybind11_tests import methods_and_attributes as m from pybind11_tests import ConstructorStats @@ -36,17 +40,17 @@ def test_methods_and_attributes(): assert instance1.overloaded(0) == "(int)" assert instance1.overloaded(1, 1.0) == "(int, float)" assert instance1.overloaded(2.0, 2) == "(float, int)" - assert instance1.overloaded(3, 3) == "(int, int)" - assert instance1.overloaded(4., 4.) == "(float, float)" + assert instance1.overloaded(3, 3) == "(int, int)" + assert instance1.overloaded(4.0, 4.0) == "(float, float)" assert instance1.overloaded_const(-3) == "(int) const" assert instance1.overloaded_const(5, 5.0) == "(int, float) const" assert instance1.overloaded_const(6.0, 6) == "(float, int) const" - assert instance1.overloaded_const(7, 7) == "(int, int) const" - assert instance1.overloaded_const(8., 8.) == "(float, float) const" + assert instance1.overloaded_const(7, 7) == "(int, int) const" + assert instance1.overloaded_const(8.0, 8.0) == "(float, float) const" assert instance1.overloaded_float(1, 1) == "(float, float)" - assert instance1.overloaded_float(1, 1.) == "(float, float)" - assert instance1.overloaded_float(1., 1) == "(float, float)" - assert instance1.overloaded_float(1., 1.) == "(float, float)" + assert instance1.overloaded_float(1, 1.0) == "(float, float)" + assert instance1.overloaded_float(1.0, 1) == "(float, float)" + assert instance1.overloaded_float(1.0, 1.0) == "(float, float)" assert instance1.value == 320 instance1.value = 100 @@ -58,8 +62,8 @@ def test_methods_and_attributes(): assert cstats.alive() == 0 assert cstats.values() == ["32"] assert cstats.default_constructions == 1 - assert cstats.copy_constructions == 3 - assert cstats.move_constructions >= 1 + assert cstats.copy_constructions == 2 + assert cstats.move_constructions >= 2 assert cstats.copy_assignments == 0 assert cstats.move_assignments == 0 @@ -98,23 +102,52 @@ def test_properties(): instance.def_property = 3 assert instance.def_property == 3 + with pytest.raises(AttributeError) as excinfo: + dummy = instance.def_property_writeonly # noqa: F841 unused var + assert "unreadable attribute" in str(excinfo.value) + + instance.def_property_writeonly = 4 + assert instance.def_property_readonly == 4 + + with pytest.raises(AttributeError) as excinfo: + dummy = instance.def_property_impossible # noqa: F841 unused var + assert "unreadable attribute" in str(excinfo.value) + + with pytest.raises(AttributeError) as excinfo: + instance.def_property_impossible = 5 + assert "can't set attribute" in str(excinfo.value) + def test_static_properties(): assert m.TestProperties.def_readonly_static == 1 with pytest.raises(AttributeError) as excinfo: m.TestProperties.def_readonly_static = 2 - assert "can't set attribute" in str(excinfo) + assert "can't set attribute" in str(excinfo.value) m.TestProperties.def_readwrite_static = 2 assert m.TestProperties.def_readwrite_static == 2 - assert m.TestProperties.def_property_readonly_static == 2 with pytest.raises(AttributeError) as excinfo: - m.TestProperties.def_property_readonly_static = 3 - assert "can't set attribute" in str(excinfo) + dummy = m.TestProperties.def_writeonly_static # noqa: F841 unused var + assert "unreadable attribute" in str(excinfo.value) + + m.TestProperties.def_writeonly_static = 3 + assert m.TestProperties.def_readonly_static == 3 + + assert m.TestProperties.def_property_readonly_static == 3 + with pytest.raises(AttributeError) as excinfo: + m.TestProperties.def_property_readonly_static = 99 + assert "can't set attribute" in str(excinfo.value) + + m.TestProperties.def_property_static = 4 + assert m.TestProperties.def_property_static == 4 + + with pytest.raises(AttributeError) as excinfo: + dummy = m.TestProperties.def_property_writeonly_static + assert "unreadable attribute" in str(excinfo.value) - m.TestProperties.def_property_static = 3 - assert m.TestProperties.def_property_static == 3 + m.TestProperties.def_property_writeonly_static = 5 + assert m.TestProperties.def_property_static == 5 # Static property read and write via instance instance = m.TestProperties() @@ -127,10 +160,30 @@ def test_static_properties(): assert m.TestProperties.def_readwrite_static == 2 assert instance.def_readwrite_static == 2 + with pytest.raises(AttributeError) as excinfo: + dummy = instance.def_property_writeonly_static # noqa: F841 unused var + assert "unreadable attribute" in str(excinfo.value) + + instance.def_property_writeonly_static = 4 + assert instance.def_property_static == 4 + # It should be possible to override properties in derived classes assert m.TestPropertiesOverride().def_readonly == 99 assert m.TestPropertiesOverride.def_readonly_static == 99 + # Only static attributes can be deleted + del m.TestPropertiesOverride.def_readonly_static + assert ( + hasattr(m.TestPropertiesOverride, "def_readonly_static") + and m.TestPropertiesOverride.def_readonly_static + is m.TestProperties.def_readonly_static + ) + assert "def_readonly_static" not in m.TestPropertiesOverride.__dict__ + properties_override = m.TestPropertiesOverride() + with pytest.raises(AttributeError) as excinfo: + del properties_override.def_readonly + assert "can't delete attribute" in str(excinfo.value) + def test_static_cls(): """Static property getter and setters expect the type object as the their only argument""" @@ -153,7 +206,10 @@ def test_metaclass_override(): assert type(m.MetaclassOverride).__name__ == "type" assert m.MetaclassOverride.readonly == 1 - assert type(m.MetaclassOverride.__dict__["readonly"]).__name__ == "pybind11_static_property" + assert ( + type(m.MetaclassOverride.__dict__["readonly"]).__name__ + == "pybind11_static_property" + ) # Regular `type` replaces the property instead of calling `__set__()` m.MetaclassOverride.readonly = 2 @@ -166,22 +222,26 @@ def test_no_mixed_overloads(): with pytest.raises(RuntimeError) as excinfo: m.ExampleMandA.add_mixed_overloads1() - assert (str(excinfo.value) == - "overloading a method with both static and instance methods is not supported; " + - ("compile in debug mode for more details" if not debug_enabled else - "error while attempting to bind static method ExampleMandA.overload_mixed1" - "(arg0: float) -> str") - ) + assert str( + excinfo.value + ) == "overloading a method with both static and instance methods is not supported; " + ( + "compile in debug mode for more details" + if not debug_enabled + else "error while attempting to bind static method ExampleMandA.overload_mixed1" + "(arg0: float) -> str" + ) with pytest.raises(RuntimeError) as excinfo: m.ExampleMandA.add_mixed_overloads2() - assert (str(excinfo.value) == - "overloading a method with both static and instance methods is not supported; " + - ("compile in debug mode for more details" if not debug_enabled else - "error while attempting to bind instance method ExampleMandA.overload_mixed2" - "(self: pybind11_tests.methods_and_attributes.ExampleMandA, arg0: int, arg1: int)" - " -> str") - ) + assert str( + excinfo.value + ) == "overloading a method with both static and instance methods is not supported; " + ( + "compile in debug mode for more details" + if not debug_enabled + else "error while attempting to bind instance method ExampleMandA.overload_mixed2" + "(self: pybind11_tests.methods_and_attributes.ExampleMandA, arg0: int, arg1: int)" + " -> str" + ) @pytest.mark.parametrize("access", ["ro", "rw", "static_ro", "static_rw"]) @@ -220,8 +280,8 @@ def test_property_rvalue_policy(): assert os.value == 1 -# https://bitbucket.org/pypy/pypy/issues/2447 -@pytest.unsupported_on_pypy +# https://foss.heptapod.net/pypy/pypy/-/issues/2447 +@pytest.mark.xfail("env.PYPY") def test_dynamic_attributes(): instance = m.DynamicClass() assert not hasattr(instance, "foo") @@ -262,8 +322,8 @@ class PythonDerivedDynamicClass(m.DynamicClass): assert cstats.alive() == 0 -# https://bitbucket.org/pypy/pypy/issues/2447 -@pytest.unsupported_on_pypy +# https://foss.heptapod.net/pypy/pypy/-/issues/2447 +@pytest.mark.xfail("env.PYPY") def test_cyclic_gc(): # One object references itself instance = m.DynamicClass() @@ -285,69 +345,6 @@ def test_cyclic_gc(): assert cstats.alive() == 0 -def test_noconvert_args(msg): - a = m.ArgInspector() - assert msg(a.f("hi")) == """ - loading ArgInspector1 argument WITH conversion allowed. Argument value = hi - """ - assert msg(a.g("this is a", "this is b")) == """ - loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = this is a - loading ArgInspector1 argument WITH conversion allowed. Argument value = this is b - 13 - loading ArgInspector2 argument WITH conversion allowed. Argument value = (default arg inspector 2) - """ # noqa: E501 line too long - assert msg(a.g("this is a", "this is b", 42)) == """ - loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = this is a - loading ArgInspector1 argument WITH conversion allowed. Argument value = this is b - 42 - loading ArgInspector2 argument WITH conversion allowed. Argument value = (default arg inspector 2) - """ # noqa: E501 line too long - assert msg(a.g("this is a", "this is b", 42, "this is d")) == """ - loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = this is a - loading ArgInspector1 argument WITH conversion allowed. Argument value = this is b - 42 - loading ArgInspector2 argument WITH conversion allowed. Argument value = this is d - """ - assert (a.h("arg 1") == - "loading ArgInspector2 argument WITHOUT conversion allowed. Argument value = arg 1") - assert msg(m.arg_inspect_func("A1", "A2")) == """ - loading ArgInspector2 argument WITH conversion allowed. Argument value = A1 - loading ArgInspector1 argument WITHOUT conversion allowed. Argument value = A2 - """ - - assert m.floats_preferred(4) == 2.0 - assert m.floats_only(4.0) == 2.0 - with pytest.raises(TypeError) as excinfo: - m.floats_only(4) - assert msg(excinfo.value) == """ - floats_only(): incompatible function arguments. The following argument types are supported: - 1. (f: float) -> float - - Invoked with: 4 - """ - - assert m.ints_preferred(4) == 2 - assert m.ints_preferred(True) == 0 - with pytest.raises(TypeError) as excinfo: - m.ints_preferred(4.0) - assert msg(excinfo.value) == """ - ints_preferred(): incompatible function arguments. The following argument types are supported: - 1. (i: int) -> int - - Invoked with: 4.0 - """ # noqa: E501 line too long - - assert m.ints_only(4) == 2 - with pytest.raises(TypeError) as excinfo: - m.ints_only(4.0) - assert msg(excinfo.value) == """ - ints_only(): incompatible function arguments. The following argument types are supported: - 1. (i: int) -> int - - Invoked with: 4.0 - """ - - def test_bad_arg_default(msg): from pybind11_tests import debug_enabled @@ -356,8 +353,8 @@ def test_bad_arg_default(msg): assert msg(excinfo.value) == ( "arg(): could not convert default argument 'a: UnregisteredType' in function " "'should_fail' into a Python object (type not registered yet?)" - if debug_enabled else - "arg(): could not convert default argument into a Python object (type not registered " + if debug_enabled + else "arg(): could not convert default argument into a Python object (type not registered " "yet?). Compile in debug mode for more information." ) @@ -366,8 +363,8 @@ def test_bad_arg_default(msg): assert msg(excinfo.value) == ( "arg(): could not convert default argument 'UnregisteredType' in function " "'should_fail' into a Python object (type not registered yet?)" - if debug_enabled else - "arg(): could not convert default argument into a Python object (type not registered " + if debug_enabled + else "arg(): could not convert default argument into a Python object (type not registered " "yet?). Compile in debug mode for more information." ) @@ -404,12 +401,15 @@ def test_accepts_none(msg): # The first one still raises because you can't pass None as a lvalue reference arg: with pytest.raises(TypeError) as excinfo: assert m.ok_none1(None) == -1 - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ ok_none1(): incompatible function arguments. The following argument types are supported: 1. (arg0: m.methods_and_attributes.NoneTester) -> int Invoked with: None """ + ) # The rest take the argument as pointer or holder, and accept None: assert m.ok_none2(None) == -1 @@ -417,6 +417,19 @@ def test_accepts_none(msg): assert m.ok_none4(None) == -1 assert m.ok_none5(None) == -1 + with pytest.raises(TypeError) as excinfo: + m.no_none_kwarg(None) + assert "incompatible function arguments" in str(excinfo.value) + with pytest.raises(TypeError) as excinfo: + m.no_none_kwarg(a=None) + assert "incompatible function arguments" in str(excinfo.value) + with pytest.raises(TypeError) as excinfo: + m.no_none_kwarg_kw_only(None) + assert "incompatible function arguments" in str(excinfo.value) + with pytest.raises(TypeError) as excinfo: + m.no_none_kwarg_kw_only(a=None) + assert "incompatible function arguments" in str(excinfo.value) + def test_str_issue(msg): """#283: __str__ called on uninitialized instance when constructor arguments invalid""" @@ -425,13 +438,16 @@ def test_str_issue(msg): with pytest.raises(TypeError) as excinfo: str(m.StrIssue("no", "such", "constructor")) - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ __init__(): incompatible constructor arguments. The following argument types are supported: 1. m.methods_and_attributes.StrIssue(arg0: int) 2. m.methods_and_attributes.StrIssue() Invoked with: 'no', 'such', 'constructor' """ + ) def test_unregistered_base_implementations(): @@ -452,25 +468,40 @@ def test_unregistered_base_implementations(): assert a.ro_value_prop == 1.75 -def test_custom_caster_destruction(): - """Tests that returning a pointer to a type that gets converted with a custom type caster gets - destroyed when the function has py::return_value_policy::take_ownership policy applied.""" +def test_ref_qualified(): + """Tests that explicit lvalue ref-qualified methods can be called just like their + non ref-qualified counterparts.""" - cstats = m.destruction_tester_cstats() - # This one *doesn't* have take_ownership: the pointer should be used but not destroyed: - z = m.custom_caster_no_destroy() - assert cstats.alive() == 1 and cstats.default_constructions == 1 - assert z + r = m.RefQualified() + assert r.value == 0 + r.refQualified(17) + assert r.value == 17 + assert r.constRefQualified(23) == 40 - # take_ownership applied: this constructs a new object, casts it, then destroys it: - z = m.custom_caster_destroy() - assert z - assert cstats.default_constructions == 2 - # Same, but with a const pointer return (which should *not* inhibit destruction): - z = m.custom_caster_destroy_const() - assert z - assert cstats.default_constructions == 3 +def test_overload_ordering(): + "Check to see if the normal overload order (first defined) and prepend overload order works" + assert m.overload_order("string") == 1 + assert m.overload_order(0) == 4 - # Make sure we still only have the original object (from ..._no_destroy()) alive: - assert cstats.alive() == 1 + # Different for Python 2 vs. 3 + uni_name = type(u"").__name__ + + assert "1. overload_order(arg0: int) -> int" in m.overload_order.__doc__ + assert ( + "2. overload_order(arg0: {}) -> int".format(uni_name) + in m.overload_order.__doc__ + ) + assert ( + "3. overload_order(arg0: {}) -> int".format(uni_name) + in m.overload_order.__doc__ + ) + assert "4. overload_order(arg0: int) -> int" in m.overload_order.__doc__ + + with pytest.raises(TypeError) as err: + m.overload_order(1.1) + + assert "1. (arg0: int) -> int" in str(err.value) + assert "2. (arg0: {}) -> int".format(uni_name) in str(err.value) + assert "3. (arg0: {}) -> int".format(uni_name) in str(err.value) + assert "4. (arg0: int) -> int" in str(err.value) diff --git a/plugins/python/pybind11/tests/test_modules.cpp b/plugins/python/pybind11/tests/test_modules.cpp index c1475fa..67387e8 100644 --- a/plugins/python/pybind11/tests/test_modules.cpp +++ b/plugins/python/pybind11/tests/test_modules.cpp @@ -13,6 +13,7 @@ TEST_SUBMODULE(modules, m) { // test_nested_modules + // This is intentionally "py::module" to verify it still can be used in place of "py::module_" py::module m_sub = m.def_submodule("subsubmodule"); m_sub.def("submodule_func", []() { return "submodule_func()"; }); @@ -50,6 +51,7 @@ TEST_SUBMODULE(modules, m) { .def_readwrite("a1", &B::a1) // def_readonly uses an internal reference return policy by default .def_readwrite("a2", &B::a2); + // This is intentionally "py::module" to verify it still can be used in place of "py::module_" m.attr("OD") = py::module::import("collections").attr("OrderedDict"); // test_duplicate_registration @@ -60,7 +62,8 @@ TEST_SUBMODULE(modules, m) { class Dupe3 { }; class DupeException { }; - auto dm = py::module("dummy"); + // Go ahead and leak, until we have a non-leaking py::module_ constructor + auto dm = py::module_::create_extension_module("dummy", nullptr, new py::module_::module_def); auto failures = py::list(); py::class_(dm, "Dupe1"); diff --git a/plugins/python/pybind11/tests/test_modules.py b/plugins/python/pybind11/tests/test_modules.py index 2552838..5630ccf 100644 --- a/plugins/python/pybind11/tests/test_modules.py +++ b/plugins/python/pybind11/tests/test_modules.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- from pybind11_tests import modules as m from pybind11_tests.modules import subsubmodule as ms from pybind11_tests import ConstructorStats @@ -5,9 +6,13 @@ def test_nested_modules(): import pybind11_tests + assert pybind11_tests.__name__ == "pybind11_tests" assert pybind11_tests.modules.__name__ == "pybind11_tests.modules" - assert pybind11_tests.modules.subsubmodule.__name__ == "pybind11_tests.modules.subsubmodule" + assert ( + pybind11_tests.modules.subsubmodule.__name__ + == "pybind11_tests.modules.subsubmodule" + ) assert m.__name__ == "pybind11_tests.modules" assert ms.__name__ == "pybind11_tests.modules.subsubmodule" @@ -34,7 +39,7 @@ def test_reference_internal(): del b assert astats.alive() == 0 assert bstats.alive() == 0 - assert astats.values() == ['1', '2', '42', '43'] + assert astats.values() == ["1", "2", "42", "43"] assert bstats.values() == [] assert astats.default_constructions == 0 assert bstats.default_constructions == 1 @@ -53,7 +58,7 @@ def test_importing(): from collections import OrderedDict assert OD is OrderedDict - assert str(OD([(1, 'a'), (2, 'b')])) == "OrderedDict([(1, 'a'), (2, 'b')])" + assert str(OD([(1, "a"), (2, "b")])) == "OrderedDict([(1, 'a'), (2, 'b')])" def test_pydoc(): diff --git a/plugins/python/pybind11/tests/test_multiple_inheritance.cpp b/plugins/python/pybind11/tests/test_multiple_inheritance.cpp index 35f9d9c..e672008 100644 --- a/plugins/python/pybind11/tests/test_multiple_inheritance.cpp +++ b/plugins/python/pybind11/tests/test_multiple_inheritance.cpp @@ -130,8 +130,8 @@ TEST_SUBMODULE(multiple_inheritance, m) { // test_mi_unaligned_base // test_mi_base_return // Issue #801: invalid casting to derived type with MI bases - struct I801B1 { int a = 1; virtual ~I801B1() = default; }; - struct I801B2 { int b = 2; virtual ~I801B2() = default; }; + struct I801B1 { int a = 1; I801B1() = default; I801B1(const I801B1 &) = default; virtual ~I801B1() = default; }; + struct I801B2 { int b = 2; I801B2() = default; I801B2(const I801B2 &) = default; virtual ~I801B2() = default; }; struct I801C : I801B1, I801B2 {}; struct I801D : I801C {}; // Indirect MI // Unregistered classes: @@ -193,19 +193,17 @@ TEST_SUBMODULE(multiple_inheritance, m) { .def_readwrite_static("static_value", &VanillaStaticMix2::static_value); -#if !defined(PYPY_VERSION) struct WithDict { }; struct VanillaDictMix1 : Vanilla, WithDict { }; struct VanillaDictMix2 : WithDict, Vanilla { }; py::class_(m, "WithDict", py::dynamic_attr()).def(py::init<>()); py::class_(m, "VanillaDictMix1").def(py::init<>()); py::class_(m, "VanillaDictMix2").def(py::init<>()); -#endif // test_diamond_inheritance // Issue #959: segfault when constructing diamond inheritance instance // All of these have int members so that there will be various unequal pointers involved. - struct B { int b; virtual ~B() = default; }; + struct B { int b; B() = default; B(const B&) = default; virtual ~B() = default; }; struct C0 : public virtual B { int c0; }; struct C1 : public virtual B { int c1; }; struct D : public C0, public C1 { int d; }; diff --git a/plugins/python/pybind11/tests/test_multiple_inheritance.py b/plugins/python/pybind11/tests/test_multiple_inheritance.py index 475dd3b..e6a7f97 100644 --- a/plugins/python/pybind11/tests/test_multiple_inheritance.py +++ b/plugins/python/pybind11/tests/test_multiple_inheritance.py @@ -1,4 +1,8 @@ +# -*- coding: utf-8 -*- import pytest + +import env # noqa: F401 + from pybind11_tests import ConstructorStats from pybind11_tests import multiple_inheritance as m @@ -10,6 +14,8 @@ def test_multiple_inheritance_cpp(): assert mt.bar() == 4 +@pytest.mark.skipif("env.PYPY and env.PY2") +@pytest.mark.xfail("env.PYPY and not env.PY2") def test_multiple_inheritance_mix1(): class Base1: def __init__(self, i): @@ -30,7 +36,6 @@ def __init__(self, i, j): def test_multiple_inheritance_mix2(): - class Base2: def __init__(self, i): self.i = i @@ -49,8 +54,9 @@ def __init__(self, i, j): assert mt.bar() == 4 +@pytest.mark.skipif("env.PYPY and env.PY2") +@pytest.mark.xfail("env.PYPY and not env.PY2") def test_multiple_inheritance_python(): - class MI1(m.Base1, m.Base2): def __init__(self, i, j): m.Base1.__init__(self, i) @@ -156,7 +162,6 @@ def __init__(self, i): def test_multiple_inheritance_python_many_bases(): - class MIMany14(m.BaseN1, m.BaseN2, m.BaseN3, m.BaseN4): def __init__(self): m.BaseN1.__init__(self, 1) @@ -171,8 +176,16 @@ def __init__(self): m.BaseN7.__init__(self, 7) m.BaseN8.__init__(self, 8) - class MIMany916(m.BaseN9, m.BaseN10, m.BaseN11, m.BaseN12, m.BaseN13, m.BaseN14, m.BaseN15, - m.BaseN16): + class MIMany916( + m.BaseN9, + m.BaseN10, + m.BaseN11, + m.BaseN12, + m.BaseN13, + m.BaseN14, + m.BaseN15, + m.BaseN16, + ): def __init__(self): m.BaseN9.__init__(self, 9) m.BaseN10.__init__(self, 10) @@ -218,7 +231,6 @@ def __init__(self): def test_multiple_inheritance_virtbase(): - class MITypePy(m.Base12a): def __init__(self, i, j): m.Base12a.__init__(self, i, j) @@ -231,7 +243,7 @@ def __init__(self, i, j): def test_mi_static_properties(): """Mixing bases with and without static properties should be possible - and the result should be independent of base definition order""" + and the result should be independent of base definition order""" for d in (m.VanillaStaticMix1(), m.VanillaStaticMix2()): assert d.vanilla() == "Vanilla" @@ -253,7 +265,7 @@ def test_mi_static_properties(): assert d.static_value == 0 -@pytest.unsupported_on_pypy +# Requires PyPy 6+ def test_mi_dynamic_attributes(): """Mixing bases with and without dynamic attribute support""" diff --git a/plugins/python/pybind11/tests/test_numpy_array.cpp b/plugins/python/pybind11/tests/test_numpy_array.cpp index 79a157e..a84de77 100644 --- a/plugins/python/pybind11/tests/test_numpy_array.cpp +++ b/plugins/python/pybind11/tests/test_numpy_array.cpp @@ -14,6 +14,67 @@ #include +// Size / dtype checks. +struct DtypeCheck { + py::dtype numpy{}; + py::dtype pybind11{}; +}; + +template +DtypeCheck get_dtype_check(const char* name) { + py::module_ np = py::module_::import("numpy"); + DtypeCheck check{}; + check.numpy = np.attr("dtype")(np.attr(name)); + check.pybind11 = py::dtype::of(); + return check; +} + +std::vector get_concrete_dtype_checks() { + return { + // Normalization + get_dtype_check("int8"), + get_dtype_check("uint8"), + get_dtype_check("int16"), + get_dtype_check("uint16"), + get_dtype_check("int32"), + get_dtype_check("uint32"), + get_dtype_check("int64"), + get_dtype_check("uint64") + }; +} + +struct DtypeSizeCheck { + std::string name{}; + int size_cpp{}; + int size_numpy{}; + // For debugging. + py::dtype dtype{}; +}; + +template +DtypeSizeCheck get_dtype_size_check() { + DtypeSizeCheck check{}; + check.name = py::type_id(); + check.size_cpp = sizeof(T); + check.dtype = py::dtype::of(); + check.size_numpy = check.dtype.attr("itemsize").template cast(); + return check; +} + +std::vector get_platform_dtype_size_checks() { + return { + get_dtype_size_check(), + get_dtype_size_check(), + get_dtype_size_check(), + get_dtype_size_check(), + get_dtype_size_check(), + get_dtype_size_check(), + get_dtype_size_check(), + get_dtype_size_check(), + }; +} + +// Arrays. using arr = py::array; using arr_t = py::array_t; static_assert(std::is_same::value, ""); @@ -28,23 +89,23 @@ template arr data_t(const arr_t& a, Ix... index) { template arr& mutate_data(arr& a, Ix... index) { auto ptr = (uint8_t *) a.mutable_data(index...); - for (ssize_t i = 0; i < a.nbytes() - a.offset_at(index...); i++) + for (py::ssize_t i = 0; i < a.nbytes() - a.offset_at(index...); i++) ptr[i] = (uint8_t) (ptr[i] * 2); return a; } template arr_t& mutate_data_t(arr_t& a, Ix... index) { auto ptr = a.mutable_data(index...); - for (ssize_t i = 0; i < a.size() - a.index_at(index...); i++) + for (py::ssize_t i = 0; i < a.size() - a.index_at(index...); i++) ptr[i]++; return a; } -template ssize_t index_at(const arr& a, Ix... idx) { return a.index_at(idx...); } -template ssize_t index_at_t(const arr_t& a, Ix... idx) { return a.index_at(idx...); } -template ssize_t offset_at(const arr& a, Ix... idx) { return a.offset_at(idx...); } -template ssize_t offset_at_t(const arr_t& a, Ix... idx) { return a.offset_at(idx...); } -template ssize_t at_t(const arr_t& a, Ix... idx) { return a.at(idx...); } +template py::ssize_t index_at(const arr& a, Ix... idx) { return a.index_at(idx...); } +template py::ssize_t index_at_t(const arr_t& a, Ix... idx) { return a.index_at(idx...); } +template py::ssize_t offset_at(const arr& a, Ix... idx) { return a.offset_at(idx...); } +template py::ssize_t offset_at_t(const arr_t& a, Ix... idx) { return a.offset_at(idx...); } +template py::ssize_t at_t(const arr_t& a, Ix... idx) { return a.at(idx...); } template arr_t& mutate_at_t(arr_t& a, Ix... idx) { a.mutable_at(idx...)++; return a; } #define def_index_fn(name, type) \ @@ -68,16 +129,39 @@ template py::handle auxiliaries(T &&r, T2 &&r2) { return l.release(); } +// note: declaration at local scope would create a dangling reference! +static int data_i = 42; + TEST_SUBMODULE(numpy_array, sm) { - try { py::module::import("numpy"); } + try { py::module_::import("numpy"); } catch (...) { return; } + // test_dtypes + py::class_(sm, "DtypeCheck") + .def_readonly("numpy", &DtypeCheck::numpy) + .def_readonly("pybind11", &DtypeCheck::pybind11) + .def("__repr__", [](const DtypeCheck& self) { + return py::str("").format( + self.numpy, self.pybind11); + }); + sm.def("get_concrete_dtype_checks", &get_concrete_dtype_checks); + + py::class_(sm, "DtypeSizeCheck") + .def_readonly("name", &DtypeSizeCheck::name) + .def_readonly("size_cpp", &DtypeSizeCheck::size_cpp) + .def_readonly("size_numpy", &DtypeSizeCheck::size_numpy) + .def("__repr__", [](const DtypeSizeCheck& self) { + return py::str("").format( + self.name, self.size_cpp, self.size_numpy, self.dtype); + }); + sm.def("get_platform_dtype_size_checks", &get_platform_dtype_size_checks); + // test_array_attributes sm.def("ndim", [](const arr& a) { return a.ndim(); }); sm.def("shape", [](const arr& a) { return arr(a.ndim(), a.shape()); }); - sm.def("shape", [](const arr& a, ssize_t dim) { return a.shape(dim); }); + sm.def("shape", [](const arr& a, py::ssize_t dim) { return a.shape(dim); }); sm.def("strides", [](const arr& a) { return arr(a.ndim(), a.strides()); }); - sm.def("strides", [](const arr& a, ssize_t dim) { return a.strides(dim); }); + sm.def("strides", [](const arr& a, py::ssize_t dim) { return a.strides(dim); }); sm.def("writeable", [](const arr& a) { return a.writeable(); }); sm.def("size", [](const arr& a) { return a.size(); }); sm.def("itemsize", [](const arr& a) { return a.itemsize(); }); @@ -104,6 +188,8 @@ TEST_SUBMODULE(numpy_array, sm) { // test_empty_shaped_array sm.def("make_empty_shaped_array", [] { return py::array(py::dtype("f"), {}, {}); }); + // test numpy scalars (empty shape, ndim==0) + sm.def("scalar_int", []() { return py::array(py::dtype("i"), {}, {}, &data_i); }); // test_wrap sm.def("wrap", [](py::array a) { @@ -126,7 +212,7 @@ TEST_SUBMODULE(numpy_array, sm) { .def(py::init<>()) .def("numpy_view", [](py::object &obj) { py::print("ArrayClass::numpy_view()"); - ArrayClass &a = obj.cast(); + auto &a = obj.cast(); return py::array_t({2}, {4}, a.data, obj); } ); @@ -195,33 +281,33 @@ TEST_SUBMODULE(numpy_array, sm) { // test_array_unchecked_fixed_dims sm.def("proxy_add2", [](py::array_t a, double v) { auto r = a.mutable_unchecked<2>(); - for (ssize_t i = 0; i < r.shape(0); i++) - for (ssize_t j = 0; j < r.shape(1); j++) + for (py::ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t j = 0; j < r.shape(1); j++) r(i, j) += v; }, py::arg().noconvert(), py::arg()); sm.def("proxy_init3", [](double start) { py::array_t a({ 3, 3, 3 }); auto r = a.mutable_unchecked<3>(); - for (ssize_t i = 0; i < r.shape(0); i++) - for (ssize_t j = 0; j < r.shape(1); j++) - for (ssize_t k = 0; k < r.shape(2); k++) + for (py::ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t j = 0; j < r.shape(1); j++) + for (py::ssize_t k = 0; k < r.shape(2); k++) r(i, j, k) = start++; return a; }); sm.def("proxy_init3F", [](double start) { py::array_t a({ 3, 3, 3 }); auto r = a.mutable_unchecked<3>(); - for (ssize_t k = 0; k < r.shape(2); k++) - for (ssize_t j = 0; j < r.shape(1); j++) - for (ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t k = 0; k < r.shape(2); k++) + for (py::ssize_t j = 0; j < r.shape(1); j++) + for (py::ssize_t i = 0; i < r.shape(0); i++) r(i, j, k) = start++; return a; }); sm.def("proxy_squared_L2_norm", [](py::array_t a) { auto r = a.unchecked<1>(); double sumsq = 0; - for (ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t i = 0; i < r.shape(0); i++) sumsq += r[i] * r(i); // Either notation works for a 1D array return sumsq; }); @@ -232,22 +318,34 @@ TEST_SUBMODULE(numpy_array, sm) { return auxiliaries(r, r2); }); + sm.def("proxy_auxiliaries1_const_ref", [](py::array_t a) { + const auto &r = a.unchecked<1>(); + const auto &r2 = a.mutable_unchecked<1>(); + return r(0) == r2(0) && r[0] == r2[0]; + }); + + sm.def("proxy_auxiliaries2_const_ref", [](py::array_t a) { + const auto &r = a.unchecked<2>(); + const auto &r2 = a.mutable_unchecked<2>(); + return r(0, 0) == r2(0, 0); + }); + // test_array_unchecked_dyn_dims // Same as the above, but without a compile-time dimensions specification: sm.def("proxy_add2_dyn", [](py::array_t a, double v) { auto r = a.mutable_unchecked(); if (r.ndim() != 2) throw std::domain_error("error: ndim != 2"); - for (ssize_t i = 0; i < r.shape(0); i++) - for (ssize_t j = 0; j < r.shape(1); j++) + for (py::ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t j = 0; j < r.shape(1); j++) r(i, j) += v; }, py::arg().noconvert(), py::arg()); sm.def("proxy_init3_dyn", [](double start) { py::array_t a({ 3, 3, 3 }); auto r = a.mutable_unchecked(); if (r.ndim() != 3) throw std::domain_error("error: ndim != 3"); - for (ssize_t i = 0; i < r.shape(0); i++) - for (ssize_t j = 0; j < r.shape(1); j++) - for (ssize_t k = 0; k < r.shape(2); k++) + for (py::ssize_t i = 0; i < r.shape(0); i++) + for (py::ssize_t j = 0; j < r.shape(1); j++) + for (py::ssize_t k = 0; k < r.shape(2); k++) r(i, j, k) = start++; return a; }); @@ -276,7 +374,7 @@ TEST_SUBMODULE(numpy_array, sm) { // test_array_resize // reshape array to 2D without changing size sm.def("array_reshape2", [](py::array_t a) { - const ssize_t dim_sz = (ssize_t)std::sqrt(a.size()); + const auto dim_sz = (py::ssize_t)std::sqrt(a.size()); if (dim_sz * dim_sz != a.size()) throw std::domain_error("array_reshape2: input array total size is not a squared integer"); a.resize({dim_sz, dim_sz}); @@ -295,4 +393,46 @@ TEST_SUBMODULE(numpy_array, sm) { std::fill(a.mutable_data(), a.mutable_data() + a.size(), 42.); return a; }); + + sm.def("index_using_ellipsis", [](py::array a) { + return a[py::make_tuple(0, py::ellipsis(), 0)]; + }); + + // test_argument_conversions + sm.def("accept_double", + [](py::array_t) {}, + py::arg("a")); + sm.def("accept_double_forcecast", + [](py::array_t) {}, + py::arg("a")); + sm.def("accept_double_c_style", + [](py::array_t) {}, + py::arg("a")); + sm.def("accept_double_c_style_forcecast", + [](py::array_t) {}, + py::arg("a")); + sm.def("accept_double_f_style", + [](py::array_t) {}, + py::arg("a")); + sm.def("accept_double_f_style_forcecast", + [](py::array_t) {}, + py::arg("a")); + sm.def("accept_double_noconvert", + [](py::array_t) {}, + py::arg("a").noconvert()); + sm.def("accept_double_forcecast_noconvert", + [](py::array_t) {}, + py::arg("a").noconvert()); + sm.def("accept_double_c_style_noconvert", + [](py::array_t) {}, + py::arg("a").noconvert()); + sm.def("accept_double_c_style_forcecast_noconvert", + [](py::array_t) {}, + py::arg("a").noconvert()); + sm.def("accept_double_f_style_noconvert", + [](py::array_t) {}, + py::arg("a").noconvert()); + sm.def("accept_double_f_style_forcecast_noconvert", + [](py::array_t) {}, + py::arg("a").noconvert()); } diff --git a/plugins/python/pybind11/tests/test_numpy_array.py b/plugins/python/pybind11/tests/test_numpy_array.py index 1e83135..02f3ecf 100644 --- a/plugins/python/pybind11/tests/test_numpy_array.py +++ b/plugins/python/pybind11/tests/test_numpy_array.py @@ -1,35 +1,54 @@ +# -*- coding: utf-8 -*- import pytest + +import env # noqa: F401 + from pybind11_tests import numpy_array as m -pytestmark = pytest.requires_numpy +np = pytest.importorskip("numpy") + -with pytest.suppress(ImportError): - import numpy as np +def test_dtypes(): + # See issue #1328. + # - Platform-dependent sizes. + for size_check in m.get_platform_dtype_size_checks(): + print(size_check) + assert size_check.size_cpp == size_check.size_numpy, size_check + # - Concrete sizes. + for check in m.get_concrete_dtype_checks(): + print(check) + assert check.numpy == check.pybind11, check + if check.numpy.num != check.pybind11.num: + print( + "NOTE: typenum mismatch for {}: {} != {}".format( + check, check.numpy.num, check.pybind11.num + ) + ) -@pytest.fixture(scope='function') +@pytest.fixture(scope="function") def arr(): - return np.array([[1, 2, 3], [4, 5, 6]], '=u2') + return np.array([[1, 2, 3], [4, 5, 6]], "=u2") def test_array_attributes(): - a = np.array(0, 'f8') + a = np.array(0, "f8") assert m.ndim(a) == 0 assert all(m.shape(a) == []) assert all(m.strides(a) == []) with pytest.raises(IndexError) as excinfo: m.shape(a, 0) - assert str(excinfo.value) == 'invalid axis: 0 (ndim = 0)' + assert str(excinfo.value) == "invalid axis: 0 (ndim = 0)" with pytest.raises(IndexError) as excinfo: m.strides(a, 0) - assert str(excinfo.value) == 'invalid axis: 0 (ndim = 0)' + assert str(excinfo.value) == "invalid axis: 0 (ndim = 0)" assert m.writeable(a) assert m.size(a) == 1 assert m.itemsize(a) == 8 assert m.nbytes(a) == 8 assert m.owndata(a) - a = np.array([[1, 2, 3], [4, 5, 6]], 'u2').view() + a = np.array([[1, 2, 3], [4, 5, 6]], "u2").view() a.flags.writeable = False assert m.ndim(a) == 2 assert all(m.shape(a) == [2, 3]) @@ -40,10 +59,10 @@ def test_array_attributes(): assert m.strides(a, 1) == 2 with pytest.raises(IndexError) as excinfo: m.shape(a, 2) - assert str(excinfo.value) == 'invalid axis: 2 (ndim = 2)' + assert str(excinfo.value) == "invalid axis: 2 (ndim = 2)" with pytest.raises(IndexError) as excinfo: m.strides(a, 2) - assert str(excinfo.value) == 'invalid axis: 2 (ndim = 2)' + assert str(excinfo.value) == "invalid axis: 2 (ndim = 2)" assert not m.writeable(a) assert m.size(a) == 6 assert m.itemsize(a) == 2 @@ -51,7 +70,9 @@ def test_array_attributes(): assert not m.owndata(a) -@pytest.mark.parametrize('args, ret', [([], 0), ([0], 0), ([1], 3), ([0, 1], 1), ([1, 2], 5)]) +@pytest.mark.parametrize( + "args, ret", [([], 0), ([0], 0), ([1], 3), ([0, 1], 1), ([1, 2], 5)] +) def test_index_offset(arr, args, ret): assert m.index_at(arr, *args) == ret assert m.index_at_t(arr, *args) == ret @@ -60,31 +81,46 @@ def test_index_offset(arr, args, ret): def test_dim_check_fail(arr): - for func in (m.index_at, m.index_at_t, m.offset_at, m.offset_at_t, m.data, m.data_t, - m.mutate_data, m.mutate_data_t): + for func in ( + m.index_at, + m.index_at_t, + m.offset_at, + m.offset_at_t, + m.data, + m.data_t, + m.mutate_data, + m.mutate_data_t, + ): with pytest.raises(IndexError) as excinfo: func(arr, 1, 2, 3) - assert str(excinfo.value) == 'too many indices for an array: 3 (ndim = 2)' - - -@pytest.mark.parametrize('args, ret', - [([], [1, 2, 3, 4, 5, 6]), - ([1], [4, 5, 6]), - ([0, 1], [2, 3, 4, 5, 6]), - ([1, 2], [6])]) + assert str(excinfo.value) == "too many indices for an array: 3 (ndim = 2)" + + +@pytest.mark.parametrize( + "args, ret", + [ + ([], [1, 2, 3, 4, 5, 6]), + ([1], [4, 5, 6]), + ([0, 1], [2, 3, 4, 5, 6]), + ([1, 2], [6]), + ], +) def test_data(arr, args, ret): from sys import byteorder + assert all(m.data_t(arr, *args) == ret) - assert all(m.data(arr, *args)[(0 if byteorder == 'little' else 1)::2] == ret) - assert all(m.data(arr, *args)[(1 if byteorder == 'little' else 0)::2] == 0) + assert all(m.data(arr, *args)[(0 if byteorder == "little" else 1) :: 2] == ret) + assert all(m.data(arr, *args)[(1 if byteorder == "little" else 0) :: 2] == 0) -@pytest.mark.parametrize('dim', [0, 1, 3]) +@pytest.mark.parametrize("dim", [0, 1, 3]) def test_at_fail(arr, dim): for func in m.at_t, m.mutate_at_t: with pytest.raises(IndexError) as excinfo: func(arr, *([0] * dim)) - assert str(excinfo.value) == 'index dimension mismatch: {} (ndim = 2)'.format(dim) + assert str(excinfo.value) == "index dimension mismatch: {} (ndim = 2)".format( + dim + ) def test_at(arr): @@ -97,10 +133,14 @@ def test_at(arr): def test_mutate_readonly(arr): arr.flags.writeable = False - for func, args in (m.mutate_data, ()), (m.mutate_data_t, ()), (m.mutate_at_t, (0, 0)): + for func, args in ( + (m.mutate_data, ()), + (m.mutate_data_t, ()), + (m.mutate_at_t, (0, 0)), + ): with pytest.raises(ValueError) as excinfo: func(arr, *args) - assert str(excinfo.value) == 'array is not writeable' + assert str(excinfo.value) == "array is not writeable" def test_mutate_data(arr): @@ -118,14 +158,22 @@ def test_mutate_data(arr): def test_bounds_check(arr): - for func in (m.index_at, m.index_at_t, m.data, m.data_t, - m.mutate_data, m.mutate_data_t, m.at_t, m.mutate_at_t): + for func in ( + m.index_at, + m.index_at_t, + m.data, + m.data_t, + m.mutate_data, + m.mutate_data_t, + m.at_t, + m.mutate_at_t, + ): with pytest.raises(IndexError) as excinfo: func(arr, 2, 0) - assert str(excinfo.value) == 'index 2 is out of bounds for axis 0 with size 2' + assert str(excinfo.value) == "index 2 is out of bounds for axis 0 with size 2" with pytest.raises(IndexError) as excinfo: func(arr, 0, 4) - assert str(excinfo.value) == 'index 4 is out of bounds for axis 1 with size 3' + assert str(excinfo.value) == "index 4 is out of bounds for axis 1 with size 3" def test_make_c_f_array(): @@ -138,14 +186,20 @@ def test_make_c_f_array(): def test_make_empty_shaped_array(): m.make_empty_shaped_array() + # empty shape means numpy scalar, PEP 3118 + assert m.scalar_int().ndim == 0 + assert m.scalar_int().shape == () + assert m.scalar_int() == 42 + def test_wrap(): def assert_references(a, b, base=None): from distutils.version import LooseVersion + if base is None: base = a assert a is not b - assert a.__array_interface__['data'][0] == b.__array_interface__['data'][0] + assert a.__array_interface__["data"][0] == b.__array_interface__["data"][0] assert a.shape == b.shape assert a.strides == b.strides assert a.flags.c_contiguous == b.flags.c_contiguous @@ -168,12 +222,12 @@ def assert_references(a, b, base=None): a2 = m.wrap(a1) assert_references(a1, a2) - a1 = np.array([[1, 2], [3, 4]], dtype=np.float32, order='F') + a1 = np.array([[1, 2], [3, 4]], dtype=np.float32, order="F") assert a1.flags.owndata and a1.base is None a2 = m.wrap(a1) assert_references(a1, a2) - a1 = np.array([[1, 2], [3, 4]], dtype=np.float32, order='C') + a1 = np.array([[1, 2], [3, 4]], dtype=np.float32, order="C") a1.flags.writeable = False a2 = m.wrap(a1) assert_references(a1, a2) @@ -203,11 +257,14 @@ def test_numpy_view(capture): assert np.all(ac_view_1 == np.array([1, 2], dtype=np.int32)) del ac pytest.gc_collect() - assert capture == """ + assert ( + capture + == """ ArrayClass() ArrayClass::numpy_view() ArrayClass::numpy_view() """ + ) ac_view_1[0] = 4 ac_view_1[1] = 3 assert ac_view_2[0] == 4 @@ -217,12 +274,14 @@ def test_numpy_view(capture): del ac_view_2 pytest.gc_collect() pytest.gc_collect() - assert capture == """ + assert ( + capture + == """ ~ArrayClass() """ + ) -@pytest.unsupported_on_pypy def test_cast_numpy_int64_to_uint64(): m.function_taking_uint64(123) m.function_taking_uint64(np.uint64(123)) @@ -251,89 +310,94 @@ def test_constructors(): def test_overload_resolution(msg): # Exact overload matches: - assert m.overloaded(np.array([1], dtype='float64')) == 'double' - assert m.overloaded(np.array([1], dtype='float32')) == 'float' - assert m.overloaded(np.array([1], dtype='ushort')) == 'unsigned short' - assert m.overloaded(np.array([1], dtype='intc')) == 'int' - assert m.overloaded(np.array([1], dtype='longlong')) == 'long long' - assert m.overloaded(np.array([1], dtype='complex')) == 'double complex' - assert m.overloaded(np.array([1], dtype='csingle')) == 'float complex' + assert m.overloaded(np.array([1], dtype="float64")) == "double" + assert m.overloaded(np.array([1], dtype="float32")) == "float" + assert m.overloaded(np.array([1], dtype="ushort")) == "unsigned short" + assert m.overloaded(np.array([1], dtype="intc")) == "int" + assert m.overloaded(np.array([1], dtype="longlong")) == "long long" + assert m.overloaded(np.array([1], dtype="complex")) == "double complex" + assert m.overloaded(np.array([1], dtype="csingle")) == "float complex" # No exact match, should call first convertible version: - assert m.overloaded(np.array([1], dtype='uint8')) == 'double' + assert m.overloaded(np.array([1], dtype="uint8")) == "double" with pytest.raises(TypeError) as excinfo: m.overloaded("not an array") - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ overloaded(): incompatible function arguments. The following argument types are supported: - 1. (arg0: numpy.ndarray[float64]) -> str - 2. (arg0: numpy.ndarray[float32]) -> str - 3. (arg0: numpy.ndarray[int32]) -> str - 4. (arg0: numpy.ndarray[uint16]) -> str - 5. (arg0: numpy.ndarray[int64]) -> str - 6. (arg0: numpy.ndarray[complex128]) -> str - 7. (arg0: numpy.ndarray[complex64]) -> str + 1. (arg0: numpy.ndarray[numpy.float64]) -> str + 2. (arg0: numpy.ndarray[numpy.float32]) -> str + 3. (arg0: numpy.ndarray[numpy.int32]) -> str + 4. (arg0: numpy.ndarray[numpy.uint16]) -> str + 5. (arg0: numpy.ndarray[numpy.int64]) -> str + 6. (arg0: numpy.ndarray[numpy.complex128]) -> str + 7. (arg0: numpy.ndarray[numpy.complex64]) -> str Invoked with: 'not an array' """ + ) - assert m.overloaded2(np.array([1], dtype='float64')) == 'double' - assert m.overloaded2(np.array([1], dtype='float32')) == 'float' - assert m.overloaded2(np.array([1], dtype='complex64')) == 'float complex' - assert m.overloaded2(np.array([1], dtype='complex128')) == 'double complex' - assert m.overloaded2(np.array([1], dtype='float32')) == 'float' + assert m.overloaded2(np.array([1], dtype="float64")) == "double" + assert m.overloaded2(np.array([1], dtype="float32")) == "float" + assert m.overloaded2(np.array([1], dtype="complex64")) == "float complex" + assert m.overloaded2(np.array([1], dtype="complex128")) == "double complex" + assert m.overloaded2(np.array([1], dtype="float32")) == "float" - assert m.overloaded3(np.array([1], dtype='float64')) == 'double' - assert m.overloaded3(np.array([1], dtype='intc')) == 'int' + assert m.overloaded3(np.array([1], dtype="float64")) == "double" + assert m.overloaded3(np.array([1], dtype="intc")) == "int" expected_exc = """ overloaded3(): incompatible function arguments. The following argument types are supported: - 1. (arg0: numpy.ndarray[int32]) -> str - 2. (arg0: numpy.ndarray[float64]) -> str + 1. (arg0: numpy.ndarray[numpy.int32]) -> str + 2. (arg0: numpy.ndarray[numpy.float64]) -> str Invoked with: """ with pytest.raises(TypeError) as excinfo: - m.overloaded3(np.array([1], dtype='uintc')) - assert msg(excinfo.value) == expected_exc + repr(np.array([1], dtype='uint32')) + m.overloaded3(np.array([1], dtype="uintc")) + assert msg(excinfo.value) == expected_exc + repr(np.array([1], dtype="uint32")) with pytest.raises(TypeError) as excinfo: - m.overloaded3(np.array([1], dtype='float32')) - assert msg(excinfo.value) == expected_exc + repr(np.array([1.], dtype='float32')) + m.overloaded3(np.array([1], dtype="float32")) + assert msg(excinfo.value) == expected_exc + repr(np.array([1.0], dtype="float32")) with pytest.raises(TypeError) as excinfo: - m.overloaded3(np.array([1], dtype='complex')) - assert msg(excinfo.value) == expected_exc + repr(np.array([1. + 0.j])) + m.overloaded3(np.array([1], dtype="complex")) + assert msg(excinfo.value) == expected_exc + repr(np.array([1.0 + 0.0j])) # Exact matches: - assert m.overloaded4(np.array([1], dtype='double')) == 'double' - assert m.overloaded4(np.array([1], dtype='longlong')) == 'long long' + assert m.overloaded4(np.array([1], dtype="double")) == "double" + assert m.overloaded4(np.array([1], dtype="longlong")) == "long long" # Non-exact matches requiring conversion. Since float to integer isn't a # save conversion, it should go to the double overload, but short can go to # either (and so should end up on the first-registered, the long long). - assert m.overloaded4(np.array([1], dtype='float32')) == 'double' - assert m.overloaded4(np.array([1], dtype='short')) == 'long long' + assert m.overloaded4(np.array([1], dtype="float32")) == "double" + assert m.overloaded4(np.array([1], dtype="short")) == "long long" - assert m.overloaded5(np.array([1], dtype='double')) == 'double' - assert m.overloaded5(np.array([1], dtype='uintc')) == 'unsigned int' - assert m.overloaded5(np.array([1], dtype='float32')) == 'unsigned int' + assert m.overloaded5(np.array([1], dtype="double")) == "double" + assert m.overloaded5(np.array([1], dtype="uintc")) == "unsigned int" + assert m.overloaded5(np.array([1], dtype="float32")) == "unsigned int" def test_greedy_string_overload(): """Tests fix for #685 - ndarray shouldn't go to std::string overload""" assert m.issue685("abc") == "string" - assert m.issue685(np.array([97, 98, 99], dtype='b')) == "array" + assert m.issue685(np.array([97, 98, 99], dtype="b")) == "array" assert m.issue685(123) == "other" def test_array_unchecked_fixed_dims(msg): - z1 = np.array([[1, 2], [3, 4]], dtype='float64') + z1 = np.array([[1, 2], [3, 4]], dtype="float64") m.proxy_add2(z1, 10) assert np.all(z1 == [[11, 12], [13, 14]]) with pytest.raises(ValueError) as excinfo: - m.proxy_add2(np.array([1., 2, 3]), 5.0) - assert msg(excinfo.value) == "array has incorrect number of dimensions: 1; expected 2" + m.proxy_add2(np.array([1.0, 2, 3]), 5.0) + assert ( + msg(excinfo.value) == "array has incorrect number of dimensions: 1; expected 2" + ) - expect_c = np.ndarray(shape=(3, 3, 3), buffer=np.array(range(3, 30)), dtype='int') + expect_c = np.ndarray(shape=(3, 3, 3), buffer=np.array(range(3, 30)), dtype="int") assert np.all(m.proxy_init3(3.0) == expect_c) expect_f = np.transpose(expect_c) assert np.all(m.proxy_init3F(3.0) == expect_f) @@ -344,13 +408,16 @@ def test_array_unchecked_fixed_dims(msg): assert m.proxy_auxiliaries2(z1) == [11, 11, True, 2, 8, 2, 2, 4, 32] assert m.proxy_auxiliaries2(z1) == m.array_auxiliaries2(z1) + assert m.proxy_auxiliaries1_const_ref(z1[0, :]) + assert m.proxy_auxiliaries2_const_ref(z1) + def test_array_unchecked_dyn_dims(msg): - z1 = np.array([[1, 2], [3, 4]], dtype='float64') + z1 = np.array([[1, 2], [3, 4]], dtype="float64") m.proxy_add2_dyn(z1, 10) assert np.all(z1 == [[11, 12], [13, 14]]) - expect_c = np.ndarray(shape=(3, 3, 3), buffer=np.array(range(3, 30)), dtype='int') + expect_c = np.ndarray(shape=(3, 3, 3), buffer=np.array(range(3, 30)), dtype="int") assert np.all(m.proxy_init3_dyn(3.0) == expect_c) assert m.proxy_auxiliaries2_dyn(z1) == [11, 11, True, 2, 8, 2, 2, 4, 32] @@ -360,15 +427,15 @@ def test_array_unchecked_dyn_dims(msg): def test_array_failure(): with pytest.raises(ValueError) as excinfo: m.array_fail_test() - assert str(excinfo.value) == 'cannot create a pybind11::array from a nullptr' + assert str(excinfo.value) == "cannot create a pybind11::array from a nullptr" with pytest.raises(ValueError) as excinfo: m.array_t_fail_test() - assert str(excinfo.value) == 'cannot create a pybind11::array_t from a nullptr' + assert str(excinfo.value) == "cannot create a pybind11::array_t from a nullptr" with pytest.raises(ValueError) as excinfo: m.array_fail_test_negative_size() - assert str(excinfo.value) == 'negative dimensions are not allowed' + assert str(excinfo.value) == "negative dimensions are not allowed" def test_initializer_list(): @@ -379,32 +446,96 @@ def test_initializer_list(): def test_array_resize(msg): - a = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9], dtype='float64') + a = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9], dtype="float64") m.array_reshape2(a) - assert(a.size == 9) - assert(np.all(a == [[1, 2, 3], [4, 5, 6], [7, 8, 9]])) + assert a.size == 9 + assert np.all(a == [[1, 2, 3], [4, 5, 6], [7, 8, 9]]) # total size change should succced with refcheck off m.array_resize3(a, 4, False) - assert(a.size == 64) + assert a.size == 64 # ... and fail with refcheck on try: m.array_resize3(a, 3, True) except ValueError as e: - assert(str(e).startswith("cannot resize an array")) + assert str(e).startswith("cannot resize an array") # transposed array doesn't own data b = a.transpose() try: m.array_resize3(b, 3, False) except ValueError as e: - assert(str(e).startswith("cannot resize this array: it does not own its data")) + assert str(e).startswith("cannot resize this array: it does not own its data") # ... but reshape should be fine m.array_reshape2(b) - assert(b.shape == (8, 8)) + assert b.shape == (8, 8) -@pytest.unsupported_on_pypy +@pytest.mark.xfail("env.PYPY") def test_array_create_and_resize(msg): a = m.create_and_resize(2) - assert(a.size == 4) - assert(np.all(a == 42.)) + assert a.size == 4 + assert np.all(a == 42.0) + + +def test_index_using_ellipsis(): + a = m.index_using_ellipsis(np.zeros((5, 6, 7))) + assert a.shape == (6,) + + +@pytest.mark.parametrize("forcecast", [False, True]) +@pytest.mark.parametrize("contiguity", [None, "C", "F"]) +@pytest.mark.parametrize("noconvert", [False, True]) +@pytest.mark.filterwarnings( + "ignore:Casting complex values to real discards the imaginary part:numpy.ComplexWarning" +) +def test_argument_conversions(forcecast, contiguity, noconvert): + function_name = "accept_double" + if contiguity == "C": + function_name += "_c_style" + elif contiguity == "F": + function_name += "_f_style" + if forcecast: + function_name += "_forcecast" + if noconvert: + function_name += "_noconvert" + function = getattr(m, function_name) + + for dtype in [np.dtype("float32"), np.dtype("float64"), np.dtype("complex128")]: + for order in ["C", "F"]: + for shape in [(2, 2), (1, 3, 1, 1), (1, 1, 1), (0,)]: + if not noconvert: + # If noconvert is not passed, only complex128 needs to be truncated and + # "cannot be safely obtained". So without `forcecast`, the argument shouldn't + # be accepted. + should_raise = dtype.name == "complex128" and not forcecast + else: + # If noconvert is passed, only float64 and the matching order is accepted. + # If at most one dimension has a size greater than 1, the array is also + # trivially contiguous. + trivially_contiguous = sum(1 for d in shape if d > 1) <= 1 + should_raise = dtype.name != "float64" or ( + contiguity is not None + and contiguity != order + and not trivially_contiguous + ) + + array = np.zeros(shape, dtype=dtype, order=order) + if not should_raise: + function(array) + else: + with pytest.raises( + TypeError, match="incompatible function arguments" + ): + function(array) + + +@pytest.mark.xfail("env.PYPY") +def test_dtype_refcount_leak(): + from sys import getrefcount + + dtype = np.dtype(np.float_) + a = np.array([1], dtype=dtype) + before = getrefcount(dtype) + m.ndim(a) + after = getrefcount(dtype) + assert after == before diff --git a/plugins/python/pybind11/tests/test_numpy_dtypes.cpp b/plugins/python/pybind11/tests/test_numpy_dtypes.cpp index ddec851..b2e5e60 100644 --- a/plugins/python/pybind11/tests/test_numpy_dtypes.cpp +++ b/plugins/python/pybind11/tests/test_numpy_dtypes.cpp @@ -29,6 +29,13 @@ std::ostream& operator<<(std::ostream& os, const SimpleStruct& v) { return os << "s:" << v.bool_ << "," << v.uint_ << "," << v.float_ << "," << v.ldbl_; } +struct SimpleStructReordered { + bool bool_; + float float_; + uint32_t uint_; + long double ldbl_; +}; + PYBIND11_PACKED(struct PackedStruct { bool bool_; uint32_t uint_; @@ -161,7 +168,7 @@ py::list print_recarray(py::array_t arr) { const auto req = arr.request(); const auto ptr = static_cast(req.ptr); auto l = py::list(); - for (ssize_t i = 0; i < req.size; i++) { + for (py::ssize_t i = 0; i < req.size; i++) { std::stringstream ss; ss << ptr[i]; l.append(py::str(ss.str())); @@ -173,8 +180,8 @@ py::array_t test_array_ctors(int i) { using arr_t = py::array_t; std::vector data { 1, 2, 3, 4, 5, 6 }; - std::vector shape { 3, 2 }; - std::vector strides { 8, 4 }; + std::vector shape { 3, 2 }; + std::vector strides { 8, 4 }; auto ptr = data.data(); auto vptr = (void *) ptr; @@ -244,14 +251,37 @@ py::list test_dtype_ctors() { return list; } +struct A {}; +struct B {}; + TEST_SUBMODULE(numpy_dtypes, m) { - try { py::module::import("numpy"); } + try { py::module_::import("numpy"); } catch (...) { return; } // typeinfo may be registered before the dtype descriptor for scalar casts to work... - py::class_(m, "SimpleStruct"); + py::class_(m, "SimpleStruct") + // Explicit construct to ensure zero-valued initialization. + .def(py::init([]() { return SimpleStruct(); })) + .def_readwrite("bool_", &SimpleStruct::bool_) + .def_readwrite("uint_", &SimpleStruct::uint_) + .def_readwrite("float_", &SimpleStruct::float_) + .def_readwrite("ldbl_", &SimpleStruct::ldbl_) + .def("astuple", [](const SimpleStruct& self) { + return py::make_tuple(self.bool_, self.uint_, self.float_, self.ldbl_); + }) + .def_static("fromtuple", [](const py::tuple tup) { + if (py::len(tup) != 4) { + throw py::cast_error("Invalid size"); + } + return SimpleStruct{ + tup[0].cast(), + tup[1].cast(), + tup[2].cast(), + tup[3].cast()}; + }); PYBIND11_NUMPY_DTYPE(SimpleStruct, bool_, uint_, float_, ldbl_); + PYBIND11_NUMPY_DTYPE(SimpleStructReordered, bool_, uint_, float_, ldbl_); PYBIND11_NUMPY_DTYPE(PackedStruct, bool_, uint_, float_, ldbl_); PYBIND11_NUMPY_DTYPE(NestedStruct, a, b); PYBIND11_NUMPY_DTYPE(PartialStruct, bool_, uint_, float_, ldbl_); @@ -271,6 +301,15 @@ TEST_SUBMODULE(numpy_dtypes, m) { // struct NotPOD { std::string v; NotPOD() : v("hi") {}; }; // PYBIND11_NUMPY_DTYPE(NotPOD, v); + // Check that dtypes can be registered programmatically, both from + // initializer lists of field descriptors and from other containers. + py::detail::npy_format_descriptor::register_dtype( + {} + ); + py::detail::npy_format_descriptor::register_dtype( + std::vector{} + ); + // test_recarray, test_scalar_conversion m.def("create_rec_simple", &create_recarray); m.def("create_rec_packed", &create_recarray); @@ -359,7 +398,7 @@ TEST_SUBMODULE(numpy_dtypes, m) { if (non_empty) { auto req = arr.request(); auto ptr = static_cast(req.ptr); - for (ssize_t i = 0; i < req.size * req.itemsize; i++) + for (py::ssize_t i = 0; i < req.size * req.itemsize; i++) static_cast(req.ptr)[i] = 0; ptr[1].a[0] = 'a'; ptr[1].b[0] = 'a'; ptr[2].a[0] = 'a'; ptr[2].b[0] = 'a'; @@ -442,10 +481,19 @@ TEST_SUBMODULE(numpy_dtypes, m) { m.def("buffer_to_dtype", [](py::buffer& buf) { return py::dtype(buf.request()); }); // test_scalar_conversion - m.def("f_simple", [](SimpleStruct s) { return s.uint_ * 10; }); + auto f_simple = [](SimpleStruct s) { return s.uint_ * 10; }; + m.def("f_simple", f_simple); m.def("f_packed", [](PackedStruct s) { return s.uint_ * 10; }); m.def("f_nested", [](NestedStruct s) { return s.a.uint_ * 10; }); + // test_vectorize + m.def("f_simple_vectorized", py::vectorize(f_simple)); + auto f_simple_pass_thru = [](SimpleStruct s) { return s; }; + m.def("f_simple_pass_thru_vectorized", py::vectorize(f_simple_pass_thru)); + // test_register_dtype m.def("register_dtype", []() { PYBIND11_NUMPY_DTYPE(SimpleStruct, bool_, uint_, float_, ldbl_); }); + + // test_str_leak + m.def("dtype_wrapper", [](py::object d) { return py::dtype::from_args(std::move(d)); }); } diff --git a/plugins/python/pybind11/tests/test_numpy_dtypes.py b/plugins/python/pybind11/tests/test_numpy_dtypes.py index a4f49a9..f56b776 100644 --- a/plugins/python/pybind11/tests/test_numpy_dtypes.py +++ b/plugins/python/pybind11/tests/test_numpy_dtypes.py @@ -1,64 +1,80 @@ +# -*- coding: utf-8 -*- import re + import pytest -from pybind11_tests import numpy_dtypes as m -pytestmark = pytest.requires_numpy +import env # noqa: F401 + +from pybind11_tests import numpy_dtypes as m -with pytest.suppress(ImportError): - import numpy as np +np = pytest.importorskip("numpy") -@pytest.fixture(scope='module') +@pytest.fixture(scope="module") def simple_dtype(): - ld = np.dtype('longdouble') - return np.dtype({'names': ['bool_', 'uint_', 'float_', 'ldbl_'], - 'formats': ['?', 'u4', 'f4', 'f{}'.format(ld.itemsize)], - 'offsets': [0, 4, 8, (16 if ld.alignment > 4 else 12)]}) + ld = np.dtype("longdouble") + return np.dtype( + { + "names": ["bool_", "uint_", "float_", "ldbl_"], + "formats": ["?", "u4", "f4", "f{}".format(ld.itemsize)], + "offsets": [0, 4, 8, (16 if ld.alignment > 4 else 12)], + } + ) -@pytest.fixture(scope='module') +@pytest.fixture(scope="module") def packed_dtype(): - return np.dtype([('bool_', '?'), ('uint_', 'u4'), ('float_', 'f4'), ('ldbl_', 'g')]) + return np.dtype([("bool_", "?"), ("uint_", "u4"), ("float_", "f4"), ("ldbl_", "g")]) def dt_fmt(): from sys import byteorder - e = '<' if byteorder == 'little' else '>' - return ("{{'names':['bool_','uint_','float_','ldbl_']," - " 'formats':['?','" + e + "u4','" + e + "f4','" + e + "f{}']," - " 'offsets':[0,4,8,{}], 'itemsize':{}}}") + + e = "<" if byteorder == "little" else ">" + return ( + "{{'names':['bool_','uint_','float_','ldbl_']," + " 'formats':['?','" + e + "u4','" + e + "f4','" + e + "f{}']," + " 'offsets':[0,4,8,{}], 'itemsize':{}}}" + ) def simple_dtype_fmt(): - ld = np.dtype('longdouble') + ld = np.dtype("longdouble") simple_ld_off = 12 + 4 * (ld.alignment > 4) return dt_fmt().format(ld.itemsize, simple_ld_off, simple_ld_off + ld.itemsize) def packed_dtype_fmt(): from sys import byteorder + return "[('bool_', '?'), ('uint_', '{e}u4'), ('float_', '{e}f4'), ('ldbl_', '{e}f{}')]".format( - np.dtype('longdouble').itemsize, e='<' if byteorder == 'little' else '>') + np.dtype("longdouble").itemsize, e="<" if byteorder == "little" else ">" + ) def partial_ld_offset(): - return 12 + 4 * (np.dtype('uint64').alignment > 4) + 8 + 8 * ( - np.dtype('longdouble').alignment > 8) + return ( + 12 + + 4 * (np.dtype("uint64").alignment > 4) + + 8 + + 8 * (np.dtype("longdouble").alignment > 8) + ) def partial_dtype_fmt(): - ld = np.dtype('longdouble') + ld = np.dtype("longdouble") partial_ld_off = partial_ld_offset() return dt_fmt().format(ld.itemsize, partial_ld_off, partial_ld_off + ld.itemsize) def partial_nested_fmt(): - ld = np.dtype('longdouble') + ld = np.dtype("longdouble") partial_nested_off = 8 + 8 * (ld.alignment > 8) partial_ld_off = partial_ld_offset() partial_nested_size = partial_nested_off * 2 + partial_ld_off + ld.itemsize return "{{'names':['a'], 'formats':[{}], 'offsets':[{}], 'itemsize':{}}}".format( - partial_dtype_fmt(), partial_nested_off, partial_nested_size) + partial_dtype_fmt(), partial_nested_off, partial_nested_size + ) def assert_equal(actual, expected_data, expected_dtype): @@ -68,15 +84,19 @@ def assert_equal(actual, expected_data, expected_dtype): def test_format_descriptors(): with pytest.raises(RuntimeError) as excinfo: m.get_format_unbound() - assert re.match('^NumPy type info missing for .*UnboundStruct.*$', str(excinfo.value)) + assert re.match( + "^NumPy type info missing for .*UnboundStruct.*$", str(excinfo.value) + ) - ld = np.dtype('longdouble') - ldbl_fmt = ('4x' if ld.alignment > 4 else '') + ld.char + ld = np.dtype("longdouble") + ldbl_fmt = ("4x" if ld.alignment > 4 else "") + ld.char ss_fmt = "^T{?:bool_:3xI:uint_:f:float_:" + ldbl_fmt + ":ldbl_:}" - dbl = np.dtype('double') - partial_fmt = ("^T{?:bool_:3xI:uint_:f:float_:" + - str(4 * (dbl.alignment > 4) + dbl.itemsize + 8 * (ld.alignment > 8)) + - "xg:ldbl_:}") + dbl = np.dtype("double") + partial_fmt = ( + "^T{?:bool_:3xI:uint_:f:float_:" + + str(4 * (dbl.alignment > 4) + dbl.itemsize + 8 * (ld.alignment > 8)) + + "xg:ldbl_:}" + ) nested_extra = str(max(8, ld.alignment)) assert m.print_format_descriptors() == [ ss_fmt, @@ -86,14 +106,15 @@ def test_format_descriptors(): "^T{" + nested_extra + "x" + partial_fmt + ":a:" + nested_extra + "x}", "^T{3s:a:3s:b:}", "^T{(3)4s:a:(2)i:b:(3)B:c:1x(4, 2)f:d:}", - '^T{q:e1:B:e2:}', - '^T{Zf:cflt:Zd:cdbl:}' + "^T{q:e1:B:e2:}", + "^T{Zf:cflt:Zd:cdbl:}", ] def test_dtype(simple_dtype): from sys import byteorder - e = '<' if byteorder == 'little' else '>' + + e = "<" if byteorder == "little" else ">" assert m.print_dtypes() == [ simple_dtype_fmt(), @@ -102,30 +123,60 @@ def test_dtype(simple_dtype): partial_dtype_fmt(), partial_nested_fmt(), "[('a', 'S3'), ('b', 'S3')]", - ("{{'names':['a','b','c','d'], " + - "'formats':[('S4', (3,)),('" + e + "i4', (2,)),('u1', (3,)),('" + e + "f4', (4, 2))], " + - "'offsets':[0,12,20,24], 'itemsize':56}}").format(e=e), + ( + "{{'names':['a','b','c','d'], " + + "'formats':[('S4', (3,)),('" + + e + + "i4', (2,)),('u1', (3,)),('" + + e + + "f4', (4, 2))], " + + "'offsets':[0,12,20,24], 'itemsize':56}}" + ).format(e=e), "[('e1', '" + e + "i8'), ('e2', 'u1')]", "[('x', 'i1'), ('y', '" + e + "u8')]", - "[('cflt', '" + e + "c8'), ('cdbl', '" + e + "c16')]" + "[('cflt', '" + e + "c8'), ('cdbl', '" + e + "c16')]", ] - d1 = np.dtype({'names': ['a', 'b'], 'formats': ['int32', 'float64'], - 'offsets': [1, 10], 'itemsize': 20}) - d2 = np.dtype([('a', 'i4'), ('b', 'f4')]) - assert m.test_dtype_ctors() == [np.dtype('int32'), np.dtype('float64'), - np.dtype('bool'), d1, d1, np.dtype('uint32'), d2] + d1 = np.dtype( + { + "names": ["a", "b"], + "formats": ["int32", "float64"], + "offsets": [1, 10], + "itemsize": 20, + } + ) + d2 = np.dtype([("a", "i4"), ("b", "f4")]) + assert m.test_dtype_ctors() == [ + np.dtype("int32"), + np.dtype("float64"), + np.dtype("bool"), + d1, + d1, + np.dtype("uint32"), + d2, + ] - assert m.test_dtype_methods() == [np.dtype('int32'), simple_dtype, False, True, - np.dtype('int32').itemsize, simple_dtype.itemsize] + assert m.test_dtype_methods() == [ + np.dtype("int32"), + simple_dtype, + False, + True, + np.dtype("int32").itemsize, + simple_dtype.itemsize, + ] - assert m.trailing_padding_dtype() == m.buffer_to_dtype(np.zeros(1, m.trailing_padding_dtype())) + assert m.trailing_padding_dtype() == m.buffer_to_dtype( + np.zeros(1, m.trailing_padding_dtype()) + ) def test_recarray(simple_dtype, packed_dtype): elements = [(False, 0, 0.0, -0.0), (True, 1, 1.5, -2.5), (False, 2, 3.0, -5.0)] - for func, dtype in [(m.create_rec_simple, simple_dtype), (m.create_rec_packed, packed_dtype)]: + for func, dtype in [ + (m.create_rec_simple, simple_dtype), + (m.create_rec_packed, packed_dtype), + ]: arr = func(0) assert arr.dtype == dtype assert_equal(arr, [], simple_dtype) @@ -136,20 +187,24 @@ def test_recarray(simple_dtype, packed_dtype): assert_equal(arr, elements, simple_dtype) assert_equal(arr, elements, packed_dtype) + # Show what recarray's look like in NumPy. + assert type(arr[0]) == np.void + assert type(arr[0].item()) == tuple + if dtype == simple_dtype: assert m.print_rec_simple(arr) == [ "s:0,0,0,-0", "s:1,1,1.5,-2.5", - "s:0,2,3,-5" + "s:0,2,3,-5", ] else: assert m.print_rec_packed(arr) == [ "p:0,0,0,-0", "p:1,1,1.5,-2.5", - "p:0,2,3,-5" + "p:0,2,3,-5", ] - nested_dtype = np.dtype([('a', simple_dtype), ('b', packed_dtype)]) + nested_dtype = np.dtype([("a", simple_dtype), ("b", packed_dtype)]) arr = m.create_rec_nested(0) assert arr.dtype == nested_dtype @@ -157,33 +212,39 @@ def test_recarray(simple_dtype, packed_dtype): arr = m.create_rec_nested(3) assert arr.dtype == nested_dtype - assert_equal(arr, [((False, 0, 0.0, -0.0), (True, 1, 1.5, -2.5)), - ((True, 1, 1.5, -2.5), (False, 2, 3.0, -5.0)), - ((False, 2, 3.0, -5.0), (True, 3, 4.5, -7.5))], nested_dtype) + assert_equal( + arr, + [ + ((False, 0, 0.0, -0.0), (True, 1, 1.5, -2.5)), + ((True, 1, 1.5, -2.5), (False, 2, 3.0, -5.0)), + ((False, 2, 3.0, -5.0), (True, 3, 4.5, -7.5)), + ], + nested_dtype, + ) assert m.print_rec_nested(arr) == [ "n:a=s:0,0,0,-0;b=p:1,1,1.5,-2.5", "n:a=s:1,1,1.5,-2.5;b=p:0,2,3,-5", - "n:a=s:0,2,3,-5;b=p:1,3,4.5,-7.5" + "n:a=s:0,2,3,-5;b=p:1,3,4.5,-7.5", ] arr = m.create_rec_partial(3) assert str(arr.dtype) == partial_dtype_fmt() partial_dtype = arr.dtype - assert '' not in arr.dtype.fields + assert "" not in arr.dtype.fields assert partial_dtype.itemsize > simple_dtype.itemsize assert_equal(arr, elements, simple_dtype) assert_equal(arr, elements, packed_dtype) arr = m.create_rec_partial_nested(3) assert str(arr.dtype) == partial_nested_fmt() - assert '' not in arr.dtype.fields - assert '' not in arr.dtype.fields['a'][0].fields + assert "" not in arr.dtype.fields + assert "" not in arr.dtype.fields["a"][0].fields assert arr.dtype.itemsize > partial_dtype.itemsize - np.testing.assert_equal(arr['a'], m.create_rec_partial(3)) + np.testing.assert_equal(arr["a"], m.create_rec_partial(3)) def test_array_constructors(): - data = np.arange(1, 7, dtype='int32') + data = np.arange(1, 7, dtype="int32") for i in range(8): np.testing.assert_array_equal(m.test_array_ctors(10 + i), data.reshape((3, 2))) np.testing.assert_array_equal(m.test_array_ctors(20 + i), data.reshape((3, 2))) @@ -199,82 +260,92 @@ def test_string_array(): "a='',b=''", "a='a',b='a'", "a='ab',b='ab'", - "a='abc',b='abc'" + "a='abc',b='abc'", ] dtype = arr.dtype - assert arr['a'].tolist() == [b'', b'a', b'ab', b'abc'] - assert arr['b'].tolist() == [b'', b'a', b'ab', b'abc'] + assert arr["a"].tolist() == [b"", b"a", b"ab", b"abc"] + assert arr["b"].tolist() == [b"", b"a", b"ab", b"abc"] arr = m.create_string_array(False) assert dtype == arr.dtype def test_array_array(): from sys import byteorder - e = '<' if byteorder == 'little' else '>' + + e = "<" if byteorder == "little" else ">" arr = m.create_array_array(3) assert str(arr.dtype) == ( - "{{'names':['a','b','c','d'], " + - "'formats':[('S4', (3,)),('" + e + "i4', (2,)),('u1', (3,)),('{e}f4', (4, 2))], " + - "'offsets':[0,12,20,24], 'itemsize':56}}").format(e=e) + "{{'names':['a','b','c','d'], " + + "'formats':[('S4', (3,)),('" + + e + + "i4', (2,)),('u1', (3,)),('{e}f4', (4, 2))], " + + "'offsets':[0,12,20,24], 'itemsize':56}}" + ).format(e=e) assert m.print_array_array(arr) == [ - "a={{A,B,C,D},{K,L,M,N},{U,V,W,X}},b={0,1}," + - "c={0,1,2},d={{0,1},{10,11},{20,21},{30,31}}", - "a={{W,X,Y,Z},{G,H,I,J},{Q,R,S,T}},b={1000,1001}," + - "c={10,11,12},d={{100,101},{110,111},{120,121},{130,131}}", - "a={{S,T,U,V},{C,D,E,F},{M,N,O,P}},b={2000,2001}," + - "c={20,21,22},d={{200,201},{210,211},{220,221},{230,231}}", + "a={{A,B,C,D},{K,L,M,N},{U,V,W,X}},b={0,1}," + + "c={0,1,2},d={{0,1},{10,11},{20,21},{30,31}}", + "a={{W,X,Y,Z},{G,H,I,J},{Q,R,S,T}},b={1000,1001}," + + "c={10,11,12},d={{100,101},{110,111},{120,121},{130,131}}", + "a={{S,T,U,V},{C,D,E,F},{M,N,O,P}},b={2000,2001}," + + "c={20,21,22},d={{200,201},{210,211},{220,221},{230,231}}", ] - assert arr['a'].tolist() == [[b'ABCD', b'KLMN', b'UVWX'], - [b'WXYZ', b'GHIJ', b'QRST'], - [b'STUV', b'CDEF', b'MNOP']] - assert arr['b'].tolist() == [[0, 1], [1000, 1001], [2000, 2001]] + assert arr["a"].tolist() == [ + [b"ABCD", b"KLMN", b"UVWX"], + [b"WXYZ", b"GHIJ", b"QRST"], + [b"STUV", b"CDEF", b"MNOP"], + ] + assert arr["b"].tolist() == [[0, 1], [1000, 1001], [2000, 2001]] assert m.create_array_array(0).dtype == arr.dtype def test_enum_array(): from sys import byteorder - e = '<' if byteorder == 'little' else '>' + + e = "<" if byteorder == "little" else ">" arr = m.create_enum_array(3) dtype = arr.dtype - assert dtype == np.dtype([('e1', e + 'i8'), ('e2', 'u1')]) - assert m.print_enum_array(arr) == [ - "e1=A,e2=X", - "e1=B,e2=Y", - "e1=A,e2=X" - ] - assert arr['e1'].tolist() == [-1, 1, -1] - assert arr['e2'].tolist() == [1, 2, 1] + assert dtype == np.dtype([("e1", e + "i8"), ("e2", "u1")]) + assert m.print_enum_array(arr) == ["e1=A,e2=X", "e1=B,e2=Y", "e1=A,e2=X"] + assert arr["e1"].tolist() == [-1, 1, -1] + assert arr["e2"].tolist() == [1, 2, 1] assert m.create_enum_array(0).dtype == dtype def test_complex_array(): from sys import byteorder - e = '<' if byteorder == 'little' else '>' + + e = "<" if byteorder == "little" else ">" arr = m.create_complex_array(3) dtype = arr.dtype - assert dtype == np.dtype([('cflt', e + 'c8'), ('cdbl', e + 'c16')]) + assert dtype == np.dtype([("cflt", e + "c8"), ("cdbl", e + "c16")]) assert m.print_complex_array(arr) == [ "c:(0,0.25),(0.5,0.75)", "c:(1,1.25),(1.5,1.75)", - "c:(2,2.25),(2.5,2.75)" + "c:(2,2.25),(2.5,2.75)", ] - assert arr['cflt'].tolist() == [0.0 + 0.25j, 1.0 + 1.25j, 2.0 + 2.25j] - assert arr['cdbl'].tolist() == [0.5 + 0.75j, 1.5 + 1.75j, 2.5 + 2.75j] + assert arr["cflt"].tolist() == [0.0 + 0.25j, 1.0 + 1.25j, 2.0 + 2.25j] + assert arr["cdbl"].tolist() == [0.5 + 0.75j, 1.5 + 1.75j, 2.5 + 2.75j] assert m.create_complex_array(0).dtype == dtype def test_signature(doc): - assert doc(m.create_rec_nested) == \ - "create_rec_nested(arg0: int) -> numpy.ndarray[NestedStruct]" + assert ( + doc(m.create_rec_nested) + == "create_rec_nested(arg0: int) -> numpy.ndarray[NestedStruct]" + ) def test_scalar_conversion(): n = 3 - arrays = [m.create_rec_simple(n), m.create_rec_packed(n), - m.create_rec_nested(n), m.create_enum_array(n)] + arrays = [ + m.create_rec_simple(n), + m.create_rec_packed(n), + m.create_rec_nested(n), + m.create_enum_array(n), + ] funcs = [m.f_simple, m.f_packed, m.f_nested] for i, func in enumerate(funcs): @@ -284,15 +355,77 @@ def test_scalar_conversion(): else: with pytest.raises(TypeError) as excinfo: func(arr[0]) - assert 'incompatible function arguments' in str(excinfo.value) + assert "incompatible function arguments" in str(excinfo.value) + + +def test_vectorize(): + n = 3 + array = m.create_rec_simple(n) + values = m.f_simple_vectorized(array) + np.testing.assert_array_equal(values, [0, 10, 20]) + array_2 = m.f_simple_pass_thru_vectorized(array) + np.testing.assert_array_equal(array, array_2) + + +def test_cls_and_dtype_conversion(simple_dtype): + s = m.SimpleStruct() + assert s.astuple() == (False, 0, 0.0, 0.0) + assert m.SimpleStruct.fromtuple(s.astuple()).astuple() == s.astuple() + + s.uint_ = 2 + assert m.f_simple(s) == 20 + + # Try as recarray of shape==(1,). + s_recarray = np.array([(False, 2, 0.0, 0.0)], dtype=simple_dtype) + # Show that this will work for vectorized case. + np.testing.assert_array_equal(m.f_simple_vectorized(s_recarray), [20]) + + # Show as a scalar that inherits from np.generic. + s_scalar = s_recarray[0] + assert isinstance(s_scalar, np.void) + assert m.f_simple(s_scalar) == 20 + + # Show that an *array* scalar (np.ndarray.shape == ()) does not convert. + # More specifically, conversion to SimpleStruct is not implicit. + s_recarray_scalar = s_recarray.reshape(()) + assert isinstance(s_recarray_scalar, np.ndarray) + assert s_recarray_scalar.dtype == simple_dtype + with pytest.raises(TypeError) as excinfo: + m.f_simple(s_recarray_scalar) + assert "incompatible function arguments" in str(excinfo.value) + # Explicitly convert to m.SimpleStruct. + assert m.f_simple(m.SimpleStruct.fromtuple(s_recarray_scalar.item())) == 20 + + # Show that an array of dtype=object does *not* convert. + s_array_object = np.array([s]) + assert s_array_object.dtype == object + with pytest.raises(TypeError) as excinfo: + m.f_simple_vectorized(s_array_object) + assert "incompatible function arguments" in str(excinfo.value) + # Explicitly convert to `np.array(..., dtype=simple_dtype)` + s_array = np.array([s.astuple()], dtype=simple_dtype) + np.testing.assert_array_equal(m.f_simple_vectorized(s_array), [20]) def test_register_dtype(): with pytest.raises(RuntimeError) as excinfo: m.register_dtype() - assert 'dtype is already registered' in str(excinfo.value) + assert "dtype is already registered" in str(excinfo.value) + + +@pytest.mark.xfail("env.PYPY") +def test_str_leak(): + from sys import getrefcount + + fmt = "f4" + pytest.gc_collect() + start = getrefcount(fmt) + d = m.dtype_wrapper(fmt) + assert d is np.dtype("f4") + del d + pytest.gc_collect() + assert getrefcount(fmt) == start -@pytest.requires_numpy def test_compare_buffer_info(): assert all(m.compare_buffer_info()) diff --git a/plugins/python/pybind11/tests/test_numpy_vectorize.cpp b/plugins/python/pybind11/tests/test_numpy_vectorize.cpp index a875a74..274b755 100644 --- a/plugins/python/pybind11/tests/test_numpy_vectorize.cpp +++ b/plugins/python/pybind11/tests/test_numpy_vectorize.cpp @@ -17,7 +17,7 @@ double my_func(int x, float y, double z) { } TEST_SUBMODULE(numpy_vectorize, m) { - try { py::module::import("numpy"); } + try { py::module_::import("numpy"); } catch (...) { return; } // test_vectorize, test_docs, test_array_collapse @@ -37,7 +37,7 @@ TEST_SUBMODULE(numpy_vectorize, m) { )); // test_type_selection - // Numpy function which only accepts specific data types + // NumPy function which only accepts specific data types m.def("selective_func", [](py::array_t) { return "Int branch taken."; }); m.def("selective_func", [](py::array_t) { return "Float branch taken."; }); m.def("selective_func", [](py::array_t, py::array::c_style>) { return "Complex float branch taken."; }); @@ -50,7 +50,9 @@ TEST_SUBMODULE(numpy_vectorize, m) { NonPODClass(int v) : value{v} {} int value; }; - py::class_(m, "NonPODClass").def(py::init()); + py::class_(m, "NonPODClass") + .def(py::init()) + .def_readwrite("value", &NonPODClass::value); m.def("vec_passthrough", py::vectorize( [](double *a, double b, py::array_t c, const int &d, int &e, NonPODClass f, const double g) { return *a + b + c.at(0) + d + e + f.value + g; @@ -81,9 +83,11 @@ TEST_SUBMODULE(numpy_vectorize, m) { py::array_t arg2, py::array_t arg3 ) { - ssize_t ndim; - std::vector shape; + py::ssize_t ndim; + std::vector shape; std::array buffers {{ arg1.request(), arg2.request(), arg3.request() }}; return py::detail::broadcast(buffers, ndim, shape); }); + + m.def("add_to", py::vectorize([](NonPODClass& x, int a) { x.value += a; })); } diff --git a/plugins/python/pybind11/tests/test_numpy_vectorize.py b/plugins/python/pybind11/tests/test_numpy_vectorize.py index 0e9c883..4e6b2d1 100644 --- a/plugins/python/pybind11/tests/test_numpy_vectorize.py +++ b/plugins/python/pybind11/tests/test_numpy_vectorize.py @@ -1,10 +1,8 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import numpy_vectorize as m -pytestmark = pytest.requires_numpy - -with pytest.suppress(ImportError): - import numpy as np +np = pytest.importorskip("numpy") def test_vectorize(capture): @@ -19,28 +17,40 @@ def test_vectorize(capture): assert capture == "my_func(x:int=1, y:float=2, z:float=3)" with capture: assert np.allclose(f(np.array([1, 3]), np.array([2, 4]), 3), [6, 36]) - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=2, z:float=3) my_func(x:int=3, y:float=4, z:float=3) """ + ) with capture: - a = np.array([[1, 2], [3, 4]], order='F') - b = np.array([[10, 20], [30, 40]], order='F') + a = np.array([[1, 2], [3, 4]], order="F") + b = np.array([[10, 20], [30, 40]], order="F") c = 3 result = f(a, b, c) assert np.allclose(result, a * b * c) assert result.flags.f_contiguous # All inputs are F order and full or singletons, so we the result is in col-major order: - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=10, z:float=3) my_func(x:int=3, y:float=30, z:float=3) my_func(x:int=2, y:float=20, z:float=3) my_func(x:int=4, y:float=40, z:float=3) """ + ) with capture: - a, b, c = np.array([[1, 3, 5], [7, 9, 11]]), np.array([[2, 4, 6], [8, 10, 12]]), 3 + a, b, c = ( + np.array([[1, 3, 5], [7, 9, 11]]), + np.array([[2, 4, 6], [8, 10, 12]]), + 3, + ) assert np.allclose(f(a, b, c), a * b * c) - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=2, z:float=3) my_func(x:int=3, y:float=4, z:float=3) my_func(x:int=5, y:float=6, z:float=3) @@ -48,10 +58,13 @@ def test_vectorize(capture): my_func(x:int=9, y:float=10, z:float=3) my_func(x:int=11, y:float=12, z:float=3) """ + ) with capture: a, b, c = np.array([[1, 2, 3], [4, 5, 6]]), np.array([2, 3, 4]), 2 assert np.allclose(f(a, b, c), a * b * c) - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=2, z:float=2) my_func(x:int=2, y:float=3, z:float=2) my_func(x:int=3, y:float=4, z:float=2) @@ -59,10 +72,13 @@ def test_vectorize(capture): my_func(x:int=5, y:float=3, z:float=2) my_func(x:int=6, y:float=4, z:float=2) """ + ) with capture: a, b, c = np.array([[1, 2, 3], [4, 5, 6]]), np.array([[2], [3]]), 2 assert np.allclose(f(a, b, c), a * b * c) - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=2, z:float=2) my_func(x:int=2, y:float=2, z:float=2) my_func(x:int=3, y:float=2, z:float=2) @@ -70,10 +86,17 @@ def test_vectorize(capture): my_func(x:int=5, y:float=3, z:float=2) my_func(x:int=6, y:float=3, z:float=2) """ + ) with capture: - a, b, c = np.array([[1, 2, 3], [4, 5, 6]], order='F'), np.array([[2], [3]]), 2 + a, b, c = ( + np.array([[1, 2, 3], [4, 5, 6]], order="F"), + np.array([[2], [3]]), + 2, + ) assert np.allclose(f(a, b, c), a * b * c) - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=2, z:float=2) my_func(x:int=2, y:float=2, z:float=2) my_func(x:int=3, y:float=2, z:float=2) @@ -81,36 +104,53 @@ def test_vectorize(capture): my_func(x:int=5, y:float=3, z:float=2) my_func(x:int=6, y:float=3, z:float=2) """ + ) with capture: a, b, c = np.array([[1, 2, 3], [4, 5, 6]])[::, ::2], np.array([[2], [3]]), 2 assert np.allclose(f(a, b, c), a * b * c) - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=2, z:float=2) my_func(x:int=3, y:float=2, z:float=2) my_func(x:int=4, y:float=3, z:float=2) my_func(x:int=6, y:float=3, z:float=2) """ + ) with capture: - a, b, c = np.array([[1, 2, 3], [4, 5, 6]], order='F')[::, ::2], np.array([[2], [3]]), 2 + a, b, c = ( + np.array([[1, 2, 3], [4, 5, 6]], order="F")[::, ::2], + np.array([[2], [3]]), + 2, + ) assert np.allclose(f(a, b, c), a * b * c) - assert capture == """ + assert ( + capture + == """ my_func(x:int=1, y:float=2, z:float=2) my_func(x:int=3, y:float=2, z:float=2) my_func(x:int=4, y:float=3, z:float=2) my_func(x:int=6, y:float=3, z:float=2) """ + ) def test_type_selection(): assert m.selective_func(np.array([1], dtype=np.int32)) == "Int branch taken." assert m.selective_func(np.array([1.0], dtype=np.float32)) == "Float branch taken." - assert m.selective_func(np.array([1.0j], dtype=np.complex64)) == "Complex float branch taken." + assert ( + m.selective_func(np.array([1.0j], dtype=np.complex64)) + == "Complex float branch taken." + ) def test_docs(doc): - assert doc(m.vectorized_func) == """ - vectorized_func(arg0: numpy.ndarray[int32], arg1: numpy.ndarray[float32], arg2: numpy.ndarray[float64]) -> object + assert ( + doc(m.vectorized_func) + == """ + vectorized_func(arg0: numpy.ndarray[numpy.int32], arg1: numpy.ndarray[numpy.float32], arg2: numpy.ndarray[numpy.float64]) -> object """ # noqa: E501 line too long + ) def test_trivial_broadcasting(): @@ -118,16 +158,24 @@ def test_trivial_broadcasting(): assert vectorized_is_trivial(1, 2, 3) == trivial.c_trivial assert vectorized_is_trivial(np.array(1), np.array(2), 3) == trivial.c_trivial - assert vectorized_is_trivial(np.array([1, 3]), np.array([2, 4]), 3) == trivial.c_trivial + assert ( + vectorized_is_trivial(np.array([1, 3]), np.array([2, 4]), 3) + == trivial.c_trivial + ) assert trivial.c_trivial == vectorized_is_trivial( - np.array([[1, 3, 5], [7, 9, 11]]), np.array([[2, 4, 6], [8, 10, 12]]), 3) - assert vectorized_is_trivial( - np.array([[1, 2, 3], [4, 5, 6]]), np.array([2, 3, 4]), 2) == trivial.non_trivial - assert vectorized_is_trivial( - np.array([[1, 2, 3], [4, 5, 6]]), np.array([[2], [3]]), 2) == trivial.non_trivial - z1 = np.array([[1, 2, 3, 4], [5, 6, 7, 8]], dtype='int32') - z2 = np.array(z1, dtype='float32') - z3 = np.array(z1, dtype='float64') + np.array([[1, 3, 5], [7, 9, 11]]), np.array([[2, 4, 6], [8, 10, 12]]), 3 + ) + assert ( + vectorized_is_trivial(np.array([[1, 2, 3], [4, 5, 6]]), np.array([2, 3, 4]), 2) + == trivial.non_trivial + ) + assert ( + vectorized_is_trivial(np.array([[1, 2, 3], [4, 5, 6]]), np.array([[2], [3]]), 2) + == trivial.non_trivial + ) + z1 = np.array([[1, 2, 3, 4], [5, 6, 7, 8]], dtype="int32") + z2 = np.array(z1, dtype="float32") + z3 = np.array(z1, dtype="float64") assert vectorized_is_trivial(z1, z2, z3) == trivial.c_trivial assert vectorized_is_trivial(1, z2, z3) == trivial.c_trivial assert vectorized_is_trivial(z1, 1, z3) == trivial.c_trivial @@ -137,7 +185,7 @@ def test_trivial_broadcasting(): assert vectorized_is_trivial(1, 1, z3[::2, ::2]) == trivial.non_trivial assert vectorized_is_trivial(z1, 1, z3[1::4, 1::4]) == trivial.c_trivial - y1 = np.array(z1, order='F') + y1 = np.array(z1, order="F") y2 = np.array(y1) y3 = np.array(y1) assert vectorized_is_trivial(y1, y2, y3) == trivial.f_trivial @@ -158,30 +206,41 @@ def test_trivial_broadcasting(): def test_passthrough_arguments(doc): assert doc(m.vec_passthrough) == ( - "vec_passthrough(" + ", ".join([ - "arg0: float", - "arg1: numpy.ndarray[float64]", - "arg2: numpy.ndarray[float64]", - "arg3: numpy.ndarray[int32]", - "arg4: int", - "arg5: m.numpy_vectorize.NonPODClass", - "arg6: numpy.ndarray[float64]"]) + ") -> object") - - b = np.array([[10, 20, 30]], dtype='float64') + "vec_passthrough(" + + ", ".join( + [ + "arg0: float", + "arg1: numpy.ndarray[numpy.float64]", + "arg2: numpy.ndarray[numpy.float64]", + "arg3: numpy.ndarray[numpy.int32]", + "arg4: int", + "arg5: m.numpy_vectorize.NonPODClass", + "arg6: numpy.ndarray[numpy.float64]", + ] + ) + + ") -> object" + ) + + b = np.array([[10, 20, 30]], dtype="float64") c = np.array([100, 200]) # NOT a vectorized argument - d = np.array([[1000], [2000], [3000]], dtype='int') - g = np.array([[1000000, 2000000, 3000000]], dtype='int') # requires casting + d = np.array([[1000], [2000], [3000]], dtype="int") + g = np.array([[1000000, 2000000, 3000000]], dtype="int") # requires casting assert np.all( - m.vec_passthrough(1, b, c, d, 10000, m.NonPODClass(100000), g) == - np.array([[1111111, 2111121, 3111131], - [1112111, 2112121, 3112131], - [1113111, 2113121, 3113131]])) + m.vec_passthrough(1, b, c, d, 10000, m.NonPODClass(100000), g) + == np.array( + [ + [1111111, 2111121, 3111131], + [1112111, 2112121, 3112131], + [1113111, 2113121, 3113131], + ] + ) + ) def test_method_vectorization(): o = m.VectorizeTestClass(3) - x = np.array([1, 2], dtype='int') - y = np.array([[10], [20]], dtype='float32') + x = np.array([1, 2], dtype="int") + y = np.array([[10], [20]], dtype="float32") assert np.all(o.method(x, y) == [[14, 15], [24, 25]]) @@ -190,7 +249,18 @@ def test_array_collapse(): assert not isinstance(m.vectorized_func(np.array(1), 2, 3), np.ndarray) z = m.vectorized_func([1], 2, 3) assert isinstance(z, np.ndarray) - assert z.shape == (1, ) + assert z.shape == (1,) z = m.vectorized_func(1, [[[2]]], 3) assert isinstance(z, np.ndarray) assert z.shape == (1, 1, 1) + + +def test_vectorized_noreturn(): + x = m.NonPODClass(0) + assert x.value == 0 + m.add_to(x, [1, 2, 3, 4]) + assert x.value == 10 + m.add_to(x, 1) + assert x.value == 11 + m.add_to(x, [[1, 1], [2, 3]]) + assert x.value == 18 diff --git a/plugins/python/pybind11/tests/test_opaque_types.cpp b/plugins/python/pybind11/tests/test_opaque_types.cpp index 5e83df0..5a23431 100644 --- a/plugins/python/pybind11/tests/test_opaque_types.cpp +++ b/plugins/python/pybind11/tests/test_opaque_types.cpp @@ -11,10 +11,14 @@ #include #include -using StringList = std::vector; +// IMPORTANT: Disable internal pybind11 translation mechanisms for STL data structures +// +// This also deliberately doesn't use the below StringList type alias to test +// that MAKE_OPAQUE can handle a type containing a `,`. (The `std::allocator` +// bit is just the default `std::vector` allocator). +PYBIND11_MAKE_OPAQUE(std::vector>); -/* IMPORTANT: Disable internal pybind11 translation mechanisms for STL data structures */ -PYBIND11_MAKE_OPAQUE(StringList); +using StringList = std::vector>; TEST_SUBMODULE(opaque_types, m) { // test_string_list @@ -56,8 +60,14 @@ TEST_SUBMODULE(opaque_types, m) { m.def("get_null_str_value", [](char *ptr) { return reinterpret_cast(ptr); }); m.def("return_unique_ptr", []() -> std::unique_ptr { - StringList *result = new StringList(); + auto *result = new StringList(); result->push_back("some value"); return std::unique_ptr(result); }); + + // test unions + py::class_(m, "IntFloat") + .def(py::init<>()) + .def_readwrite("i", &IntFloat::i) + .def_readwrite("f", &IntFloat::f); } diff --git a/plugins/python/pybind11/tests/test_opaque_types.py b/plugins/python/pybind11/tests/test_opaque_types.py index 6b3802f..7737946 100644 --- a/plugins/python/pybind11/tests/test_opaque_types.py +++ b/plugins/python/pybind11/tests/test_opaque_types.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import opaque_types as m from pybind11_tests import ConstructorStats, UserType @@ -31,12 +32,15 @@ def test_pointers(msg): with pytest.raises(TypeError) as excinfo: m.get_void_ptr_value([1, 2, 3]) # This should not work - assert msg(excinfo.value) == """ + assert ( + msg(excinfo.value) + == """ get_void_ptr_value(): incompatible function arguments. The following argument types are supported: 1. (arg0: capsule) -> int Invoked with: [1, 2, 3] """ # noqa: E501 line too long + ) assert m.return_null_str() is None assert m.get_null_str_value(m.return_null_str()) is not None @@ -44,3 +48,11 @@ def test_pointers(msg): ptr = m.return_unique_ptr() assert "StringList" in repr(ptr) assert m.print_opaque_list(ptr) == "Opaque list: [some value]" + + +def test_unions(): + int_float_union = m.IntFloat() + int_float_union.i = 42 + assert int_float_union.i == 42 + int_float_union.f = 3.0 + assert int_float_union.f == 3.0 diff --git a/plugins/python/pybind11/tests/test_operator_overloading.cpp b/plugins/python/pybind11/tests/test_operator_overloading.cpp index 4ad34d1..0a27bfd 100644 --- a/plugins/python/pybind11/tests/test_operator_overloading.cpp +++ b/plugins/python/pybind11/tests/test_operator_overloading.cpp @@ -23,6 +23,7 @@ class Vector2 { std::string toString() const { return "[" + std::to_string(x) + ", " + std::to_string(y) + "]"; } + Vector2 operator-() const { return Vector2(-x, -y); } Vector2 operator+(const Vector2 &v) const { return Vector2(x + v.x, y + v.y); } Vector2 operator-(const Vector2 &v) const { return Vector2(x - v.x, y - v.y); } Vector2 operator-(float value) const { return Vector2(x - value, y - value); } @@ -42,6 +43,13 @@ class Vector2 { friend Vector2 operator-(float f, const Vector2 &v) { return Vector2(f - v.x, f - v.y); } friend Vector2 operator*(float f, const Vector2 &v) { return Vector2(f * v.x, f * v.y); } friend Vector2 operator/(float f, const Vector2 &v) { return Vector2(f / v.x, f / v.y); } + + bool operator==(const Vector2 &v) const { + return x == v.x && y == v.y; + } + bool operator!=(const Vector2 &v) const { + return x != v.x || y != v.y; + } private: float x, y; }; @@ -54,14 +62,43 @@ int operator+(const C2 &, const C2 &) { return 22; } int operator+(const C2 &, const C1 &) { return 21; } int operator+(const C1 &, const C2 &) { return 12; } +// Note: Specializing explicit within `namespace std { ... }` is done due to a +// bug in GCC<7. If you are supporting compilers later than this, consider +// specializing `using template<> struct std::hash<...>` in the global +// namespace instead, per this recommendation: +// https://en.cppreference.com/w/cpp/language/extending_std#Adding_template_specializations namespace std { template<> struct hash { // Not a good hash function, but easy to test size_t operator()(const Vector2 &) { return 4; } }; +} // namespace std + +// Not a good abs function, but easy to test. +std::string abs(const Vector2&) { + return "abs(Vector2)"; } +// MSVC warns about unknown pragmas, and warnings are errors. +#ifndef _MSC_VER + #pragma GCC diagnostic push + // clang 7.0.0 and Apple LLVM 10.0.1 introduce `-Wself-assign-overloaded` to + // `-Wall`, which is used here for overloading (e.g. `py::self += py::self `). + // Here, we suppress the warning using `#pragma diagnostic`. + // Taken from: https://github.com/RobotLocomotion/drake/commit/aaf84b46 + // TODO(eric): This could be resolved using a function / functor (e.g. `py::self()`). + #if defined(__APPLE__) && defined(__clang__) + #if (__clang_major__ >= 10) + #pragma GCC diagnostic ignored "-Wself-assign-overloaded" + #endif + #elif defined(__clang__) + #if (__clang_major__ >= 7) + #pragma GCC diagnostic ignored "-Wself-assign-overloaded" + #endif + #endif +#endif + TEST_SUBMODULE(operators, m) { // test_operator_overloading @@ -85,8 +122,15 @@ TEST_SUBMODULE(operators, m) { .def(float() - py::self) .def(float() * py::self) .def(float() / py::self) + .def(-py::self) .def("__str__", &Vector2::toString) - .def(hash(py::self)) + .def("__repr__", &Vector2::toString) + .def(py::self == py::self) + .def(py::self != py::self) + .def(py::hash(py::self)) + // N.B. See warning about usage of `py::detail::abs(py::self)` in + // `operators.h`. + .def("__abs__", [](const Vector2& v) { return abs(v); }) ; m.attr("Vector") = m.attr("Vector2"); @@ -143,4 +187,40 @@ TEST_SUBMODULE(operators, m) { .def(py::self *= int()) .def_readwrite("b", &NestC::b); m.def("get_NestC", [](const NestC &c) { return c.value; }); + + + // test_overriding_eq_reset_hash + // #2191 Overriding __eq__ should set __hash__ to None + struct Comparable { + int value; + bool operator==(const Comparable& rhs) const {return value == rhs.value;} + }; + + struct Hashable : Comparable { + explicit Hashable(int value): Comparable{value}{}; + size_t hash() const { return static_cast(value); } + }; + + struct Hashable2 : Hashable { + using Hashable::Hashable; + }; + + py::class_(m, "Comparable") + .def(py::init()) + .def(py::self == py::self); + + py::class_(m, "Hashable") + .def(py::init()) + .def(py::self == py::self) + .def("__hash__", &Hashable::hash); + + // define __hash__ before __eq__ + py::class_(m, "Hashable2") + .def("__hash__", &Hashable::hash) + .def(py::init()) + .def(py::self == py::self); } + +#ifndef _MSC_VER + #pragma GCC diagnostic pop +#endif diff --git a/plugins/python/pybind11/tests/test_operator_overloading.py b/plugins/python/pybind11/tests/test_operator_overloading.py index 86827d2..5dbfb32 100644 --- a/plugins/python/pybind11/tests/test_operator_overloading.py +++ b/plugins/python/pybind11/tests/test_operator_overloading.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import operators as m from pybind11_tests import ConstructorStats @@ -6,9 +7,14 @@ def test_operator_overloading(): v1 = m.Vector2(1, 2) v2 = m.Vector(3, -1) + v3 = m.Vector2(1, 2) # Same value as v1, but different instance. + assert v1 is not v3 + assert str(v1) == "[1.000000, 2.000000]" assert str(v2) == "[3.000000, -1.000000]" + assert str(-v2) == "[-3.000000, 1.000000]" + assert str(v1 + v2) == "[4.000000, 1.000000]" assert str(v1 - v2) == "[-2.000000, 3.000000]" assert str(v1 - 8) == "[-7.000000, -6.000000]" @@ -22,6 +28,12 @@ def test_operator_overloading(): assert str(v1 * v2) == "[3.000000, -2.000000]" assert str(v2 / v1) == "[3.000000, -0.500000]" + assert v1 == v3 + assert v1 != v2 + assert hash(v1) == 4 + # TODO(eric.cousineau): Make this work. + # assert abs(v1) == "abs(Vector2)" + v1 += 2 * v2 assert str(v1) == "[7.000000, 0.000000]" v1 -= v2 @@ -35,22 +47,33 @@ def test_operator_overloading(): v2 /= v1 assert str(v2) == "[2.000000, 8.000000]" - assert hash(v1) == 4 - cstats = ConstructorStats.get(m.Vector2) - assert cstats.alive() == 2 + assert cstats.alive() == 3 del v1 - assert cstats.alive() == 1 + assert cstats.alive() == 2 del v2 + assert cstats.alive() == 1 + del v3 assert cstats.alive() == 0 - assert cstats.values() == ['[1.000000, 2.000000]', '[3.000000, -1.000000]', - '[4.000000, 1.000000]', '[-2.000000, 3.000000]', - '[-7.000000, -6.000000]', '[9.000000, 10.000000]', - '[8.000000, 16.000000]', '[0.125000, 0.250000]', - '[7.000000, 6.000000]', '[9.000000, 10.000000]', - '[8.000000, 16.000000]', '[8.000000, 4.000000]', - '[3.000000, -2.000000]', '[3.000000, -0.500000]', - '[6.000000, -2.000000]'] + assert cstats.values() == [ + "[1.000000, 2.000000]", + "[3.000000, -1.000000]", + "[1.000000, 2.000000]", + "[-3.000000, 1.000000]", + "[4.000000, 1.000000]", + "[-2.000000, 3.000000]", + "[-7.000000, -6.000000]", + "[9.000000, 10.000000]", + "[8.000000, 16.000000]", + "[0.125000, 0.250000]", + "[7.000000, 6.000000]", + "[9.000000, 10.000000]", + "[8.000000, 16.000000]", + "[8.000000, 4.000000]", + "[3.000000, -2.000000]", + "[3.000000, -0.500000]", + "[6.000000, -2.000000]", + ] assert cstats.default_constructions == 0 assert cstats.copy_constructions == 0 assert cstats.move_constructions >= 10 @@ -104,3 +127,19 @@ def test_nested(): assert abase.value == 42 del abase, b pytest.gc_collect() + + +def test_overriding_eq_reset_hash(): + + assert m.Comparable(15) is not m.Comparable(15) + assert m.Comparable(15) == m.Comparable(15) + + with pytest.raises(TypeError): + hash(m.Comparable(15)) # TypeError: unhashable type: 'm.Comparable' + + for hashable in (m.Hashable, m.Hashable2): + assert hashable(15) is not hashable(15) + assert hashable(15) == hashable(15) + + assert hash(hashable(15)) == 15 + assert hash(hashable(15)) == hash(hashable(15)) diff --git a/plugins/python/pybind11/tests/test_pickling.py b/plugins/python/pybind11/tests/test_pickling.py index 707d347..6b27a73 100644 --- a/plugins/python/pybind11/tests/test_pickling.py +++ b/plugins/python/pybind11/tests/test_pickling.py @@ -1,4 +1,8 @@ +# -*- coding: utf-8 -*- import pytest + +import env # noqa: F401 + from pybind11_tests import pickling as m try: @@ -21,7 +25,7 @@ def test_roundtrip(cls_name): assert p2.extra2() == p.extra2() -@pytest.unsupported_on_pypy +@pytest.mark.xfail("env.PYPY") @pytest.mark.parametrize("cls_name", ["PickleableWithDict", "PickleableWithDictNew"]) def test_roundtrip_with_dict(cls_name): cls = getattr(m, cls_name) @@ -34,3 +38,10 @@ def test_roundtrip_with_dict(cls_name): assert p2.value == p.value assert p2.extra == p.extra assert p2.dynamic == p.dynamic + + +def test_enum_pickle(): + from pybind11_tests import enums as e + + data = pickle.dumps(e.EOne, 2) + assert e.EOne == pickle.loads(data) diff --git a/plugins/python/pybind11/tests/test_pytypes.cpp b/plugins/python/pybind11/tests/test_pytypes.cpp index a962f0c..113cf5c 100644 --- a/plugins/python/pybind11/tests/test_pytypes.cpp +++ b/plugins/python/pybind11/tests/test_pytypes.cpp @@ -11,12 +11,20 @@ TEST_SUBMODULE(pytypes, m) { + // test_int + m.def("get_int", []{return py::int_(0);}); + // test_iterator + m.def("get_iterator", []{return py::iterator();}); + // test_iterable + m.def("get_iterable", []{return py::iterable();}); // test_list m.def("get_list", []() { py::list list; list.append("value"); py::print("Entry at position 0:", list[0]); list[0] = py::str("overwritten"); + list.insert(0, "inserted-0"); + list.insert(2, "inserted-2"); return list; }); m.def("print_list", [](py::list list) { @@ -24,6 +32,11 @@ TEST_SUBMODULE(pytypes, m) { for (auto item : list) py::print("list item {}: {}"_s.format(index++, item)); }); + // test_none + m.def("get_none", []{return py::none();}); + m.def("print_none", [](py::none none) { + py::print("none: {}"_s.format(none)); + }); // test_set m.def("get_set", []() { @@ -37,6 +50,12 @@ TEST_SUBMODULE(pytypes, m) { for (auto item : set) py::print("key:", item); }); + m.def("set_contains", [](py::set set, py::object key) { + return set.contains(key); + }); + m.def("set_contains", [](py::set set, const char* key) { + return set.contains(key); + }); // test_dict m.def("get_dict", []() { return py::dict("key"_a="value"); }); @@ -49,12 +68,19 @@ TEST_SUBMODULE(pytypes, m) { auto d2 = py::dict("z"_a=3, **d1); return d2; }); + m.def("dict_contains", [](py::dict dict, py::object val) { + return dict.contains(val); + }); + m.def("dict_contains", [](py::dict dict, const char* val) { + return dict.contains(val); + }); // test_str m.def("str_from_string", []() { return py::str(std::string("baz")); }); m.def("str_from_bytes", []() { return py::str(py::bytes("boo", 3)); }); m.def("str_from_object", [](const py::object& obj) { return py::str(obj); }); m.def("repr_from_object", [](const py::object& obj) { return py::repr(obj); }); + m.def("str_from_handle", [](py::handle h) { return py::str(h); }); m.def("str_format", []() { auto s1 = "{} + {} = {}"_s.format(1, 2, 3); @@ -82,7 +108,7 @@ TEST_SUBMODULE(pytypes, m) { }); m.def("return_capsule_with_name_and_destructor", []() { - auto capsule = py::capsule((void *) 1234, "pointer type description", [](PyObject *ptr) { + auto capsule = py::capsule((void *) 12345, "pointer type description", [](PyObject *ptr) { if (ptr) { auto name = PyCapsule_GetName(ptr); py::print("destructing capsule ({}, '{}')"_s.format( @@ -90,8 +116,19 @@ TEST_SUBMODULE(pytypes, m) { )); } }); - void *contents = capsule; - py::print("created capsule ({}, '{}')"_s.format((size_t) contents, capsule.name())); + + capsule.set_pointer((void *) 1234); + + // Using get_pointer() + void* contents1 = static_cast(capsule); + void* contents2 = capsule.get_pointer(); + void* contents3 = capsule.get_pointer(); + + auto result1 = reinterpret_cast(contents1); + auto result2 = reinterpret_cast(contents2); + auto result3 = reinterpret_cast(contents3); + + py::print("created capsule ({}, '{}')"_s.format(result1 & result2 & result3, capsule.name())); return capsule; }); @@ -102,7 +139,7 @@ TEST_SUBMODULE(pytypes, m) { d["basic_attr"] = o.attr("basic_attr"); auto l = py::list(); - for (const auto &item : o.attr("begin_end")) { + for (auto item : o.attr("begin_end")) { l.append(item); } d["begin_end"] = l; @@ -172,6 +209,7 @@ TEST_SUBMODULE(pytypes, m) { // test_constructors m.def("default_constructors", []() { return py::dict( + "bytes"_a=py::bytes(), "str"_a=py::str(), "bool"_a=py::bool_(), "int"_a=py::int_(), @@ -185,6 +223,7 @@ TEST_SUBMODULE(pytypes, m) { m.def("converting_constructors", [](py::dict d) { return py::dict( + "bytes"_a=py::bytes(d["bytes"]), "str"_a=py::str(d["str"]), "bool"_a=py::bool_(d["bool"]), "int"_a=py::int_(d["int"]), @@ -200,6 +239,7 @@ TEST_SUBMODULE(pytypes, m) { m.def("cast_functions", [](py::dict d) { // When converting between Python types, obj.cast() should be the same as T(obj) return py::dict( + "bytes"_a=d["bytes"].cast(), "str"_a=d["str"].cast(), "bool"_a=d["bool"].cast(), "int"_a=d["int"].cast(), @@ -212,6 +252,21 @@ TEST_SUBMODULE(pytypes, m) { ); }); + m.def("convert_to_pybind11_str", [](py::object o) { return py::str(o); }); + + m.def("nonconverting_constructor", [](std::string type, py::object value) -> py::object { + if (type == "bytes") { + return py::bytes(value); + } + else if (type == "none") { + return py::none(value); + } + else if (type == "ellipsis") { + return py::ellipsis(value); + } + throw std::runtime_error("Invalid type"); + }); + m.def("get_implicit_casting", []() { py::dict d; d["char*_i1"] = "abc"; @@ -258,7 +313,7 @@ TEST_SUBMODULE(pytypes, m) { py::print("no new line here", "end"_a=" -- "); py::print("next print"); - auto py_stderr = py::module::import("sys").attr("stderr"); + auto py_stderr = py::module_::import("sys").attr("stderr"); py::print("this goes to stderr", "file"_a=py_stderr); py::print("flush", "flush"_a=true); @@ -269,4 +324,90 @@ TEST_SUBMODULE(pytypes, m) { m.def("print_failure", []() { py::print(42, UnregisteredType()); }); m.def("hash_function", [](py::object obj) { return py::hash(obj); }); + + m.def("test_number_protocol", [](py::object a, py::object b) { + py::list l; + l.append(a.equal(b)); + l.append(a.not_equal(b)); + l.append(a < b); + l.append(a <= b); + l.append(a > b); + l.append(a >= b); + l.append(a + b); + l.append(a - b); + l.append(a * b); + l.append(a / b); + l.append(a | b); + l.append(a & b); + l.append(a ^ b); + l.append(a >> b); + l.append(a << b); + return l; + }); + + m.def("test_list_slicing", [](py::list a) { + return a[py::slice(0, -1, 2)]; + }); + + // See #2361 + m.def("issue2361_str_implicit_copy_none", []() { + py::str is_this_none = py::none(); + return is_this_none; + }); + m.def("issue2361_dict_implicit_copy_none", []() { + py::dict is_this_none = py::none(); + return is_this_none; + }); + + m.def("test_memoryview_object", [](py::buffer b) { + return py::memoryview(b); + }); + + m.def("test_memoryview_buffer_info", [](py::buffer b) { + return py::memoryview(b.request()); + }); + + m.def("test_memoryview_from_buffer", [](bool is_unsigned) { + static const int16_t si16[] = { 3, 1, 4, 1, 5 }; + static const uint16_t ui16[] = { 2, 7, 1, 8 }; + if (is_unsigned) + return py::memoryview::from_buffer( + ui16, { 4 }, { sizeof(uint16_t) }); + else + return py::memoryview::from_buffer( + si16, { 5 }, { sizeof(int16_t) }); + }); + + m.def("test_memoryview_from_buffer_nativeformat", []() { + static const char* format = "@i"; + static const int32_t arr[] = { 4, 7, 5 }; + return py::memoryview::from_buffer( + arr, sizeof(int32_t), format, { 3 }, { sizeof(int32_t) }); + }); + + m.def("test_memoryview_from_buffer_empty_shape", []() { + static const char* buf = ""; + return py::memoryview::from_buffer(buf, 1, "B", { }, { }); + }); + + m.def("test_memoryview_from_buffer_invalid_strides", []() { + static const char* buf = "\x02\x03\x04"; + return py::memoryview::from_buffer(buf, 1, "B", { 3 }, { }); + }); + + m.def("test_memoryview_from_buffer_nullptr", []() { + return py::memoryview::from_buffer( + static_cast(nullptr), 1, "B", { }, { }); + }); + +#if PY_MAJOR_VERSION >= 3 + m.def("test_memoryview_from_memory", []() { + const char* buf = "\xff\xe1\xab\x37"; + return py::memoryview::from_memory( + buf, static_cast(strlen(buf))); + }); +#endif + + // test_builtin_functions + m.def("get_len", [](py::handle h) { return py::len(h); }); } diff --git a/plugins/python/pybind11/tests/test_pytypes.py b/plugins/python/pybind11/tests/test_pytypes.py index 992e7fc..9e5c302 100644 --- a/plugins/python/pybind11/tests/test_pytypes.py +++ b/plugins/python/pybind11/tests/test_pytypes.py @@ -1,27 +1,53 @@ +# -*- coding: utf-8 -*- +from __future__ import division import pytest import sys +import env # noqa: F401 + from pybind11_tests import pytypes as m from pybind11_tests import debug_enabled +def test_int(doc): + assert doc(m.get_int) == "get_int() -> int" + + +def test_iterator(doc): + assert doc(m.get_iterator) == "get_iterator() -> Iterator" + + +def test_iterable(doc): + assert doc(m.get_iterable) == "get_iterable() -> Iterable" + + def test_list(capture, doc): with capture: lst = m.get_list() - assert lst == ["overwritten"] + assert lst == ["inserted-0", "overwritten", "inserted-2"] lst.append("value2") m.print_list(lst) - assert capture.unordered == """ + assert ( + capture.unordered + == """ Entry at position 0: value - list item 0: overwritten - list item 1: value2 + list item 0: inserted-0 + list item 1: overwritten + list item 2: inserted-2 + list item 3: value2 """ + ) assert doc(m.get_list) == "get_list() -> list" assert doc(m.print_list) == "print_list(arg0: list) -> None" +def test_none(capture, doc): + assert doc(m.get_none) == "get_none() -> None" + assert doc(m.print_none) == "print_none(arg0: None) -> None" + + def test_set(capture, doc): s = m.get_set() assert s == {"key1", "key2", "key3"} @@ -29,12 +55,19 @@ def test_set(capture, doc): with capture: s.add("key4") m.print_set(s) - assert capture.unordered == """ + assert ( + capture.unordered + == """ key: key1 key: key2 key: key3 key: key4 """ + ) + + assert not m.set_contains(set([]), 42) + assert m.set_contains({42}, 42) + assert m.set_contains({"foo"}, "foo") assert doc(m.get_list) == "get_list() -> list" assert doc(m.print_list) == "print_list(arg0: list) -> None" @@ -47,10 +80,17 @@ def test_dict(capture, doc): with capture: d["key2"] = "value2" m.print_dict(d) - assert capture.unordered == """ + assert ( + capture.unordered + == """ key: key, value=value key: key2, value=value2 """ + ) + + assert not m.dict_contains({}, 42) + assert m.dict_contains({42: None}, 42) + assert m.dict_contains({"foo": None}, "foo") assert doc(m.get_dict) == "get_dict() -> dict" assert doc(m.print_dict) == "print_dict(arg0: dict) -> None" @@ -73,18 +113,30 @@ def __repr__(self): assert m.str_from_object(A()) == "this is a str" assert m.repr_from_object(A()) == "this is a repr" + assert m.str_from_handle(A()) == "this is a str" s1, s2 = m.str_format() assert s1 == "1 + 2 = 3" assert s1 == s2 + malformed_utf8 = b"\x80" + assert m.str_from_object(malformed_utf8) is malformed_utf8 # To be fixed; see #2380 + if env.PY2: + # with pytest.raises(UnicodeDecodeError): + # m.str_from_object(malformed_utf8) + with pytest.raises(UnicodeDecodeError): + m.str_from_handle(malformed_utf8) + else: + # assert m.str_from_object(malformed_utf8) == "b'\\x80'" + assert m.str_from_handle(malformed_utf8) == "b'\\x80'" + def test_bytes(doc): assert m.bytes_from_string().decode() == "foo" assert m.bytes_from_str().decode() == "bar" assert doc(m.bytes_from_str) == "bytes_from_str() -> {}".format( - "bytes" if sys.version_info[0] == 3 else "str" + "str" if env.PY2 else "bytes" ) @@ -94,28 +146,37 @@ def test_capsule(capture): a = m.return_capsule_with_destructor() del a pytest.gc_collect() - assert capture.unordered == """ + assert ( + capture.unordered + == """ creating capsule destructing capsule """ + ) with capture: a = m.return_capsule_with_destructor_2() del a pytest.gc_collect() - assert capture.unordered == """ + assert ( + capture.unordered + == """ creating capsule destructing capsule: 1234 """ + ) with capture: a = m.return_capsule_with_name_and_destructor() del a pytest.gc_collect() - assert capture.unordered == """ + assert ( + capture.unordered + == """ created capsule (1234, 'pointer type description') destructing capsule (1234, 'pointer type description') """ + ) def test_accessors(): @@ -159,11 +220,17 @@ def func(self, x, *args): def test_constructors(): """C++ default and converting constructors are equivalent to type calls in Python""" - types = [str, bool, int, float, tuple, list, dict, set] + types = [bytes, str, bool, int, float, tuple, list, dict, set] expected = {t.__name__: t() for t in types} + if env.PY2: + # Note that bytes.__name__ == 'str' in Python 2. + # pybind11::str is unicode even under Python 2. + expected["bytes"] = bytes() + expected["str"] = unicode() # noqa: F821 assert m.default_constructors() == expected data = { + bytes: b"41", # Currently no supported or working conversions. str: 42, bool: "Not empty", int: "42", @@ -172,10 +239,15 @@ def test_constructors(): list: range(3), dict: [("two", 2), ("one", 1), ("three", 3)], set: [4, 4, 5, 6, 6, 6], - memoryview: b'abc' + memoryview: b"abc", } inputs = {k.__name__: v for k, v in data.items()} expected = {k.__name__: k(v) for k, v in data.items()} + if env.PY2: # Similar to the above. See comments above. + inputs["bytes"] = b"41" + inputs["str"] = 42 + expected["bytes"] = b"41" + expected["str"] = u"42" assert m.converting_constructors(inputs) == expected assert m.cast_functions(inputs) == expected @@ -191,21 +263,79 @@ def test_constructors(): assert noconv2[k] is expected[k] +def test_non_converting_constructors(): + non_converting_test_cases = [ + ("bytes", range(10)), + ("none", 42), + ("ellipsis", 42), + ] + for t, v in non_converting_test_cases: + with pytest.raises(TypeError) as excinfo: + m.nonconverting_constructor(t, v) + expected_error = "Object of type '{}' is not an instance of '{}'".format( + type(v).__name__, t + ) + assert str(excinfo.value) == expected_error + + +def test_pybind11_str_raw_str(): + # specifically to exercise pybind11::str::raw_str + cvt = m.convert_to_pybind11_str + assert cvt(u"Str") == u"Str" + assert cvt(b"Bytes") == u"Bytes" if env.PY2 else "b'Bytes'" + assert cvt(None) == u"None" + assert cvt(False) == u"False" + assert cvt(True) == u"True" + assert cvt(42) == u"42" + assert cvt(2 ** 65) == u"36893488147419103232" + assert cvt(-1.50) == u"-1.5" + assert cvt(()) == u"()" + assert cvt((18,)) == u"(18,)" + assert cvt([]) == u"[]" + assert cvt([28]) == u"[28]" + assert cvt({}) == u"{}" + assert cvt({3: 4}) == u"{3: 4}" + assert cvt(set()) == u"set([])" if env.PY2 else "set()" + assert cvt({3, 3}) == u"set([3])" if env.PY2 else "{3}" + + valid_orig = u"DZ" + valid_utf8 = valid_orig.encode("utf-8") + valid_cvt = cvt(valid_utf8) + assert type(valid_cvt) == bytes # Probably surprising. + assert valid_cvt == b"\xc7\xb1" + + malformed_utf8 = b"\x80" + malformed_cvt = cvt(malformed_utf8) + assert type(malformed_cvt) == bytes # Probably surprising. + assert malformed_cvt == b"\x80" + + def test_implicit_casting(): """Tests implicit casting when assigning or appending to dicts and lists.""" z = m.get_implicit_casting() - assert z['d'] == { - 'char*_i1': 'abc', 'char*_i2': 'abc', 'char*_e': 'abc', 'char*_p': 'abc', - 'str_i1': 'str', 'str_i2': 'str1', 'str_e': 'str2', 'str_p': 'str3', - 'int_i1': 42, 'int_i2': 42, 'int_e': 43, 'int_p': 44 + assert z["d"] == { + "char*_i1": "abc", + "char*_i2": "abc", + "char*_e": "abc", + "char*_p": "abc", + "str_i1": "str", + "str_i2": "str1", + "str_e": "str2", + "str_p": "str3", + "int_i1": 42, + "int_i2": 42, + "int_e": 43, + "int_p": 44, } - assert z['l'] == [3, 6, 9, 12, 15] + assert z["l"] == [3, 6, 9, 12, 15] def test_print(capture): with capture: m.print_function() - assert capture == """ + assert ( + capture + == """ Hello, World! 1 2.0 three True -- multiple args *args-and-a-custom-separator @@ -213,14 +343,15 @@ def test_print(capture): flush py::print + str.format = this """ + ) assert capture.stderr == "this goes to stderr" with pytest.raises(RuntimeError) as excinfo: m.print_failure() assert str(excinfo.value) == "make_tuple(): unable to convert " + ( "argument of type 'UnregisteredType' to Python object" - if debug_enabled else - "arguments to Python object (compile in debug mode for details)" + if debug_enabled + else "arguments to Python object (compile in debug mode for details)" ) @@ -238,3 +369,120 @@ class Unhashable(object): assert m.hash_function(Hashable(42)) == 42 with pytest.raises(TypeError): m.hash_function(Unhashable()) + + +def test_number_protocol(): + for a, b in [(1, 1), (3, 5)]: + li = [ + a == b, + a != b, + a < b, + a <= b, + a > b, + a >= b, + a + b, + a - b, + a * b, + a / b, + a | b, + a & b, + a ^ b, + a >> b, + a << b, + ] + assert m.test_number_protocol(a, b) == li + + +def test_list_slicing(): + li = list(range(100)) + assert li[::2] == m.test_list_slicing(li) + + +def test_issue2361(): + # See issue #2361 + assert m.issue2361_str_implicit_copy_none() == "None" + with pytest.raises(TypeError) as excinfo: + assert m.issue2361_dict_implicit_copy_none() + assert "'NoneType' object is not iterable" in str(excinfo.value) + + +@pytest.mark.parametrize( + "method, args, fmt, expected_view", + [ + (m.test_memoryview_object, (b"red",), "B", b"red"), + (m.test_memoryview_buffer_info, (b"green",), "B", b"green"), + (m.test_memoryview_from_buffer, (False,), "h", [3, 1, 4, 1, 5]), + (m.test_memoryview_from_buffer, (True,), "H", [2, 7, 1, 8]), + (m.test_memoryview_from_buffer_nativeformat, (), "@i", [4, 7, 5]), + ], +) +def test_memoryview(method, args, fmt, expected_view): + view = method(*args) + assert isinstance(view, memoryview) + assert view.format == fmt + if isinstance(expected_view, bytes) or not env.PY2: + view_as_list = list(view) + else: + # Using max to pick non-zero byte (big-endian vs little-endian). + view_as_list = [max([ord(c) for c in s]) for s in view] + assert view_as_list == list(expected_view) + + +@pytest.mark.xfail("env.PYPY", reason="getrefcount is not available") +@pytest.mark.parametrize( + "method", + [ + m.test_memoryview_object, + m.test_memoryview_buffer_info, + ], +) +def test_memoryview_refcount(method): + buf = b"\x0a\x0b\x0c\x0d" + ref_before = sys.getrefcount(buf) + view = method(buf) + ref_after = sys.getrefcount(buf) + assert ref_before < ref_after + assert list(view) == list(buf) + + +def test_memoryview_from_buffer_empty_shape(): + view = m.test_memoryview_from_buffer_empty_shape() + assert isinstance(view, memoryview) + assert view.format == "B" + if env.PY2: + # Python 2 behavior is weird, but Python 3 (the future) is fine. + # PyPy3 has #include +#include + template class NonZeroIterator { const T* ptr_; @@ -71,6 +73,25 @@ py::list test_random_access_iterator(PythonType x) { } TEST_SUBMODULE(sequences_and_iterators, m) { + // test_sliceable + class Sliceable{ + public: + Sliceable(int n): size(n) {} + int start,stop,step; + int size; + }; + py::class_(m,"Sliceable") + .def(py::init()) + .def("__getitem__",[](const Sliceable &s, py::slice slice) { + py::ssize_t start, stop, step, slicelength; + if (!slice.compute(s.size, &start, &stop, &step, &slicelength)) + throw py::error_already_set(); + int istart = static_cast(start); + int istop = static_cast(stop); + int istep = static_cast(step); + return std::make_tuple(istart,istop,istep); + }) + ; // test_sequence class Sequence { @@ -179,7 +200,7 @@ TEST_SUBMODULE(sequences_and_iterators, m) { size_t start, stop, step, slicelength; if (!slice.compute(s.size(), &start, &stop, &step, &slicelength)) throw py::error_already_set(); - Sequence *seq = new Sequence(slicelength); + auto *seq = new Sequence(slicelength); for (size_t i = 0; i < slicelength; ++i) { (*seq)[i] = s[start]; start += step; } @@ -300,6 +321,9 @@ TEST_SUBMODULE(sequences_and_iterators, m) { return l; }); + // test_sequence_length: check that Python sequences can be converted to py::sequence. + m.def("sequence_length", [](py::sequence seq) { return seq.size(); }); + // Make sure that py::iterator works with std algorithms m.def("count_none", [](py::object o) { return std::count_if(o.begin(), o.end(), [](py::handle h) { return h.is_none(); }); diff --git a/plugins/python/pybind11/tests/test_sequences_and_iterators.py b/plugins/python/pybind11/tests/test_sequences_and_iterators.py index f6c0620..c3b608c 100644 --- a/plugins/python/pybind11/tests/test_sequences_and_iterators.py +++ b/plugins/python/pybind11/tests/test_sequences_and_iterators.py @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- import pytest from pybind11_tests import sequences_and_iterators as m from pybind11_tests import ConstructorStats @@ -9,7 +10,9 @@ def isclose(a, b, rel_tol=1e-05, abs_tol=0.0): def allclose(a_list, b_list, rel_tol=1e-05, abs_tol=0.0): - return all(isclose(a, b, rel_tol=rel_tol, abs_tol=abs_tol) for a, b in zip(a_list, b_list)) + return all( + isclose(a, b, rel_tol=rel_tol, abs_tol=abs_tol) for a, b in zip(a_list, b_list) + ) def test_generalized_iterators(): @@ -33,11 +36,24 @@ def test_generalized_iterators(): next(it) +def test_sliceable(): + sliceable = m.Sliceable(100) + assert sliceable[::] == (0, 100, 1) + assert sliceable[10::] == (10, 100, 1) + assert sliceable[:10:] == (0, 10, 1) + assert sliceable[::10] == (0, 100, 10) + assert sliceable[-10::] == (90, 100, 1) + assert sliceable[:-10:] == (0, 90, 1) + assert sliceable[::-10] == (99, -1, -10) + assert sliceable[50:60:1] == (50, 60, 1) + assert sliceable[50:60:-1] == (50, 60, -1) + + def test_sequence(): cstats = ConstructorStats.get(m.Sequence) s = m.Sequence(5) - assert cstats.values() == ['of size', '5'] + assert cstats.values() == ["of size", "5"] assert "Sequence" in repr(s) assert len(s) == 5 @@ -48,16 +64,16 @@ def test_sequence(): assert isclose(s[0], 12.34) and isclose(s[3], 56.78) rev = reversed(s) - assert cstats.values() == ['of size', '5'] + assert cstats.values() == ["of size", "5"] rev2 = s[::-1] - assert cstats.values() == ['of size', '5'] + assert cstats.values() == ["of size", "5"] it = iter(m.Sequence(0)) for _ in range(3): # __next__ must continue to raise StopIteration with pytest.raises(StopIteration): next(it) - assert cstats.values() == ['of size', '0'] + assert cstats.values() == ["of size", "0"] expected = [0, 56.78, 0, 0, 12.34] assert allclose(rev, expected) @@ -65,7 +81,7 @@ def test_sequence(): assert rev == rev2 rev[0::2] = m.Sequence([2.0, 2.0, 2.0]) - assert cstats.values() == ['of size', '3', 'from std::vector'] + assert cstats.values() == ["of size", "3", "from std::vector"] assert allclose(rev, [2, 56.78, 2, 0, 2]) @@ -87,18 +103,38 @@ def test_sequence(): assert cstats.move_assignments == 0 +def test_sequence_length(): + """#2076: Exception raised by len(arg) should be propagated """ + + class BadLen(RuntimeError): + pass + + class SequenceLike: + def __getitem__(self, i): + return None + + def __len__(self): + raise BadLen() + + with pytest.raises(BadLen): + m.sequence_length(SequenceLike()) + + assert m.sequence_length([1, 2, 3]) == 3 + assert m.sequence_length("hello") == 5 + + def test_map_iterator(): - sm = m.StringMap({'hi': 'bye', 'black': 'white'}) - assert sm['hi'] == 'bye' + sm = m.StringMap({"hi": "bye", "black": "white"}) + assert sm["hi"] == "bye" assert len(sm) == 2 - assert sm['black'] == 'white' + assert sm["black"] == "white" with pytest.raises(KeyError): - assert sm['orange'] - sm['orange'] = 'banana' - assert sm['orange'] == 'banana' + assert sm["orange"] + sm["orange"] = "banana" + assert sm["orange"] == "banana" - expected = {'hi': 'bye', 'black': 'white', 'orange': 'banana'} + expected = {"hi": "bye", "black": "white", "orange": "banana"} for k in sm: assert sm[k] == expected[k] for k, v in sm.items(): @@ -146,7 +182,8 @@ def test_iterator_passthrough(): """#181: iterator passthrough did not compile""" from pybind11_tests.sequences_and_iterators import iterator_passthrough - assert list(iterator_passthrough(iter([3, 5, 7, 9, 11, 13, 15]))) == [3, 5, 7, 9, 11, 13, 15] + values = [3, 5, 7, 9, 11, 13, 15] + assert list(iterator_passthrough(iter(values))) == values def test_iterator_rvp(): diff --git a/plugins/python/pybind11/tests/test_smart_ptr.cpp b/plugins/python/pybind11/tests/test_smart_ptr.cpp index 204e85f..60c2e69 100644 --- a/plugins/python/pybind11/tests/test_smart_ptr.cpp +++ b/plugins/python/pybind11/tests/test_smart_ptr.cpp @@ -27,7 +27,8 @@ namespace pybind11 { namespace detail { struct holder_helper> { static const T *get(const ref &p) { return p.get_ptr(); } }; -}} +} // namespace detail +} // namespace pybind11 // The following is not required anymore for std::shared_ptr, but it should compile without error: PYBIND11_DECLARE_HOLDER_TYPE(T, std::shared_ptr); @@ -97,9 +98,9 @@ TEST_SUBMODULE(smart_ptr, m) { class MyObject1 : public Object { public: MyObject1(int value) : value(value) { print_created(this, toString()); } - std::string toString() const { return "MyObject1[" + std::to_string(value) + "]"; } + std::string toString() const override { return "MyObject1[" + std::to_string(value) + "]"; } protected: - virtual ~MyObject1() { print_destroyed(this); } + ~MyObject1() override { print_destroyed(this); } private: int value; }; @@ -127,6 +128,7 @@ TEST_SUBMODULE(smart_ptr, m) { // Object managed by a std::shared_ptr<> class MyObject2 { public: + MyObject2(const MyObject2 &) = default; MyObject2(int value) : value(value) { print_created(this, toString()); } std::string toString() const { return "MyObject2[" + std::to_string(value) + "]"; } virtual ~MyObject2() { print_destroyed(this); } @@ -145,6 +147,7 @@ TEST_SUBMODULE(smart_ptr, m) { // Object managed by a std::shared_ptr<>, additionally derives from std::enable_shared_from_this<> class MyObject3 : public std::enable_shared_from_this { public: + MyObject3(const MyObject3 &) = default; MyObject3(int value) : value(value) { print_created(this, toString()); } std::string toString() const { return "MyObject3[" + std::to_string(value) + "]"; } virtual ~MyObject3() { print_destroyed(this); } @@ -184,6 +187,32 @@ TEST_SUBMODULE(smart_ptr, m) { .def(py::init()) .def_readwrite("value", &MyObject4::value); + // test_unique_deleter + // Object with std::unique_ptr where D is not matching the base class + // Object with a protected destructor + class MyObject4a { + public: + MyObject4a(int i) { + value = i; + print_created(this); + }; + int value; + protected: + virtual ~MyObject4a() { print_destroyed(this); } + }; + py::class_>(m, "MyObject4a") + .def(py::init()) + .def_readwrite("value", &MyObject4a::value); + + // Object derived but with public destructor and no Deleter in default holder + class MyObject4b : public MyObject4a { + public: + MyObject4b(int i) : MyObject4a(i) { print_created(this); } + ~MyObject4b() override { print_destroyed(this); } + }; + py::class_(m, "MyObject4b") + .def(py::init()); + // test_large_holder class MyObject5 { // managed by huge_unique_ptr public: @@ -248,6 +277,8 @@ TEST_SUBMODULE(smart_ptr, m) { // Issue #865: shared_from_this doesn't work with virtual inheritance struct SharedFromThisVBase : std::enable_shared_from_this { + SharedFromThisVBase() = default; + SharedFromThisVBase(const SharedFromThisVBase &) = default; virtual ~SharedFromThisVBase() = default; }; struct SharedFromThisVirt : virtual SharedFromThisVBase {}; @@ -261,7 +292,8 @@ TEST_SUBMODULE(smart_ptr, m) { ~C() { print_destroyed(this); } }; py::class_>(m, "TypeWithMoveOnlyHolder") - .def_static("make", []() { return custom_unique_ptr(new C); }); + .def_static("make", []() { return custom_unique_ptr(new C); }) + .def_static("make_as_object", []() { return py::cast(custom_unique_ptr(new C)); }); // test_holder_with_addressof_operator struct TypeForHolderWithAddressOf { @@ -306,7 +338,11 @@ TEST_SUBMODULE(smart_ptr, m) { // test_shared_ptr_gc // #187: issue involving std::shared_ptr<> return value policy & garbage collection - struct ElementBase { virtual void foo() { } /* Force creation of virtual table */ }; + struct ElementBase { + virtual ~ElementBase() = default; /* Force creation of virtual table */ + ElementBase() = default; + ElementBase(const ElementBase&) = delete; + }; py::class_>(m, "ElementBase"); struct ElementA : ElementBase { diff --git a/plugins/python/pybind11/tests/test_smart_ptr.py b/plugins/python/pybind11/tests/test_smart_ptr.py index 60f48b3..c55bffb 100644 --- a/plugins/python/pybind11/tests/test_smart_ptr.py +++ b/plugins/python/pybind11/tests/test_smart_ptr.py @@ -1,11 +1,15 @@ +# -*- coding: utf-8 -*- import pytest -from pybind11_tests import smart_ptr as m -from pybind11_tests import ConstructorStats + +m = pytest.importorskip("pybind11_tests.smart_ptr") +from pybind11_tests import ConstructorStats # noqa: E402 def test_smart_ptr(capture): # Object1 - for i, o in enumerate([m.make_object_1(), m.make_object_2(), m.MyObject1(3)], start=1): + for i, o in enumerate( + [m.make_object_1(), m.make_object_2(), m.MyObject1(3)], start=1 + ): assert o.getRefCount() == 1 with capture: m.print_object_1(o) @@ -14,8 +18,9 @@ def test_smart_ptr(capture): m.print_object_4(o) assert capture == "MyObject1[{i}]\n".format(i=i) * 4 - for i, o in enumerate([m.make_myobject1_1(), m.make_myobject1_2(), m.MyObject1(6), 7], - start=4): + for i, o in enumerate( + [m.make_myobject1_1(), m.make_myobject1_2(), m.MyObject1(6), 7], start=4 + ): print(o) with capture: if not isinstance(o, int): @@ -27,11 +32,15 @@ def test_smart_ptr(capture): m.print_myobject1_2(o) m.print_myobject1_3(o) m.print_myobject1_4(o) - assert capture == "MyObject1[{i}]\n".format(i=i) * (4 if isinstance(o, int) else 8) + + times = 4 if isinstance(o, int) else 8 + assert capture == "MyObject1[{i}]\n".format(i=i) * times cstats = ConstructorStats.get(m.MyObject1) assert cstats.alive() == 0 - expected_values = ['MyObject1[{}]'.format(i) for i in range(1, 7)] + ['MyObject1[7]'] * 4 + expected_values = ["MyObject1[{}]".format(i) for i in range(1, 7)] + [ + "MyObject1[7]" + ] * 4 assert cstats.values() == expected_values assert cstats.default_constructions == 0 assert cstats.copy_constructions == 0 @@ -40,7 +49,9 @@ def test_smart_ptr(capture): assert cstats.move_assignments == 0 # Object2 - for i, o in zip([8, 6, 7], [m.MyObject2(8), m.make_myobject2_1(), m.make_myobject2_2()]): + for i, o in zip( + [8, 6, 7], [m.MyObject2(8), m.make_myobject2_1(), m.make_myobject2_2()] + ): print(o) with capture: m.print_myobject2_1(o) @@ -53,7 +64,7 @@ def test_smart_ptr(capture): assert cstats.alive() == 1 o = None assert cstats.alive() == 0 - assert cstats.values() == ['MyObject2[8]', 'MyObject2[6]', 'MyObject2[7]'] + assert cstats.values() == ["MyObject2[8]", "MyObject2[6]", "MyObject2[7]"] assert cstats.default_constructions == 0 assert cstats.copy_constructions == 0 # assert cstats.move_constructions >= 0 # Doesn't invoke any @@ -61,7 +72,9 @@ def test_smart_ptr(capture): assert cstats.move_assignments == 0 # Object3 - for i, o in zip([9, 8, 9], [m.MyObject3(9), m.make_myobject3_1(), m.make_myobject3_2()]): + for i, o in zip( + [9, 8, 9], [m.MyObject3(9), m.make_myobject3_1(), m.make_myobject3_2()] + ): print(o) with capture: m.print_myobject3_1(o) @@ -74,7 +87,7 @@ def test_smart_ptr(capture): assert cstats.alive() == 1 o = None assert cstats.alive() == 0 - assert cstats.values() == ['MyObject3[9]', 'MyObject3[8]', 'MyObject3[9]'] + assert cstats.values() == ["MyObject3[9]", "MyObject3[8]", "MyObject3[9]"] assert cstats.default_constructions == 0 assert cstats.copy_constructions == 0 # assert cstats.move_constructions >= 0 # Doesn't invoke any @@ -94,7 +107,7 @@ def test_smart_ptr(capture): # ref<> cstats = m.cstats_ref() assert cstats.alive() == 0 - assert cstats.values() == ['from pointer'] * 10 + assert cstats.values() == ["from pointer"] * 10 assert cstats.default_constructions == 30 assert cstats.copy_constructions == 12 # assert cstats.move_constructions >= 0 # Doesn't invoke any @@ -115,6 +128,27 @@ def test_unique_nodelete(): assert cstats.alive() == 1 # Leak, but that's intentional +def test_unique_nodelete4a(): + o = m.MyObject4a(23) + assert o.value == 23 + cstats = ConstructorStats.get(m.MyObject4a) + assert cstats.alive() == 1 + del o + assert cstats.alive() == 1 # Leak, but that's intentional + + +def test_unique_deleter(): + o = m.MyObject4b(23) + assert o.value == 23 + cstats4a = ConstructorStats.get(m.MyObject4a) + assert cstats4a.alive() == 2 # Two because of previous test + cstats4b = ConstructorStats.get(m.MyObject4b) + assert cstats4b.alive() == 1 + del o + assert cstats4a.alive() == 1 # Should now only be one leftover from previous test + assert cstats4b.alive() == 0 # Should be deleted + + def test_large_holder(): o = m.MyObject5(5) assert o.value == 5 @@ -163,7 +197,9 @@ def test_shared_ptr_from_this_and_references(): ref = s.ref # init_holder_helper(holder_ptr=false, owned=false, bad_wp=false) assert stats.alive() == 2 assert s.set_ref(ref) - assert s.set_holder(ref) # std::enable_shared_from_this can create a holder from a reference + assert s.set_holder( + ref + ) # std::enable_shared_from_this can create a holder from a reference bad_wp = s.bad_wp # init_holder_helper(holder_ptr=false, owned=false, bad_wp=true) assert stats.alive() == 2 @@ -177,12 +213,16 @@ def test_shared_ptr_from_this_and_references(): assert s.set_ref(copy) assert s.set_holder(copy) - holder_ref = s.holder_ref # init_holder_helper(holder_ptr=true, owned=false, bad_wp=false) + holder_ref = ( + s.holder_ref + ) # init_holder_helper(holder_ptr=true, owned=false, bad_wp=false) assert stats.alive() == 3 assert s.set_ref(holder_ref) assert s.set_holder(holder_ref) - holder_copy = s.holder_copy # init_holder_helper(holder_ptr=true, owned=true, bad_wp=false) + holder_copy = ( + s.holder_copy + ) # init_holder_helper(holder_ptr=true, owned=true, bad_wp=false) assert stats.alive() == 3 assert s.set_ref(holder_copy) assert s.set_holder(holder_copy) @@ -197,7 +237,10 @@ def test_shared_ptr_from_this_and_references(): def test_move_only_holder(): a = m.TypeWithMoveOnlyHolder.make() + b = m.TypeWithMoveOnlyHolder.make_as_object() stats = ConstructorStats.get(m.TypeWithMoveOnlyHolder) + assert stats.alive() == 2 + del b assert stats.alive() == 1 del a assert stats.alive() == 0 @@ -251,7 +294,10 @@ def test_smart_ptr_from_default(): instance = m.HeldByDefaultHolder() with pytest.raises(RuntimeError) as excinfo: m.HeldByDefaultHolder.load_shared_ptr(instance) - assert "Unable to load a custom holder type from a default-holder instance" in str(excinfo) + assert ( + "Unable to load a custom holder type from a " + "default-holder instance" in str(excinfo.value) + ) def test_shared_ptr_gc(): diff --git a/plugins/python/pybind11/tests/test_stl.cpp b/plugins/python/pybind11/tests/test_stl.cpp index cd0985d..0590162 100644 --- a/plugins/python/pybind11/tests/test_stl.cpp +++ b/plugins/python/pybind11/tests/test_stl.cpp @@ -11,8 +11,11 @@ #include "constructor_stats.h" #include +#include +#include + // Test with `std::variant` in C++17 mode, or with `boost::variant` in C++11/14 -#if PYBIND11_HAS_VARIANT +#if defined(PYBIND11_HAS_VARIANT) using std::variant; #elif defined(PYBIND11_TEST_BOOST) && (!defined(_MSC_VER) || _MSC_VER >= 1910) # include @@ -33,6 +36,8 @@ struct visit_helper { }} // namespace pybind11::detail #endif +PYBIND11_MAKE_OPAQUE(std::vector>); + /// Issue #528: templated constructor struct TplCtorClass { template TplCtorClass(const T &) { } @@ -42,7 +47,18 @@ struct TplCtorClass { namespace std { template <> struct hash { size_t operator()(const TplCtorClass &) const { return 0; } }; -} +} // namespace std + + +template