- const char *look = pi_str;
- const char *bval;
- const char *eval;
-
- char value[256];
- char index[256];
- char type[256];
-
- *value = '\0';
- *index = '\0';
- *type = '\0';
-
- // parsing record instruction
- if (0 == strncmp(look, "record", 6)){
- look += 6;
- printf("record\n");
-
- if (*look && 0 == strncmp(look, " id=", 4)){
- look += 4;
- bval = look;
- printf(" id=");
- while (*look && ' ' != *look)
- look++;
- eval = look;
- strncpy(value, bval, eval - bval);
- value[eval - bval] = '\0';
-
- printf("%s\n", value);
- }
-
- if (*look && 0 == strncmp(look, " rank=", 6)){
- look += 6;
- bval = look;
- printf(" rank=");
- while (*look && ' ' != *look)
- look++;
- eval = look;
- strncpy(value, bval, eval - bval);
- value[eval - bval] = '\0';
-
- printf("%s\n", value);
- }
-
- if (!*look){
- return 1;
- }
- format_pi_zebra_err(err_str, pi_str, look);
- }
-
- // parsing index instruction
- else if (0 == strncmp(look, "index", 5)){
- look += 5;
- printf("index\n");
-
- // parsing all index name/type pairs
- while (*look && ' ' == *look && *(look+1)){
- look++;
-
- // index name must not start with ';' or ' '
- if (!*look || ':' == *look || ' ' == *look){
- format_pi_zebra_err(err_str, pi_str, look);
- return 0;
- }
-
- // setting name and type to zero
- *index = '\0';
- *type = '\0';
-
- // parsing one index name
- bval = look;
- while (*look && ':' != *look && ' ' != *look){
- look++;
- }
- eval = look;
- strncpy(index, bval, eval - bval);
- index[eval - bval] = '\0';
-
-
- // parsing one index type, if existing
- if (':' == *look){
- look++;
-
- bval = look;
- while (*look && ' ' != *look){
- look++;
- }
- eval = look;
- strncpy(type, bval, eval - bval);
- type[eval - bval] = '\0';
- }
-
- printf(" %s:%s\n", index, type);
- }
-
- if (!*look){
- return 1;
- }
- format_pi_zebra_err(err_str, pi_str, look);
- }
-