# HG changeset patch # User nicodvb # Date 1233615358 0 # Node ID a70f79850e5fed990b46738be6571ec44cbd33aa # Parent 6616c485ece08e1ede67ba1278bce3ac9083477e implement and export dvdnav_get_serial_string(); patch by Matthew Wire devel - mrwire - co - uk. Fixed by Erik diff -r 6616c485ece0 -r a70f79850e5f dvdnav.c --- a/dvdnav.c Mon Jan 12 12:10:32 2009 +0000 +++ b/dvdnav.c Mon Feb 02 22:55:58 2009 +0000 @@ -825,6 +825,11 @@ return DVDNAV_STATUS_OK; } +dvdnav_status_t dvdnav_get_serial_string(dvdnav_t *this, const char **serial_str) { + (*serial_str) = this->vm->dvd_serial; + return DVDNAV_STATUS_OK; +} + uint8_t dvdnav_get_video_aspect(dvdnav_t *this) { uint8_t retval; diff -r 6616c485ece0 -r a70f79850e5f dvdnav/dvdnav.h --- a/dvdnav/dvdnav.h Mon Jan 12 12:10:32 2009 +0000 +++ b/dvdnav/dvdnav.h Mon Feb 02 22:55:58 2009 +0000 @@ -537,6 +537,13 @@ dvdnav_status_t dvdnav_get_title_string(dvdnav_t *self, const char **title_str); /* + * Returns a string containing the serial number of the DVD. + * This has a max of 15 characters and should be more unique than the + * title string. + */ +dvdnav_status_t dvdnav_get_serial_string(dvdnav_t *self, const char **serial_str); + +/* * Get video aspect code. * The aspect code does only change on VTS boundaries. * See the DVDNAV_VTS_CHANGE event. diff -r 6616c485ece0 -r a70f79850e5f vm/vm.c --- a/vm/vm.c Mon Jan 12 12:10:32 2009 +0000 +++ b/vm/vm.c Mon Feb 02 22:55:58 2009 +0000 @@ -156,7 +156,7 @@ } #endif -static void dvd_read_name(char *name, const char *device) { +static void dvd_read_name(char *name, char *serial, const char *device) { /* Because we are compiling with _FILE_OFFSET_BITS=64 * all off_t are 64bit. */ @@ -192,6 +192,8 @@ fprintf(MSG_OUT, " "); } } + strncpy(serial, (char*) &data[73], (i-73)); + serial[14] = 0; fprintf(MSG_OUT, "\nlibdvdnav: DVD Title (Alternative): "); for(i=89; i < 128; i++ ) { if((data[i] == 0)) break; @@ -352,7 +354,7 @@ fprintf(MSG_OUT, "libdvdnav: vm: failed to open/read the DVD\n"); return 0; } - dvd_read_name(vm->dvd_name, dvdroot); + dvd_read_name(vm->dvd_name, vm->dvd_serial, dvdroot); vm->map = remap_loadmap(vm->dvd_name); vm->vmgi = ifoOpenVMGI(vm->dvd); if(!vm->vmgi) { diff -r 6616c485ece0 -r a70f79850e5f vm/vm.h --- a/vm/vm.h Mon Jan 12 12:10:32 2009 +0000 +++ b/vm/vm.h Mon Feb 02 22:55:58 2009 +0000 @@ -82,6 +82,7 @@ dvd_state_t state; int32_t hop_channel; char dvd_name[50]; + char dvd_serial[15]; remap_t *map; int stopped; } vm_t;