aboutsummaryrefslogtreecommitdiff
path: root/lumina-search/main.cpp
diff options
context:
space:
mode:
authorKen Moore <ken@pcbsd.org>2015-04-27 15:07:28 -0400
committerKen Moore <ken@pcbsd.org>2015-04-27 15:07:28 -0400
commitd590979dba8ee6f23d91b1c0b1b8e092c4e68454 (patch)
tree6e6807820f2394764615e7788ee68d82baa75f91 /lumina-search/main.cpp
parentSetup the lumina-desktop to use the new favorites system: (diff)
parentAdd two new keybard shortcuts to the default Fluxbox setting: (diff)
downloadlumina-d590979dba8ee6f23d91b1c0b1b8e092c4e68454.tar.gz
lumina-d590979dba8ee6f23d91b1c0b1b8e092c4e68454.tar.bz2
lumina-d590979dba8ee6f23d91b1c0b1b8e092c4e68454.zip
Merge branch 'master' of github.com:pcbsd/lumina
Diffstat (limited to 'lumina-search/main.cpp')
-rw-r--r--lumina-search/main.cpp44
1 files changed, 44 insertions, 0 deletions
diff --git a/lumina-search/main.cpp b/lumina-search/main.cpp
index 305c388b..f03bf04a 100644
--- a/lumina-search/main.cpp
+++ b/lumina-search/main.cpp
@@ -8,6 +8,12 @@
#include <LuminaThemes.h>
#include <LuminaUtils.h>
+//==== INPUT FORMAT ====
+// lumina-search [-no-excludes] [-dir [directory]] [-search <term>]
+// -no-excludes: Don't exclude anything from this search
+// -dir [directory]: Setup a file/dir search within the current working dir (or specified dir)
+// -search <term>: Start a search with the given term
+//===================
int main(int argc, char ** argv)
{
//qDebug() << "Init App...";
@@ -21,6 +27,44 @@ int main(int argc, char ** argv)
MainUI w;
QObject::connect(&theme,SIGNAL(updateIcons()), &w, SLOT(setupIcons()) );
w.show();
+ if(argc>1){
+ bool startsearch = false;
+ for(int i=1; i<argc; i++){
+ QString val = QString(argv[i]).toLower();
+ if( val == "-no-excludes"){ w.disableExcludes(); }
+ else if(val=="-dir"){
+ //Check the next input value for a directory path
+ QString dir;
+ if( argc>(i+1) ){ dir = QString(argv[i+1]); }
+ //Check the input for validity
+ if(dir.startsWith("-")){dir.clear(); } //not a directory, just another input
+ else if(!dir.startsWith("/")){ //not an absolute path
+ dir = QDir::currentPath()+"/"+dir;
+ QFileInfo info(dir);
+ if( !info.exists() || !info.isDir() ){ dir.clear(); } //invalid relative dir
+ }
+
+ if(dir.isEmpty()){ dir= QDir::currentPath(); } //use the current directory
+ else{ i++; } //using the next input value - skip it for the next iteration
+ w.setSearchDirectory( dir );
+
+ }else if(val=="-search"){
+ //Check the next input value for a text string
+ QString text;
+ if( argc>(i+1) ){ text = QString(argv[i+1]); }
+ //Check the input for validity
+ if( !text.isEmpty() ){
+ i++; //using the next input value - skip it for the next iteration
+ w.setSearchTerm( text );
+ startsearch = true;
+ }
+ }
+ }//end loop over inputs
+ if(startsearch){
+ //A CLI search was requested, go ahead and start it now
+ QTimer::singleShot(10, &w, SLOT(startSearch()));
+ }
+ } //end check for input arguments
return a.exec();
}
bgstack15