FreeCalypso > hg > fc-pcsc-tools
diff libcommon/cardconnect.c @ 30:84d1c31d0fad
first round of refactoring for selection among multiple readers
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Fri, 12 Feb 2021 17:09:01 +0000 |
| parents | f7145c77b7fb |
| children | b37fcb235848 |
line wrap: on
line diff
--- a/libcommon/cardconnect.c Fri Feb 12 16:19:11 2021 +0000 +++ b/libcommon/cardconnect.c Fri Feb 12 17:09:01 2021 +0000 @@ -7,7 +7,7 @@ SCARDCONTEXT hContext; SCARDHANDLE hCard; -char *reader_name_buf; +char *reader_list, *selected_reader; setup_pcsc_context() { @@ -22,7 +22,7 @@ return(0); } -get_reader_name() +get_reader_list() { LONG rv; DWORD dwReaders; @@ -40,33 +40,40 @@ SCardReleaseContext(hContext); exit(1); } - reader_name_buf = malloc(dwReaders); - if (!reader_name_buf) { + reader_list = malloc(dwReaders); + if (!reader_list) { perror("malloc for readers list"); SCardReleaseContext(hContext); exit(1); } - reader_name_buf[0] = '\0'; - rv = SCardListReaders(hContext, NULL, reader_name_buf, &dwReaders); + reader_list[0] = '\0'; + rv = SCardListReaders(hContext, NULL, reader_list, &dwReaders); if (rv != SCARD_S_SUCCESS) { fprintf(stderr, "SCardListReaders 2nd call: %s\n", pcsc_stringify_error(rv)); SCardReleaseContext(hContext); exit(1); } - if (reader_name_buf[0] == '\0') { - fprintf(stderr, - "error: list returned by SCardListReaders() begins with a NUL byte\n"); - SCardReleaseContext(hContext); - exit(1); + return(0); +} + +select_reader_num(select_num) + unsigned select_num; +{ + char *cp; + unsigned num; + + for (cp = reader_list, num = 0; *cp; num++) { + if (num == select_num) { + selected_reader = cp; + return(0); + } + cp += strlen(cp) + 1; } - if (!memchr(reader_name_buf, 0, dwReaders)) { - fprintf(stderr, -"error: list returned by SCardListReaders() does not contain a NUL byte\n"); - SCardReleaseContext(hContext); - exit(1); - } - return(0); + fprintf(stderr, + "error: requested reader #%u, but only %u readers found\n", + select_num, num); + exit(1); } connect_to_card() @@ -74,7 +81,7 @@ LONG rv; DWORD dwActiveProtocol; - rv = SCardConnect(hContext, reader_name_buf, SCARD_SHARE_EXCLUSIVE, + rv = SCardConnect(hContext, selected_reader, SCARD_SHARE_EXCLUSIVE, SCARD_PROTOCOL_T0, &hCard, &dwActiveProtocol); if (rv != SCARD_S_SUCCESS) { fprintf(stderr, "SCardConnect: %s\n", pcsc_stringify_error(rv));
