get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/95236/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 95236,
    "url": "https://patches.dpdk.org/api/patches/95236/?format=api",
    "web_url": "https://patches.dpdk.org/project/dpdk/patch/20210702224015.66092-1-cristian.dumitrescu@intel.com/",
    "project": {
        "id": 1,
        "url": "https://patches.dpdk.org/api/projects/1/?format=api",
        "name": "DPDK",
        "link_name": "dpdk",
        "list_id": "dev.dpdk.org",
        "list_email": "dev@dpdk.org",
        "web_url": "http://core.dpdk.org",
        "scm_url": "git://dpdk.org/dpdk",
        "webscm_url": "http://git.dpdk.org/dpdk",
        "list_archive_url": "https://inbox.dpdk.org/dev",
        "list_archive_url_format": "https://inbox.dpdk.org/dev/{}",
        "commit_url_format": ""
    },
    "msgid": "<20210702224015.66092-1-cristian.dumitrescu@intel.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20210702224015.66092-1-cristian.dumitrescu@intel.com",
    "date": "2021-07-02T22:40:15",
    "name": "[V2,4/5] examples/pipeline: add support for selector tables",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "e6207db5f0e738bfde9704ead19f1cbb0e846efd",
    "submitter": {
        "id": 19,
        "url": "https://patches.dpdk.org/api/people/19/?format=api",
        "name": "Cristian Dumitrescu",
        "email": "cristian.dumitrescu@intel.com"
    },
    "delegate": null,
    "mbox": "https://patches.dpdk.org/project/dpdk/patch/20210702224015.66092-1-cristian.dumitrescu@intel.com/mbox/",
    "series": [
        {
            "id": 17607,
            "url": "https://patches.dpdk.org/api/series/17607/?format=api",
            "web_url": "https://patches.dpdk.org/project/dpdk/list/?series=17607",
            "date": "2021-07-02T22:40:15",
            "name": null,
            "version": 2,
            "mbox": "https://patches.dpdk.org/series/17607/mbox/"
        }
    ],
    "comments": "https://patches.dpdk.org/api/patches/95236/comments/",
    "check": "warning",
    "checks": "https://patches.dpdk.org/api/patches/95236/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@inbox.dpdk.org",
        "Delivered-To": "patchwork@inbox.dpdk.org",
        "Received": [
            "from mails.dpdk.org (mails.dpdk.org [217.70.189.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 0BB38A0C3F;\n\tSat,  3 Jul 2021 00:40:21 +0200 (CEST)",
            "from [217.70.189.124] (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id F1EBD41430;\n\tSat,  3 Jul 2021 00:40:19 +0200 (CEST)",
            "from mga04.intel.com (mga04.intel.com [192.55.52.120])\n by mails.dpdk.org (Postfix) with ESMTP id 469404013F\n for <dev@dpdk.org>; Sat,  3 Jul 2021 00:40:18 +0200 (CEST)",
            "from orsmga008.jf.intel.com ([10.7.209.65])\n by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 02 Jul 2021 15:40:17 -0700",
            "from silpixa00400573.ir.intel.com (HELO\n silpixa00400573.ger.corp.intel.com) ([10.237.223.107])\n by orsmga008.jf.intel.com with ESMTP; 02 Jul 2021 15:40:16 -0700"
        ],
        "X-IronPort-AV": [
            "E=McAfee;i=\"6200,9189,10033\"; a=\"206964886\"",
            "E=Sophos;i=\"5.83,320,1616482800\"; d=\"scan'208\";a=\"206964886\"",
            "E=Sophos;i=\"5.83,320,1616482800\"; d=\"scan'208\";a=\"456057960\""
        ],
        "X-ExtLoop1": "1",
        "From": "Cristian Dumitrescu <cristian.dumitrescu@intel.com>",
        "To": "dev@dpdk.org",
        "Cc": "Churchill Khangar <churchill.khangar@intel.com>",
        "Date": "Fri,  2 Jul 2021 23:40:15 +0100",
        "Message-Id": "<20210702224015.66092-1-cristian.dumitrescu@intel.com>",
        "X-Mailer": "git-send-email 2.17.1",
        "In-Reply-To": "<20210702204952.61445-1-cristian.dumitrescu@intel.com>",
        "References": "<20210702204952.61445-1-cristian.dumitrescu@intel.com>",
        "Subject": "[dpdk-dev] [PATCH V2 4/5] examples/pipeline: add support for\n selector tables",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.29",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <mailto:dev-request@dpdk.org?subject=unsubscribe>",
        "List-Archive": "<http://mails.dpdk.org/archives/dev/>",
        "List-Post": "<mailto:dev@dpdk.org>",
        "List-Help": "<mailto:dev-request@dpdk.org?subject=help>",
        "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n <mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org",
        "Sender": "\"dev\" <dev-bounces@dpdk.org>"
    },
    "content": "Add application-evel support for selector tables.\n\nSigned-off-by: Churchill Khangar <churchill.khangar@intel.com>\nSigned-off-by: Cristian Dumitrescu <cristian.dumitrescu@intel.com>\n---\n examples/pipeline/cli.c | 563 ++++++++++++++++++++++++++++++++++++++++\n 1 file changed, 563 insertions(+)",
    "diff": "diff --git a/examples/pipeline/cli.c b/examples/pipeline/cli.c\nindex 30754e319..f67783c8f 100644\n--- a/examples/pipeline/cli.c\n+++ b/examples/pipeline/cli.c\n@@ -1368,6 +1368,467 @@ cmd_pipeline_table_show(char **tokens,\n \t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"table_name\");\n }\n \n+static const char cmd_pipeline_selector_group_add_help[] =\n+\"pipeline <pipeline_name> selector <selector_name> group add\\n\";\n+\n+static void\n+cmd_pipeline_selector_group_add(char **tokens,\n+\tuint32_t n_tokens,\n+\tchar *out,\n+\tsize_t out_size,\n+\tvoid *obj)\n+{\n+\tstruct pipeline *p;\n+\tchar *pipeline_name, *selector_name;\n+\tuint32_t group_id;\n+\tint status;\n+\n+\tif (n_tokens != 6) {\n+\t\tsnprintf(out, out_size, MSG_ARG_MISMATCH, tokens[0]);\n+\t\treturn;\n+\t}\n+\n+\tpipeline_name = tokens[1];\n+\tp = pipeline_find(obj, pipeline_name);\n+\tif (!p || !p->ctl) {\n+\t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"pipeline_name\");\n+\t\treturn;\n+\t}\n+\n+\tif (strcmp(tokens[2], \"selector\") != 0) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"selector\");\n+\t\treturn;\n+\t}\n+\n+\tselector_name = tokens[3];\n+\n+\tif (strcmp(tokens[4], \"group\") ||\n+\t\tstrcmp(tokens[5], \"add\")) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"group add\");\n+\t\treturn;\n+\t}\n+\n+\tstatus = rte_swx_ctl_pipeline_selector_group_add(p->ctl,\n+\t\tselector_name,\n+\t\t&group_id);\n+\tif (status)\n+\t\tsnprintf(out, out_size, MSG_CMD_FAIL, tokens[0]);\n+\telse\n+\t\tsnprintf(out, out_size, \"Group ID: %u\\n\", group_id);\n+}\n+\n+static const char cmd_pipeline_selector_group_delete_help[] =\n+\"pipeline <pipeline_name> selector <selector_name> group delete <group_id>\\n\";\n+\n+static void\n+cmd_pipeline_selector_group_delete(char **tokens,\n+\tuint32_t n_tokens,\n+\tchar *out,\n+\tsize_t out_size,\n+\tvoid *obj)\n+{\n+\tstruct pipeline *p;\n+\tchar *pipeline_name, *selector_name;\n+\tuint32_t group_id;\n+\tint status;\n+\n+\tif (n_tokens != 7) {\n+\t\tsnprintf(out, out_size, MSG_ARG_MISMATCH, tokens[0]);\n+\t\treturn;\n+\t}\n+\n+\tpipeline_name = tokens[1];\n+\tp = pipeline_find(obj, pipeline_name);\n+\tif (!p || !p->ctl) {\n+\t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"pipeline_name\");\n+\t\treturn;\n+\t}\n+\n+\tif (strcmp(tokens[2], \"selector\") != 0) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"selector\");\n+\t\treturn;\n+\t}\n+\n+\tselector_name = tokens[3];\n+\n+\tif (strcmp(tokens[4], \"group\") ||\n+\t\tstrcmp(tokens[5], \"delete\")) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"group delete\");\n+\t\treturn;\n+\t}\n+\n+\tif (parser_read_uint32(&group_id, tokens[6]) != 0) {\n+\t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"group_id\");\n+\t\treturn;\n+\t}\n+\n+\tstatus = rte_swx_ctl_pipeline_selector_group_delete(p->ctl,\n+\t\tselector_name,\n+\t\tgroup_id);\n+\tif (status)\n+\t\tsnprintf(out, out_size, MSG_CMD_FAIL, tokens[0]);\n+}\n+\n+#define GROUP_MEMBER_INFO_TOKENS_MAX 6\n+\n+static int\n+token_is_comment(const char *token)\n+{\n+\tif ((token[0] == '#') ||\n+\t    (token[0] == ';') ||\n+\t    ((token[0] == '/') && (token[1] == '/')))\n+\t\treturn 1; /* TRUE. */\n+\n+\treturn 0; /* FALSE. */\n+}\n+\n+static int\n+pipeline_selector_group_member_read(const char *string,\n+\t\t\t\t      uint32_t *group_id,\n+\t\t\t\t      uint32_t *member_id,\n+\t\t\t\t      uint32_t *weight,\n+\t\t\t\t      int *is_blank_or_comment)\n+{\n+\tchar *token_array[GROUP_MEMBER_INFO_TOKENS_MAX], **tokens;\n+\tchar *s0 = NULL, *s;\n+\tuint32_t n_tokens = 0, group_id_val, member_id_val, weight_val;\n+\tint blank_or_comment = 0;\n+\n+\t/* Check input arguments. */\n+\tif (!string || !string[0])\n+\t\tgoto error;\n+\n+\t/* Memory allocation. */\n+\ts0 = strdup(string);\n+\tif (!s0)\n+\t\tgoto error;\n+\n+\t/* Parse the string into tokens. */\n+\tfor (s = s0; ; ) {\n+\t\tchar *token;\n+\n+\t\ttoken = strtok_r(s, \" \\f\\n\\r\\t\\v\", &s);\n+\t\tif (!token || token_is_comment(token))\n+\t\t\tbreak;\n+\n+\t\tif (n_tokens > GROUP_MEMBER_INFO_TOKENS_MAX)\n+\t\t\tgoto error;\n+\n+\t\ttoken_array[n_tokens] = token;\n+\t\tn_tokens++;\n+\t}\n+\n+\tif (!n_tokens) {\n+\t\tblank_or_comment = 1;\n+\t\tgoto error;\n+\t}\n+\n+\ttokens = token_array;\n+\n+\tif (n_tokens < 4 ||\n+\t\tstrcmp(tokens[0], \"group\") ||\n+\t\tstrcmp(tokens[2], \"member\"))\n+\t\tgoto error;\n+\n+\t/*\n+\t * Group ID.\n+\t */\n+\tif (parser_read_uint32(&group_id_val, tokens[1]) != 0)\n+\t\tgoto error;\n+\t*group_id = group_id_val;\n+\n+\t/*\n+\t * Member ID.\n+\t */\n+\tif (parser_read_uint32(&member_id_val, tokens[3]) != 0)\n+\t\tgoto error;\n+\t*member_id = member_id_val;\n+\n+\ttokens += 4;\n+\tn_tokens -= 4;\n+\n+\t/*\n+\t * Weight.\n+\t */\n+\tif (n_tokens && !strcmp(tokens[0], \"weight\")) {\n+\t\tif (n_tokens < 2)\n+\t\t\tgoto error;\n+\n+\t\tif (parser_read_uint32(&weight_val, tokens[1]) != 0)\n+\t\t\tgoto error;\n+\t\t*weight = weight_val;\n+\n+\t\ttokens += 2;\n+\t\tn_tokens -= 2;\n+\t}\n+\n+\tif (n_tokens)\n+\t\tgoto error;\n+\n+\tfree(s0);\n+\treturn 0;\n+\n+error:\n+\tfree(s0);\n+\tif (is_blank_or_comment)\n+\t\t*is_blank_or_comment = blank_or_comment;\n+\treturn -EINVAL;\n+}\n+\n+static int\n+pipeline_selector_group_members_add(struct rte_swx_ctl_pipeline *p,\n+\t\t\t   const char *selector_name,\n+\t\t\t   FILE *file,\n+\t\t\t   uint32_t *file_line_number)\n+{\n+\tchar *line = NULL;\n+\tuint32_t line_id = 0;\n+\tint status = 0;\n+\n+\t/* Buffer allocation. */\n+\tline = malloc(MAX_LINE_SIZE);\n+\tif (!line)\n+\t\treturn -ENOMEM;\n+\n+\t/* File read. */\n+\tfor (line_id = 1; ; line_id++) {\n+\t\tuint32_t group_id, member_id, weight;\n+\t\tint is_blank_or_comment;\n+\n+\t\tif (fgets(line, MAX_LINE_SIZE, file) == NULL)\n+\t\t\tbreak;\n+\n+\t\tstatus = pipeline_selector_group_member_read(line,\n+\t\t\t\t\t\t\t      &group_id,\n+\t\t\t\t\t\t\t      &member_id,\n+\t\t\t\t\t\t\t      &weight,\n+\t\t\t\t\t\t\t      &is_blank_or_comment);\n+\t\tif (status) {\n+\t\t\tif (is_blank_or_comment)\n+\t\t\t\tcontinue;\n+\n+\t\t\tgoto error;\n+\t\t}\n+\n+\t\tstatus = rte_swx_ctl_pipeline_selector_group_member_add(p,\n+\t\t\tselector_name,\n+\t\t\tgroup_id,\n+\t\t\tmember_id,\n+\t\t\tweight);\n+\t\tif (status)\n+\t\t\tgoto error;\n+\t}\n+\n+error:\n+\tfree(line);\n+\t*file_line_number = line_id;\n+\treturn status;\n+}\n+\n+static const char cmd_pipeline_selector_group_member_add_help[] =\n+\"pipeline <pipeline_name> selector <selector_name> group member add <file_name>\";\n+\n+static void\n+cmd_pipeline_selector_group_member_add(char **tokens,\n+\tuint32_t n_tokens,\n+\tchar *out,\n+\tsize_t out_size,\n+\tvoid *obj)\n+{\n+\tstruct pipeline *p;\n+\tchar *pipeline_name, *selector_name, *file_name;\n+\tFILE *file = NULL;\n+\tuint32_t file_line_number = 0;\n+\tint status;\n+\n+\tif (n_tokens != 8) {\n+\t\tsnprintf(out, out_size, MSG_ARG_MISMATCH, tokens[0]);\n+\t\treturn;\n+\t}\n+\n+\tpipeline_name = tokens[1];\n+\tp = pipeline_find(obj, pipeline_name);\n+\tif (!p || !p->ctl) {\n+\t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"pipeline_name\");\n+\t\treturn;\n+\t}\n+\n+\tif (strcmp(tokens[2], \"selector\") != 0) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"selector\");\n+\t\treturn;\n+\t}\n+\n+\tselector_name = tokens[3];\n+\n+\tif (strcmp(tokens[4], \"group\") ||\n+\t\tstrcmp(tokens[5], \"member\") ||\n+\t\tstrcmp(tokens[6], \"add\")) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"group member add\");\n+\t\treturn;\n+\t}\n+\n+\tfile_name = tokens[7];\n+\tfile = fopen(file_name, \"r\");\n+\tif (!file) {\n+\t\tsnprintf(out, out_size, \"Cannot open file %s.\\n\", file_name);\n+\t\treturn;\n+\t}\n+\n+\tstatus = pipeline_selector_group_members_add(p->ctl,\n+\t\t\t\t\t    selector_name,\n+\t\t\t\t\t    file,\n+\t\t\t\t\t    &file_line_number);\n+\tif (status)\n+\t\tsnprintf(out, out_size, \"Invalid entry in file %s at line %u\\n\",\n+\t\t\t file_name,\n+\t\t\t file_line_number);\n+\n+\tfclose(file);\n+}\n+\n+static int\n+pipeline_selector_group_members_delete(struct rte_swx_ctl_pipeline *p,\n+\t\t\t   const char *selector_name,\n+\t\t\t   FILE *file,\n+\t\t\t   uint32_t *file_line_number)\n+{\n+\tchar *line = NULL;\n+\tuint32_t line_id = 0;\n+\tint status = 0;\n+\n+\t/* Buffer allocation. */\n+\tline = malloc(MAX_LINE_SIZE);\n+\tif (!line)\n+\t\treturn -ENOMEM;\n+\n+\t/* File read. */\n+\tfor (line_id = 1; ; line_id++) {\n+\t\tuint32_t group_id, member_id, weight;\n+\t\tint is_blank_or_comment;\n+\n+\t\tif (fgets(line, MAX_LINE_SIZE, file) == NULL)\n+\t\t\tbreak;\n+\n+\t\tstatus = pipeline_selector_group_member_read(line,\n+\t\t\t\t\t\t\t      &group_id,\n+\t\t\t\t\t\t\t      &member_id,\n+\t\t\t\t\t\t\t      &weight,\n+\t\t\t\t\t\t\t      &is_blank_or_comment);\n+\t\tif (status) {\n+\t\t\tif (is_blank_or_comment)\n+\t\t\t\tcontinue;\n+\n+\t\t\tgoto error;\n+\t\t}\n+\n+\t\tstatus = rte_swx_ctl_pipeline_selector_group_member_delete(p,\n+\t\t\tselector_name,\n+\t\t\tgroup_id,\n+\t\t\tmember_id);\n+\t\tif (status)\n+\t\t\tgoto error;\n+\t}\n+\n+error:\n+\tfree(line);\n+\t*file_line_number = line_id;\n+\treturn status;\n+}\n+\n+static const char cmd_pipeline_selector_group_member_delete_help[] =\n+\"pipeline <pipeline_name> selector <selector_name> group member delete <file_name>\";\n+\n+static void\n+cmd_pipeline_selector_group_member_delete(char **tokens,\n+\tuint32_t n_tokens,\n+\tchar *out,\n+\tsize_t out_size,\n+\tvoid *obj)\n+{\n+\tstruct pipeline *p;\n+\tchar *pipeline_name, *selector_name, *file_name;\n+\tFILE *file = NULL;\n+\tuint32_t file_line_number = 0;\n+\tint status;\n+\n+\tif (n_tokens != 8) {\n+\t\tsnprintf(out, out_size, MSG_ARG_MISMATCH, tokens[0]);\n+\t\treturn;\n+\t}\n+\n+\tpipeline_name = tokens[1];\n+\tp = pipeline_find(obj, pipeline_name);\n+\tif (!p || !p->ctl) {\n+\t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"pipeline_name\");\n+\t\treturn;\n+\t}\n+\n+\tif (strcmp(tokens[2], \"selector\") != 0) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"selector\");\n+\t\treturn;\n+\t}\n+\n+\tselector_name = tokens[3];\n+\n+\tif (strcmp(tokens[4], \"group\") ||\n+\t\tstrcmp(tokens[5], \"member\") ||\n+\t\tstrcmp(tokens[6], \"delete\")) {\n+\t\tsnprintf(out, out_size, MSG_ARG_NOT_FOUND, \"group member delete\");\n+\t\treturn;\n+\t}\n+\n+\tfile_name = tokens[7];\n+\tfile = fopen(file_name, \"r\");\n+\tif (!file) {\n+\t\tsnprintf(out, out_size, \"Cannot open file %s.\\n\", file_name);\n+\t\treturn;\n+\t}\n+\n+\tstatus = pipeline_selector_group_members_delete(p->ctl,\n+\t\t\t\t\t    selector_name,\n+\t\t\t\t\t    file,\n+\t\t\t\t\t    &file_line_number);\n+\tif (status)\n+\t\tsnprintf(out, out_size, \"Invalid entry in file %s at line %u\\n\",\n+\t\t\t file_name,\n+\t\t\t file_line_number);\n+\n+\tfclose(file);\n+}\n+\n+static const char cmd_pipeline_selector_show_help[] =\n+\"pipeline <pipeline_name> selector <selector_name> show\\n\";\n+\n+static void\n+cmd_pipeline_selector_show(char **tokens,\n+\tuint32_t n_tokens,\n+\tchar *out,\n+\tsize_t out_size,\n+\tvoid *obj)\n+{\n+\tstruct pipeline *p;\n+\tchar *pipeline_name, *selector_name;\n+\tint status;\n+\n+\tif (n_tokens != 5) {\n+\t\tsnprintf(out, out_size, MSG_ARG_MISMATCH, tokens[0]);\n+\t\treturn;\n+\t}\n+\n+\tpipeline_name = tokens[1];\n+\tp = pipeline_find(obj, pipeline_name);\n+\tif (!p || !p->ctl) {\n+\t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"pipeline_name\");\n+\t\treturn;\n+\t}\n+\n+\tselector_name = tokens[3];\n+\tstatus = rte_swx_ctl_pipeline_selector_fprintf(stdout,\n+\t\tp->ctl, selector_name);\n+\tif (status)\n+\t\tsnprintf(out, out_size, MSG_ARG_INVALID, \"selector_name\");\n+}\n+\n static const char cmd_pipeline_commit_help[] =\n \"pipeline <pipeline_name> commit\\n\";\n \n@@ -2168,6 +2629,11 @@ cmd_help(char **tokens,\n \t\t\t\"\\tpipeline table delete\\n\"\n \t\t\t\"\\tpipeline table default\\n\"\n \t\t\t\"\\tpipeline table show\\n\"\n+\t\t\t\"\\tpipeline selector group add\\n\"\n+\t\t\t\"\\tpipeline selector group delete\\n\"\n+\t\t\t\"\\tpipeline selector group member add\\n\"\n+\t\t\t\"\\tpipeline selector group member delete\\n\"\n+\t\t\t\"\\tpipeline selector show\\n\"\n \t\t\t\"\\tpipeline commit\\n\"\n \t\t\t\"\\tpipeline abort\\n\"\n \t\t\t\"\\tpipeline regrd\\n\"\n@@ -2266,6 +2732,57 @@ cmd_help(char **tokens,\n \t\treturn;\n \t}\n \n+\tif ((strcmp(tokens[0], \"pipeline\") == 0) &&\n+\t\t(n_tokens == 4) &&\n+\t\t(strcmp(tokens[1], \"selector\") == 0) &&\n+\t\t(strcmp(tokens[2], \"group\") == 0) &&\n+\t\t(strcmp(tokens[3], \"add\") == 0)) {\n+\t\tsnprintf(out, out_size, \"\\n%s\\n\",\n+\t\t\tcmd_pipeline_selector_group_add_help);\n+\t\treturn;\n+\t}\n+\n+\tif ((strcmp(tokens[0], \"pipeline\") == 0) &&\n+\t\t(n_tokens == 4) &&\n+\t\t(strcmp(tokens[1], \"selector\") == 0) &&\n+\t\t(strcmp(tokens[2], \"group\") == 0) &&\n+\t\t(strcmp(tokens[3], \"delete\") == 0)) {\n+\t\tsnprintf(out, out_size, \"\\n%s\\n\",\n+\t\t\tcmd_pipeline_selector_group_delete_help);\n+\t\treturn;\n+\t}\n+\n+\tif ((strcmp(tokens[0], \"pipeline\") == 0) &&\n+\t\t(n_tokens == 5) &&\n+\t\t(strcmp(tokens[1], \"selector\") == 0) &&\n+\t\t(strcmp(tokens[2], \"group\") == 0) &&\n+\t\t(strcmp(tokens[3], \"member\") == 0) &&\n+\t\t(strcmp(tokens[4], \"add\") == 0)) {\n+\t\tsnprintf(out, out_size, \"\\n%s\\n\",\n+\t\t\tcmd_pipeline_selector_group_member_add_help);\n+\t\treturn;\n+\t}\n+\n+\tif ((strcmp(tokens[0], \"pipeline\") == 0) &&\n+\t\t(n_tokens == 5) &&\n+\t\t(strcmp(tokens[1], \"selector\") == 0) &&\n+\t\t(strcmp(tokens[2], \"group\") == 0) &&\n+\t\t(strcmp(tokens[3], \"member\") == 0) &&\n+\t\t(strcmp(tokens[4], \"delete\") == 0)) {\n+\t\tsnprintf(out, out_size, \"\\n%s\\n\",\n+\t\t\tcmd_pipeline_selector_group_member_delete_help);\n+\t\treturn;\n+\t}\n+\n+\tif ((strcmp(tokens[0], \"pipeline\") == 0) &&\n+\t\t(n_tokens == 3) &&\n+\t\t(strcmp(tokens[1], \"selector\") == 0) &&\n+\t\t(strcmp(tokens[2], \"show\") == 0)) {\n+\t\tsnprintf(out, out_size, \"\\n%s\\n\",\n+\t\t\tcmd_pipeline_selector_show_help);\n+\t\treturn;\n+\t}\n+\n \tif ((strcmp(tokens[0], \"pipeline\") == 0) &&\n \t\t(n_tokens == 2) &&\n \t\t(strcmp(tokens[1], \"commit\") == 0)) {\n@@ -2468,6 +2985,52 @@ cli_process(char *in, char *out, size_t out_size, void *obj)\n \t\t\treturn;\n \t\t}\n \n+\t\tif ((n_tokens >= 6) &&\n+\t\t\t(strcmp(tokens[2], \"selector\") == 0) &&\n+\t\t\t(strcmp(tokens[4], \"group\") == 0) &&\n+\t\t\t(strcmp(tokens[5], \"add\") == 0)) {\n+\t\t\tcmd_pipeline_selector_group_add(tokens, n_tokens, out,\n+\t\t\t\tout_size, obj);\n+\t\t\treturn;\n+\t\t}\n+\n+\t\tif ((n_tokens >= 6) &&\n+\t\t\t(strcmp(tokens[2], \"selector\") == 0) &&\n+\t\t\t(strcmp(tokens[4], \"group\") == 0) &&\n+\t\t\t(strcmp(tokens[5], \"delete\") == 0)) {\n+\t\t\tcmd_pipeline_selector_group_delete(tokens, n_tokens, out,\n+\t\t\t\tout_size, obj);\n+\t\t\treturn;\n+\t\t}\n+\n+\t\tif ((n_tokens >= 7) &&\n+\t\t\t(strcmp(tokens[2], \"selector\") == 0) &&\n+\t\t\t(strcmp(tokens[4], \"group\") == 0) &&\n+\t\t\t(strcmp(tokens[5], \"member\") == 0) &&\n+\t\t\t(strcmp(tokens[6], \"add\") == 0)) {\n+\t\t\tcmd_pipeline_selector_group_member_add(tokens, n_tokens, out,\n+\t\t\t\tout_size, obj);\n+\t\t\treturn;\n+\t\t}\n+\n+\t\tif ((n_tokens >= 7) &&\n+\t\t\t(strcmp(tokens[2], \"selector\") == 0) &&\n+\t\t\t(strcmp(tokens[4], \"group\") == 0) &&\n+\t\t\t(strcmp(tokens[5], \"member\") == 0) &&\n+\t\t\t(strcmp(tokens[6], \"delete\") == 0)) {\n+\t\t\tcmd_pipeline_selector_group_member_delete(tokens, n_tokens, out,\n+\t\t\t\tout_size, obj);\n+\t\t\treturn;\n+\t\t}\n+\n+\t\tif ((n_tokens >= 5) &&\n+\t\t\t(strcmp(tokens[2], \"selector\") == 0) &&\n+\t\t\t(strcmp(tokens[4], \"show\") == 0)) {\n+\t\t\tcmd_pipeline_selector_show(tokens, n_tokens, out,\n+\t\t\t\tout_size, obj);\n+\t\t\treturn;\n+\t\t}\n+\n \t\tif ((n_tokens >= 3) &&\n \t\t\t(strcmp(tokens[2], \"commit\") == 0)) {\n \t\t\tcmd_pipeline_commit(tokens, n_tokens, out,\n",
    "prefixes": [
        "V2",
        "4/5"
    ]
}