len = ast_strlen_zero(word) ? 0 : strlen(word);
 
        for (i = 0; choices[i]; i++) {
-               if ((!len || !strncasecmp(word, choices[i], len)) && ++which > state)
-                       return ast_strdup(choices[i]);
+               if ((!len || !strncasecmp(word, choices[i], len)) && ++which > state) {
+                       if (state != -1) {
+                               return ast_strdup(choices[i]);
+                       }
+
+                       if (ast_cli_completion_add(ast_strdup(choices[i]))) {
+                               return NULL;
+                       }
+               }
        }
        return NULL;
 }
                struct ast_channel_snapshot *snapshot = stasis_message_data(msg);
 
                if (!strncasecmp(word, snapshot->name, wordlen) && (++which > state)) {
-                       ret = ast_strdup(snapshot->name);
-                       ao2_ref(msg, -1);
-                       break;
+                       if (state != -1) {
+                               ret = ast_strdup(snapshot->name);
+                               ao2_ref(msg, -1);
+                               break;
+                       }
+
+                       if (ast_cli_completion_add(ast_strdup(snapshot->name))) {
+                               ao2_ref(msg, -1);
+                               break;
+                       }
                }
        }
        ao2_iterator_destroy(&iter);
 
                 * application at one time. You can type 'show application Dial Echo' and
                 * you will see informations about these two applications ...
                 */
-               return ast_complete_applications(a->line, a->word, a->n);
+               return ast_complete_applications(a->line, a->word, -1);
        }
 
        if (a->argc < 4) {
        AST_RWLIST_RDLOCK(&apps);
        AST_RWLIST_TRAVERSE(&apps, app, list) {
                cmp = strncasecmp(word, app->name, wordlen);
-               if (cmp > 0) {
-                       continue;
-               }
-               if (!cmp) {
+               if (cmp < 0) {
+                       /* No more matches. */
+                       break;
+               } else if (!cmp) {
                        /* Found match. */
-                       if (++which <= state) {
-                               /* Not enough matches. */
-                               continue;
+                       if (state != -1) {
+                               if (++which <= state) {
+                                       /* Not enough matches. */
+                                       continue;
+                               }
+                               ret = ast_strdup(app->name);
+                               break;
+                       }
+                       if (ast_cli_completion_add(ast_strdup(app->name))) {
+                               break;
                        }
-                       ret = ast_strdup(app->name);
-                       break;
                }
-               /* Not in container. */
-               break;
        }
        AST_RWLIST_UNLOCK(&apps);