mirror of
https://github.com/davatorium/rofi.git
synced 2025-02-10 15:44:41 -05:00
Removing duplicate code, small fixes.
This commit is contained in:
parent
2bfc2fff4b
commit
b9c192c4fe
7 changed files with 37 additions and 95 deletions
6
Makefile
6
Makefile
|
@ -78,9 +78,9 @@ $(BUILD_DIR):
|
||||||
$(QUIET)mkdir -p $@/$(CONFIG_DIR)
|
$(QUIET)mkdir -p $@/$(CONFIG_DIR)
|
||||||
|
|
||||||
# Objects depend on header files and makefile too.
|
# Objects depend on header files and makefile too.
|
||||||
$(BUILD_DIR)/%.o: %.c | Makefile $(HEADERS) $(BUILD_DIR)
|
$(BUILD_DIR)/%.o: %.c Makefile $(HEADERS) | $(BUILD_DIR)
|
||||||
$(info Compiling $^ -> $@)
|
$(info Compiling $< -> $@)
|
||||||
$(QUIET) $(CC) $(CFLAGS) -c -o $@ $^
|
$(QUIET) $(CC) $(CFLAGS) -c -o $@ $<
|
||||||
|
|
||||||
$(BUILD_DIR)/$(PROGRAM): $(OBJECTS)
|
$(BUILD_DIR)/$(PROGRAM): $(OBJECTS)
|
||||||
$(info Linking $@)
|
$(info Linking $@)
|
||||||
|
|
|
@ -104,4 +104,9 @@ typedef struct _Settings {
|
||||||
} Settings;
|
} Settings;
|
||||||
|
|
||||||
extern Settings config;
|
extern Settings config;
|
||||||
|
|
||||||
|
|
||||||
|
int token_match ( char **tokens, const char *input,
|
||||||
|
__attribute__( ( unused ) )int index,
|
||||||
|
__attribute__( ( unused ) )void *data );
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -27,16 +27,12 @@
|
||||||
|
|
||||||
|
|
||||||
#define _GNU_SOURCE
|
#define _GNU_SOURCE
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <X11/X.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <signal.h>
|
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <errno.h>
|
|
||||||
|
|
||||||
#include "simpleswitcher.h"
|
#include "simpleswitcher.h"
|
||||||
|
|
||||||
|
@ -51,41 +47,27 @@ static char **get_dmenu ( )
|
||||||
while ( fgets( buffer, 1024, stdin ) != NULL ) {
|
while ( fgets( buffer, 1024, stdin ) != NULL ) {
|
||||||
retv = realloc( retv, ( index+2 )*sizeof( char* ) );
|
retv = realloc( retv, ( index+2 )*sizeof( char* ) );
|
||||||
retv[index] = strdup( buffer );
|
retv[index] = strdup( buffer );
|
||||||
|
retv[index+1] = NULL;
|
||||||
|
|
||||||
|
// Filter out line-end.
|
||||||
if ( retv[index][strlen( buffer )-1] == '\n' )
|
if ( retv[index][strlen( buffer )-1] == '\n' )
|
||||||
retv[index][strlen( buffer )-1] = '\0';
|
retv[index][strlen( buffer )-1] = '\0';
|
||||||
|
|
||||||
retv[index+1] = NULL;
|
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int token_match ( char **tokens, const char *input,
|
|
||||||
__attribute__( ( unused ) )int index,
|
|
||||||
__attribute__( ( unused ) )void *data )
|
|
||||||
{
|
|
||||||
int match = 1;
|
|
||||||
|
|
||||||
// Do a tokenized match.
|
|
||||||
if ( tokens ) for ( int j = 1; match && tokens[j]; j++ ) {
|
|
||||||
match = ( strcasestr( input, tokens[j] ) != NULL );
|
|
||||||
}
|
|
||||||
|
|
||||||
return match;
|
|
||||||
}
|
|
||||||
|
|
||||||
SwitcherMode dmenu_switcher_dialog ( char **input )
|
SwitcherMode dmenu_switcher_dialog ( char **input )
|
||||||
{
|
{
|
||||||
int shift=0;
|
|
||||||
int selected_line = 0;
|
int selected_line = 0;
|
||||||
SwitcherMode retv = MODE_EXIT;
|
SwitcherMode retv = MODE_EXIT;
|
||||||
// act as a launcher
|
// act as a launcher
|
||||||
char **list = get_dmenu( );
|
char **list = get_dmenu( );
|
||||||
|
|
||||||
int mretv = menu( list, input, dmenu_prompt,NULL, &shift,
|
int mretv = menu( list, input, dmenu_prompt,NULL, NULL,
|
||||||
token_match, NULL, &selected_line );
|
token_match, NULL, &selected_line );
|
||||||
|
|
||||||
if ( mretv == MENU_NEXT ) {
|
if ( mretv == MENU_NEXT ) {
|
||||||
retv = DMENU_DIALOG;
|
retv = DMENU_DIALOG;
|
||||||
|
@ -100,7 +82,6 @@ SwitcherMode dmenu_switcher_dialog ( char **input )
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( list != NULL ) free( list );
|
if ( list != NULL ) free( list );
|
||||||
|
|
||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,9 +42,6 @@
|
||||||
|
|
||||||
#include "simpleswitcher.h"
|
#include "simpleswitcher.h"
|
||||||
#include "profile-dialog.h"
|
#include "profile-dialog.h"
|
||||||
#ifdef TIMING
|
|
||||||
#include <time.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static inline int execshprofile( const char *profile )
|
static inline int execshprofile( const char *profile )
|
||||||
{
|
{
|
||||||
|
@ -66,7 +63,7 @@ static pid_t exec_profile( const char *cmd )
|
||||||
|
|
||||||
return pid;
|
return pid;
|
||||||
}
|
}
|
||||||
static char ** add_elements( char **retv, char *element, unsigned int *retv_index )
|
static inline char ** add_elements( char **retv, char *element, unsigned int *retv_index )
|
||||||
{
|
{
|
||||||
retv = realloc( retv, ( ( *retv_index )+2 )*sizeof( char* ) );
|
retv = realloc( retv, ( ( *retv_index )+2 )*sizeof( char* ) );
|
||||||
retv[( *retv_index )] = element;
|
retv[( *retv_index )] = element;
|
||||||
|
@ -80,10 +77,6 @@ static char ** get_profile ( )
|
||||||
unsigned int retv_index = 0;
|
unsigned int retv_index = 0;
|
||||||
char *path;
|
char *path;
|
||||||
char **retv = NULL;
|
char **retv = NULL;
|
||||||
#ifdef TIMING
|
|
||||||
struct timespec start, stop;
|
|
||||||
clock_gettime( CLOCK_REALTIME, &start );
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if ( getenv( "HOME" ) == NULL ) return NULL;
|
if ( getenv( "HOME" ) == NULL ) return NULL;
|
||||||
|
|
||||||
|
@ -138,32 +131,9 @@ static char ** get_profile ( )
|
||||||
}
|
}
|
||||||
|
|
||||||
free( path );
|
free( path );
|
||||||
#ifdef TIMING
|
|
||||||
clock_gettime( CLOCK_REALTIME, &stop );
|
|
||||||
|
|
||||||
if ( stop.tv_sec != start.tv_sec ) {
|
|
||||||
stop.tv_nsec += ( stop.tv_sec-start.tv_sec )*1e9;
|
|
||||||
}
|
|
||||||
|
|
||||||
long diff = stop.tv_nsec-start.tv_nsec;
|
|
||||||
printf( "Time elapsed: %ld us\n", diff/1000 );
|
|
||||||
#endif
|
|
||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int token_match ( char **tokens, const char *input,
|
|
||||||
__attribute__( ( unused ) )int index,
|
|
||||||
__attribute__( ( unused ) )void *data )
|
|
||||||
{
|
|
||||||
int match = 1;
|
|
||||||
|
|
||||||
// Do a tokenized match.
|
|
||||||
if ( tokens ) for ( int j = 1; match && tokens[j]; j++ ) {
|
|
||||||
match = ( strcasestr( input, tokens[j] ) != NULL );
|
|
||||||
}
|
|
||||||
|
|
||||||
return match;
|
|
||||||
}
|
|
||||||
|
|
||||||
SwitcherMode profile_switcher_dialog ( char **input )
|
SwitcherMode profile_switcher_dialog ( char **input )
|
||||||
{
|
{
|
||||||
|
@ -172,9 +142,8 @@ SwitcherMode profile_switcher_dialog ( char **input )
|
||||||
char **cmd_list = get_profile( );
|
char **cmd_list = get_profile( );
|
||||||
|
|
||||||
if ( cmd_list == NULL ) {
|
if ( cmd_list == NULL ) {
|
||||||
cmd_list = allocate( 2*sizeof( char * ) );
|
unsigned int retv_index = 0;
|
||||||
cmd_list[0] = strdup( "No profiles found" );
|
cmd_list = add_elements( cmd_list, "No profiles found", &retv_index );
|
||||||
cmd_list[1] = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int shift=0;
|
int shift=0;
|
||||||
|
|
|
@ -135,8 +135,6 @@ static void delete_entry( const char *cmd )
|
||||||
unsigned int index = 0;
|
unsigned int index = 0;
|
||||||
char **retv = NULL;
|
char **retv = NULL;
|
||||||
|
|
||||||
printf( "Delete entry: %s\n", cmd );
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This happens in non-critical time (After launching app)
|
* This happens in non-critical time (After launching app)
|
||||||
* It is allowed to be a bit slower.
|
* It is allowed to be a bit slower.
|
||||||
|
@ -280,22 +278,10 @@ static char ** get_apps ( )
|
||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int token_match ( char **tokens, const char *input,
|
|
||||||
__attribute__( ( unused ) )int index,
|
|
||||||
__attribute__( ( unused ) )void *data )
|
|
||||||
{
|
|
||||||
int match = 1;
|
|
||||||
|
|
||||||
// Do a tokenized match.
|
|
||||||
if ( tokens ) for ( int j = 1; match && tokens[j]; j++ ) {
|
|
||||||
match = ( strcasestr( input, tokens[j] ) != NULL );
|
|
||||||
}
|
|
||||||
|
|
||||||
return match;
|
|
||||||
}
|
|
||||||
|
|
||||||
SwitcherMode run_switcher_dialog ( char **input )
|
SwitcherMode run_switcher_dialog ( char **input )
|
||||||
{
|
{
|
||||||
|
int shift=0;
|
||||||
|
int selected_line = 0;
|
||||||
SwitcherMode retv = MODE_EXIT;
|
SwitcherMode retv = MODE_EXIT;
|
||||||
// act as a launcher
|
// act as a launcher
|
||||||
char **cmd_list = get_apps( );
|
char **cmd_list = get_apps( );
|
||||||
|
@ -306,8 +292,6 @@ SwitcherMode run_switcher_dialog ( char **input )
|
||||||
cmd_list[1] = NULL;
|
cmd_list[1] = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int shift=0;
|
|
||||||
int selected_line = 0;
|
|
||||||
int mretv = menu( cmd_list, input, "$", NULL, &shift,token_match, NULL, &selected_line );
|
int mretv = menu( cmd_list, input, "$", NULL, &shift,token_match, NULL, &selected_line );
|
||||||
|
|
||||||
if ( mretv == MENU_NEXT ) {
|
if ( mretv == MENU_NEXT ) {
|
||||||
|
@ -325,7 +309,7 @@ SwitcherMode run_switcher_dialog ( char **input )
|
||||||
free( cmd_list[i] );
|
free( cmd_list[i] );
|
||||||
}
|
}
|
||||||
|
|
||||||
free( cmd_list );
|
if (cmd_list != NULL) free( cmd_list );
|
||||||
|
|
||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,7 +78,23 @@
|
||||||
xdgHandle xdg_handle;
|
xdgHandle xdg_handle;
|
||||||
const char *cache_dir = NULL;
|
const char *cache_dir = NULL;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shared 'token_match' function.
|
||||||
|
* Matches tokenized.
|
||||||
|
*/
|
||||||
|
int token_match ( char **tokens, const char *input,
|
||||||
|
__attribute__( ( unused ) )int index,
|
||||||
|
__attribute__( ( unused ) )void *data )
|
||||||
|
{
|
||||||
|
int match = 1;
|
||||||
|
|
||||||
|
// Do a tokenized match.
|
||||||
|
if ( tokens ) for ( int j = 1; match && tokens[j]; j++ ) {
|
||||||
|
match = ( strcasestr( input, tokens[j] ) != NULL );
|
||||||
|
}
|
||||||
|
|
||||||
|
return match;
|
||||||
|
}
|
||||||
|
|
||||||
void* allocate( unsigned long bytes )
|
void* allocate( unsigned long bytes )
|
||||||
{
|
{
|
||||||
|
@ -1239,6 +1255,7 @@ void run_switcher( int fmode, SwitcherMode mode )
|
||||||
} else if ( mode == SSH_DIALOG ) {
|
} else if ( mode == SSH_DIALOG ) {
|
||||||
retv = ssh_switcher_dialog( &input );
|
retv = ssh_switcher_dialog( &input );
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __QC_MODE__
|
#ifdef __QC_MODE__
|
||||||
else if ( mode == PROFILE_DIALOG ) {
|
else if ( mode == PROFILE_DIALOG ) {
|
||||||
retv = profile_switcher_dialog ( &input );
|
retv = profile_switcher_dialog ( &input );
|
||||||
|
|
|
@ -278,20 +278,6 @@ static char ** get_ssh ( )
|
||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int token_match ( char **tokens, const char *input,
|
|
||||||
__attribute__( ( unused ) )int index,
|
|
||||||
__attribute__( ( unused ) )void *data )
|
|
||||||
{
|
|
||||||
int match = 1;
|
|
||||||
|
|
||||||
// Do a tokenized match.
|
|
||||||
if ( tokens ) for ( int j = 1; match && tokens[j]; j++ ) {
|
|
||||||
match = ( strcasestr( input, tokens[j] ) != NULL );
|
|
||||||
}
|
|
||||||
|
|
||||||
return match;
|
|
||||||
}
|
|
||||||
|
|
||||||
SwitcherMode ssh_switcher_dialog ( char **input )
|
SwitcherMode ssh_switcher_dialog ( char **input )
|
||||||
{
|
{
|
||||||
SwitcherMode retv = MODE_EXIT;
|
SwitcherMode retv = MODE_EXIT;
|
||||||
|
@ -324,7 +310,7 @@ SwitcherMode ssh_switcher_dialog ( char **input )
|
||||||
free( cmd_list[i] );
|
free( cmd_list[i] );
|
||||||
}
|
}
|
||||||
|
|
||||||
free( cmd_list );
|
if(cmd_list != NULL) free( cmd_list );
|
||||||
|
|
||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue