X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=command.c;h=481fd0f637352fb21ff97536d426ece42ec0fda3;hp=45840755a37aef29c32afa7e425c3bcb4c443c7a;hb=ba83a291cd486e8ab53ac64d81b17d8f5705d715;hpb=18ab74be0bd8b5b086ab54b96e1ab0a7e0c14a04 diff --git a/command.c b/command.c index 45840755..481fd0f6 100644 --- a/command.c +++ b/command.c @@ -279,7 +279,7 @@ static int check_sender_args(struct command_context *cc, } /** - * Send a sideband packet through a blocking file descriptor. + * Receive a sideband packet from a blocking file descriptor. * * \param scc fd and crypto keys. * \param expected_band The expected band designator. @@ -663,7 +663,7 @@ EXPORT_SERVER_CMD_HANDLER(nomore); static int com_ff(struct command_context *cc, struct lls_parse_result *lpr) { long promille; - int i, ret, backwards = 0; + int i, ret; char c, *errctx; ret = lls(lls_check_arg_count(lpr, 1, 1, &errctx)); @@ -671,10 +671,22 @@ static int com_ff(struct command_context *cc, struct lls_parse_result *lpr) send_errctx(cc, errctx); return ret; } - if (!(ret = sscanf(lls_input(0, lpr), "%i%c", &i, &c))) - return -E_COMMAND_SYNTAX; - if (ret > 1 && c == '-') - backwards = 1; /* jmp backwards */ + ret = para_atoi32(lls_input(0, lpr), &i); + if (ret < 0) { + if (ret != -E_ATOI_JUNK_AT_END) + return ret; + /* + * Compatibility code to keep the historic syntax (ff 30-) + * working. This can be removed after 0.7.0. + */ + ret = sscanf(lls_input(0, lpr), "%i%c", &i, &c); + if (ret <= 0) + return -E_COMMAND_SYNTAX; + if (ret > 1 && c == '-') { + PARA_WARNING_LOG("use of obsolete syntax\n"); + i = -i; + } + } mutex_lock(mmd_mutex); ret = -E_NO_AUDIO_FILE; if (!mmd->afd.afhi.chunks_total || !mmd->afd.afhi.seconds_total) @@ -682,13 +694,10 @@ static int com_ff(struct command_context *cc, struct lls_parse_result *lpr) ret = 1; promille = (1000 * mmd->current_chunk) / mmd->afd.afhi.chunks_total; /* - * We need these casts because without them the expression on the right + * We need this cast because without it the expression on the right * hand side is of unsigned type. */ - if (backwards) - promille -= 1000 * i / (int)mmd->afd.afhi.seconds_total; - else - promille += 1000 * i / (int)mmd->afd.afhi.seconds_total; + promille += 1000 * i / (int)mmd->afd.afhi.seconds_total; if (promille < 0) promille = 0; if (promille > 1000) {