work on ACK error codes
git-svn-id: https://svn.musicpd.org/mpd/trunk@1324 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
d22e5ec522
commit
f958e0a4c5
|
@ -106,6 +106,9 @@ struct _CommandEntry {
|
|||
CommandListHandlerFunction listHandler;
|
||||
};
|
||||
|
||||
char * current_command = NULL;
|
||||
int command_listNum = 0;
|
||||
|
||||
CommandEntry * getCommandEntryFromString(char * string, int * permission);
|
||||
|
||||
List * commandList;
|
||||
|
@ -679,8 +682,11 @@ int checkArgcAndPermission(CommandEntry * cmd, FILE *fp,
|
|||
CommandEntry * getCommandEntryAndCheckArgcAndPermission(FILE * fp,
|
||||
unsigned int * permission, int argArrayLength, char ** argArray)
|
||||
{
|
||||
static char unknown[] = "";
|
||||
CommandEntry * cmd;
|
||||
|
||||
current_command = unknown;
|
||||
|
||||
if(argArrayLength == 0) return NULL;
|
||||
|
||||
if(!findInList(commandList, argArray[0],(void *)&cmd)) {
|
||||
|
@ -688,6 +694,8 @@ CommandEntry * getCommandEntryAndCheckArgcAndPermission(FILE * fp,
|
|||
return NULL;
|
||||
}
|
||||
|
||||
current_command = cmd->cmd;
|
||||
|
||||
if(checkArgcAndPermission(cmd, fp, *permission, argArrayLength,
|
||||
argArray) < 0)
|
||||
{
|
||||
|
@ -739,6 +747,8 @@ int processCommandInternal(FILE * fp, unsigned int * permission,
|
|||
|
||||
freeArgArray(argArray,argArrayLength);
|
||||
|
||||
current_command = NULL;
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -749,6 +759,8 @@ int proccessListOfCommands(FILE * fp, int * permission, int * expired,
|
|||
ListNode * tempNode;
|
||||
int ret = 0;
|
||||
|
||||
command_listNum = 0;
|
||||
|
||||
while(node!=NULL) {
|
||||
DEBUG("proccesListOfCommands: process command \"%s\"\n",
|
||||
node->data);
|
||||
|
@ -759,12 +771,14 @@ int proccessListOfCommands(FILE * fp, int * permission, int * expired,
|
|||
deleteNodeFromList(list,node);
|
||||
node = tempNode;
|
||||
if(ret!=0 || (*expired)!=0) node = NULL;
|
||||
command_listNum++;
|
||||
}
|
||||
|
||||
command_listNum = 0;
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int processCommand(FILE * fp, unsigned int * permission, char * commandString) {
|
||||
return processCommandInternal(fp,permission,commandString,NULL);
|
||||
}
|
||||
/* vim:set shiftwidth=4 tabstop=8 expandtab: */
|
||||
|
|
|
@ -29,6 +29,9 @@
|
|||
#define COMMAND_RETURN_KILL 10
|
||||
#define COMMAND_RETURN_CLOSE 20
|
||||
|
||||
extern char * current_command;
|
||||
extern int command_listNum;
|
||||
|
||||
int proccessListOfCommands(FILE * fp, int * permission, int * expired,
|
||||
List * list);
|
||||
|
||||
|
@ -40,6 +43,18 @@ void finishCommands();
|
|||
|
||||
#define commandSuccess(fp) myfprintf(fp, "OK\n")
|
||||
|
||||
#define commandError(fp, format, ... ) myfprintf(fp, "ACK " format "\n", ##__VA_ARGS__)
|
||||
#define commandError(fp, format, ... ) \
|
||||
{\
|
||||
if(current_command) { \
|
||||
myfprintf(fp, "ACK [%s:%i] " format "\n", \
|
||||
current_command, command_listNum, \
|
||||
##__VA_ARGS__); \
|
||||
current_command = NULL; \
|
||||
} \
|
||||
else { \
|
||||
myfprintf(fp, "ACK [:%i] " format "\n", \
|
||||
command_listNum, ##__VA_ARGS__); \
|
||||
} \
|
||||
}
|
||||
|
||||
#endif
|
||||
|
|
|
@ -375,7 +375,7 @@ int playlistInfo(FILE * fp,int song) {
|
|||
end = song+1;
|
||||
}
|
||||
if(song>=playlist.length) {
|
||||
commandError(fp, "song doesn't exist");
|
||||
commandError(fp, "song doesn't exist: \"%i\"", song);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -535,11 +535,11 @@ int swapSongsInPlaylist(FILE * fp, int song1, int song2) {
|
|||
int currentSong = -1;
|
||||
|
||||
if(song1<0 || song1>=playlist.length) {
|
||||
commandError(fp,"\"%i\" is not in the playlist", song1);
|
||||
commandError(fp, "song doesn't exist: \"%i\"", song1);
|
||||
return -1;
|
||||
}
|
||||
if(song2<0 || song2>=playlist.length) {
|
||||
commandError(fp, "\"%i\" is not in the playlist", song2);
|
||||
commandError(fp, "song doesn't exist: \"%i\"", song2);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -585,12 +585,8 @@ int deleteFromPlaylist(FILE * fp, int song) {
|
|||
int i;
|
||||
int songOrder;
|
||||
|
||||
if(song<0) {
|
||||
commandError(fp, "need a positive integer");
|
||||
return -1;
|
||||
}
|
||||
if(song>=playlist.length) {
|
||||
commandError(fp, "song doesn't exist");
|
||||
if(song<0 || song>=playlist.length) {
|
||||
commandError(fp, "song doesn't exist: \"%i\"", song);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -713,18 +709,8 @@ int playPlaylist(FILE * fp, int song, int stopOnError) {
|
|||
i = 0;
|
||||
}
|
||||
}
|
||||
else if(song<0) {
|
||||
commandError(fp, "need integer >= -1");
|
||||
playlist_state = PLAYLIST_STATE_STOP;
|
||||
return -1;
|
||||
}
|
||||
if(!playlist.length) {
|
||||
commandError(fp, "playlist is empty");
|
||||
playlist_state = PLAYLIST_STATE_STOP;
|
||||
return -1;
|
||||
}
|
||||
else if(song>=playlist.length) {
|
||||
commandError(fp, "song doesn't exist");
|
||||
else if(song<0 || song>=playlist.length) {
|
||||
commandError(fp, "song doesn't exist: \"%i\"", song);
|
||||
playlist_state = PLAYLIST_STATE_STOP;
|
||||
return -1;
|
||||
}
|
||||
|
@ -869,12 +855,12 @@ int moveSongInPlaylist(FILE * fp, int from, int to) {
|
|||
int currentSong = -1;
|
||||
|
||||
if(from<0 || from>=playlist.length) {
|
||||
commandError(fp, "\"%i\" is not a song in the playlist", from);
|
||||
commandError(fp, "song doesn't exist: \"%i\"", from);
|
||||
return -1;
|
||||
}
|
||||
|
||||
if(to<0 || to>=playlist.length) {
|
||||
commandError(fp, "\"%i\" is not a song in the playlist", to);
|
||||
commandError(fp, "song doesn't exist: \"%i\"", to);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -1253,16 +1239,8 @@ int getPlaylistLength() {
|
|||
int seekSongInPlaylist(FILE * fp, int song, float time) {
|
||||
int i = song;
|
||||
|
||||
if(song<0) {
|
||||
commandError(fp, "need integer >= -1");
|
||||
return -1;
|
||||
}
|
||||
if(!playlist.length) {
|
||||
commandError(fp, "playlist is empty");
|
||||
return -1;
|
||||
}
|
||||
else if(song>=playlist.length) {
|
||||
commandError(fp, "song doesn't exist");
|
||||
if(song<0 || song>=playlist.length) {
|
||||
commandError(fp, "song doesn't exist: \"%i\"", song);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
|
|
@ -192,8 +192,7 @@ int printAllKeysOfTable(FILE * fp, char * table, char * arg1) {
|
|||
return printAllAlbums(fp,arg1);
|
||||
}
|
||||
else {
|
||||
commandError(fp, "table \"%s\" does not exist or not available "
|
||||
"for listing", table);
|
||||
commandError(fp, "table \"%s\" does not exist", table);
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue