From: Sean Chiang <sean_chiang@openmoko.com> Subject: [PATCH] improvement for find and read phonebooks in shell This patch improves the functions to find and read phonebooks in shell. Besides prr and pf, I add two new commands pRr and pRf to retrieve the phonebook. Signed-off-by: Jim Huang <jserv@openmoko.org> Index: gsm/src/util/shell.c =================================================================== --- gsm.orig/src/util/shell.c 2007-09-17 23:57:51.000000000 +0800 +++ gsm/src/util/shell.c 2007-09-17 23:59:04.000000000 +0800 @@ -34,8 +34,6 @@ #include <gsmd/usock.h> #include <gsmd/ts0705.h> -#include <common/linux_list.h> - #ifndef __GSMD__ #define __GSMD__ #include <gsmd/talloc.h> @@ -43,9 +41,8 @@ #endif #define STDIN_BUF_SIZE 1024 - -static LLIST_HEAD(storage_list); -static LLIST_HEAD(phonebook_list); +static int nFIND = 0; +static int nREADRG = 0; /* this is the handler for receiving passthrough responses */ static int pt_msghandler(struct lgsm_handle *lh, struct gsmd_msg_hdr *gmh) @@ -62,46 +59,23 @@ struct gsmd_phonebook_storage *gpst; char *payload; char *fcomma, *lcomma, *ptr = NULL; + int *num; char buf[128]; + int i; switch (gmh->msg_subtype) { -#if 0 case GSMD_PHONEBOOK_FIND: + num = (int *) ((char *)gmh + sizeof(*gmh)); + printf("Records:%d\n", *num); + + nFIND = *num; + break; case GSMD_PHONEBOOK_READRG: - payload = (char *)gmh + sizeof(*gmh); + num = (int *) ((char *)gmh + sizeof(*gmh)); + printf("Records:%d\n", *num); - if (!strncmp(payload, "+CPBR", 5) || - !strncmp(payload, "+CPBF", 5)) { - gp = (struct gsmd_phonebook *) malloc(sizeof(struct gsmd_phonebook)); - ptr = strchr(payload, ' '); - gp->index = atoi(ptr+1); - - fcomma = strchr(payload, '"'); - lcomma = strchr(fcomma+1, '"'); - strncpy(gp->numb, fcomma + 1, (lcomma-fcomma-1)); - gp->numb[(lcomma - fcomma) - 1] = '\0'; - - gp->type = atoi(lcomma + 2); - - ptr = strrchr(payload, ','); - fcomma = ptr + 1; - lcomma = strchr(fcomma + 1, '"'); - strncpy(gp->text, fcomma + 1, (lcomma - fcomma - 1)); - gp->text[(lcomma - fcomma) - 1] = '\0'; - - llist_add_tail(&gp->list, &phonebook_list); - -#if 0 - llist_for_each_entry(gp, &phonebook_list, list) { - printf("%d, %s, %d, %s\n", gp->index, gp->numb, gp->type, gp->text); - } -#endif - printf("%d, %s, %d, %s\n", gp->index, gp->numb, gp->type, gp->text); - } - else - printf("%s\n", payload); + nREADRG = *num; break; -#endif case GSMD_PHONEBOOK_READ: gp = (struct gsmd_phonebook *) ((char *)gmh + sizeof(*gmh)); if (gp->index) @@ -115,48 +89,18 @@ gps = (struct gsmd_phonebook_support *) ((char *)gmh + sizeof(*gmh)); printf("(1-%d), %d, %d\n", gps->index, gps->nlength, gps->tlength); break; -#if 0 - case GSMD_PHONEBOOK_LIST_STORAGE: - payload = (char *)gmh + sizeof(*gmh); - if (!strncmp(payload, "+CPBS", 5)) { - char* delim = "(,"; - struct gsmd_phonebook_storage *cur, *cur2; - - /* Remove previous record */ - if (!llist_empty(&storage_list)) { - llist_for_each_entry_safe(cur, cur2, - &storage_list, list) { - llist_del(&cur->list); - talloc_free(cur); - } - } - - ptr = strpbrk(payload, delim); - - while ( ptr ) { - gpst = (struct gsmd_phonebook_storage *) malloc(sizeof(struct gsmd_phonebook_storage)); - strncpy(gpst->storage, ptr+2, 2); - gpst->storage[2] = '\0'; - - ptr = strpbrk(ptr+2, delim); - - llist_add_tail(&gpst->list, &storage_list); - } + case GSMD_PHONEBOOK_LIST_STORAGE: + gpst = (struct gsmd_phonebook_storage *)((char *)gmh + sizeof(*gmh)); - if (llist_empty(&storage_list)) - return 0; + for (i = 0; i < gpst->num; i++) { + printf("%s, ", gpst->mem[i].type); + } - llist_for_each_entry(cur, &storage_list, list) { - printf("\n%s",cur->storage); - } + printf("\n"); - printf("\n"); - } - else - printf("%s\n", payload); break; -#endif + case GSMD_PHONEBOOK_WRITE: case GSMD_PHONEBOOK_DELETE: case GSMD_PHONEBOOK_SET_STORAGE: @@ -164,6 +108,26 @@ payload = (char *)gmh + sizeof(*gmh); printf("%s\n", payload); break; + case GSMD_PHONEBOOK_RETRIEVE_READRG: + gp = (struct gsmd_phonebook *) ((char *)gmh + sizeof(*gmh)); + + for (i=0; i<nREADRG; i++) { + printf("%d,%s,%d,%s\n", gp->index, gp->numb, gp->type, gp->text); + gp++; + } + + nREADRG = 0; + break; + case GSMD_PHONEBOOK_RETRIEVE_FIND: + gp = (struct gsmd_phonebook *) ((char *)gmh + sizeof(*gmh)); + + for (i = 0; i < nFIND; i++) { + printf("%d,%s,%d,%s\n", gp->index, gp->numb, gp->type, gp->text); + gp++; + } + + nFIND = 0; + break; default: return -EINVAL; } @@ -381,11 +345,13 @@ "\tpd\tPB Delete (pb=index)\n" "\tpr\tPB Read (pr=index)\n" "\tprr\tPB Read Range (prr=index1,index2)\n" - "\tpf\tPB Find (pff=indtext)\n" + "\tpf\tPB Find (pf=indtext)\n" "\tpw\tPB Write (pw=index,number,text)\n" "\tps\tPB Support\n" "\tpm\tPB Memory\n" "\tpp\tPB Set Memory (pp=storage)\n" + "\tpRr\tRetrieve Readrg Records\n" + "\tpRf\tRetrieve Find Records\n" "\tsd\tSMS Delete (sd=index,delflg)\n" "\tsl\tSMS List (sl=stat)\n" "\tsr\tSMS Read (sr=index)\n" @@ -509,48 +475,21 @@ printf("Delete Phonebook Entry\n"); ptr = strchr(buf, '='); lgsm_pb_del_entry(lgsmh, atoi(ptr+1)); -#if 0 } else if ( !strncmp(buf, "prr", 3)) { printf("Read Phonebook Entries\n"); struct lgsm_phonebook_readrg pb_readrg; - struct gsmd_phonebook *gp_cur, *gp_cur2; - - /* Remove records */ - if (!llist_empty(&phonebook_list)) { - llist_for_each_entry_safe(gp_cur, - gp_cur2, - &phonebook_list, - list) { - llist_del(&gp_cur->list); - talloc_free(gp_cur); - } - } ptr = strchr(buf, '='); pb_readrg.index1 = atoi(ptr+1); ptr = strchr(buf, ','); pb_readrg.index2 = atoi(ptr+1); lgsm_pb_read_entries(lgsmh, &pb_readrg); -#endif } else if ( !strncmp(buf, "pr", 2)) { ptr = strchr(buf, '='); lgsm_pb_read_entry(lgsmh, atoi(ptr+1)); -#if 0 } else if ( !strncmp(buf, "pf", 2)) { printf("Find Phonebook Entry\n"); struct lgsm_phonebook_find pb_find; - struct gsmd_phonebook *gp_cur, *gp_cur2; - - /* Remove records */ - if (!llist_empty(&phonebook_list)) { - llist_for_each_entry_safe(gp_cur, - gp_cur2, - &phonebook_list, - list) { - llist_del(&gp_cur->list); - talloc_free(gp_cur); - } - } ptr = strchr(buf, '='); strncpy(pb_find.findtext, @@ -559,7 +498,6 @@ pb_find.findtext[strlen(ptr+1)] = '\0'; lgsm_pb_find_entry(lgsmh, &pb_find); -#endif } else if ( !strncmp(buf, "pw", 2)) { printf("Write Phonebook Entry\n"); struct lgsm_phonebook pb; @@ -591,6 +529,16 @@ } else if ( !strncmp(buf, "ps", 2)) { printf("Get Phonebook Support\n"); lgsm_pb_get_support(lgsmh); + } else if( !strncmp(buf, "pRr", 3) ) { + printf("Retrieve Readrg Records\n"); + + if ( nREADRG ) + lgsm_pb_retrieve_readrg(lgsmh, nREADRG); + } else if( !strncmp(buf, "pRf", 3) ) { + printf("Retrieve Find Records\n"); + + if ( nFIND ) + lgsm_pb_retrieve_find(lgsmh, nFIND); } else if ( !strncmp(buf, "sd", 2)) { printf("Delete SMS\n"); struct lgsm_sms_delete sms_del;