static void add_track_to_album (RBMtpSource *source, const char *album_name, LIBMTP_track_t *track) { RBMtpSourcePrivate *priv = MTP_SOURCE_GET_PRIVATE (source); LIBMTP_album_t *album; album = g_hash_table_lookup (priv->album_map, album_name); if (album != NULL) { /* add track to album */ album->tracks = realloc (album->tracks, sizeof(uint32_t) * (album->no_tracks+1)); album->tracks[album->no_tracks] = track->item_id; album->no_tracks++; rb_debug ("adding track ID %d to album ID %d; now %d tracks", track->item_id, album->album_id, album->no_tracks); if (LIBMTP_Update_Album (priv->device, album) != 0) { rb_debug ("LIBMTP_Update_Album failed.."); report_libmtp_errors (priv->device, FALSE); } } else { /* add new album */ album = LIBMTP_new_album_t (); album->name = strdup (album_name); album->no_tracks = 1; album->tracks = malloc (sizeof(uint32_t)); album->tracks[0] = track->item_id; album->storage_id = track->storage_id; /* fill in artist and genre? */ rb_debug ("creating new album (%s) for track ID %d", album->name, track->item_id); if (LIBMTP_Create_New_Album (priv->device, album) != 0) { LIBMTP_destroy_album_t (album); rb_debug ("LIBMTP_Create_New_Album failed.."); report_libmtp_errors (priv->device, FALSE); } else { g_hash_table_insert (priv->album_map, album->name, album); } } }
static LIBMTP_album_t * add_track_to_album (RBMtpThread *thread, const char *album_name, uint32_t track_id, uint32_t storage_id, gboolean *new_album) { LIBMTP_album_t *album; album = g_hash_table_lookup (thread->albums, album_name); if (album != NULL) { /* add track to album */ album->tracks = realloc (album->tracks, sizeof(uint32_t) * (album->no_tracks+1)); album->tracks[album->no_tracks] = track_id; album->no_tracks++; rb_debug ("adding track ID %d to album ID %d; now has %d tracks", track_id, album->album_id, album->no_tracks); if (new_album != NULL) { *new_album = FALSE; } } else { /* add new album */ album = LIBMTP_new_album_t (); album->name = strdup (album_name); album->no_tracks = 1; album->tracks = malloc (sizeof(uint32_t)); album->tracks[0] = track_id; album->storage_id = storage_id; rb_debug ("creating new album (%s) for track ID %d", album->name, track_id); g_hash_table_insert (thread->albums, album->name, album); if (new_album != NULL) { *new_album = TRUE; } } return album; }
int sendtrack_function(char * from_path, char * to_path, char *partist, char *palbumartist, char *ptitle, char *pgenre, char *palbum, char *pcomposer, uint16_t tracknum, uint16_t length, uint16_t year, uint32_t storageid, uint16_t quiet) { char *filename, *parent; char artist[80], albumartist[80], title[80], genre[80], album[80], composer[80]; char num[80]; uint64_t filesize; uint32_t parent_id = 0; struct stat sb; LIBMTP_track_t *trackmeta; LIBMTP_album_t *albuminfo; int ret; printf("Sending track %s to %s\n", from_path, to_path); trackmeta = LIBMTP_new_track_t(); albuminfo = LIBMTP_new_album_t(); parent = dirname(strdup(to_path)); filename = basename(strdup(to_path)); parent_id = parse_path (parent,files,folders); if (parent_id == -1) { printf("Parent folder could not be found, skipping\n"); return 1; } if (stat(from_path, &sb) == -1) { fprintf(stderr, "%s: ", from_path); perror("stat"); return 1; } if (!S_ISREG(sb.st_mode)) return 0; filesize = sb.st_size; trackmeta->filetype = find_filetype (from_path); if (!LIBMTP_FILETYPE_IS_TRACK(trackmeta->filetype)) { printf("Not a valid track codec: \"%s\"\n", LIBMTP_Get_Filetype_Description(trackmeta->filetype)); return 1; } if ((ptitle == NULL) && (quiet == 0)) { if ( (ptitle = prompt("Title", title, 80, 0)) != NULL ) if (!strlen(ptitle)) ptitle = NULL; } if ((palbum == NULL) && (quiet == 0)) { if ( (palbum = prompt("Album", album, 80, 0)) != NULL ) if (!strlen(palbum)) palbum = NULL; } if ((palbumartist == NULL) && (quiet == 0)) { if ( (palbumartist = prompt("Album artist", albumartist, 80, 0)) != NULL ) if (!strlen(palbumartist)) palbumartist = NULL; } if ((partist == NULL) && (quiet == 0)) { if ( (partist = prompt("Artist", artist, 80, 0)) != NULL ) if (!strlen(partist)) partist = NULL; } if ((pcomposer == NULL) && (quiet == 0)) { if ( (pcomposer = prompt("Writer or Composer", composer, 80, 0)) != NULL ) if (!strlen(pcomposer)) pcomposer = NULL; } if ((pgenre == NULL) && (quiet == 0)) { if ( (pgenre = prompt("Genre", genre, 80, 0)) != NULL ) if (!strlen(pgenre)) pgenre = NULL; } if ((tracknum == 0) && (quiet == 0)) { char *pnum; if ( (pnum = prompt("Track number", num, 80, 0)) == NULL ) tracknum = 0; else tracknum = strtoul(pnum, 0, 10); } if ((year == 0) && (quiet == 0)) { char *pnum; if ( (pnum = prompt("Year", num, 80, 0)) == NULL ) year = 0; else year = strtoul(pnum, 0, 10); } if ((length == 0) && (quiet == 0)) { char *pnum; if ( (pnum = prompt("Length", num, 80, 0)) == NULL ) length = 0; else length = strtoul(pnum, 0, 10); } printf("Sending track:\n"); printf("Codec: %s\n", LIBMTP_Get_Filetype_Description(trackmeta->filetype)); if (ptitle) { printf("Title: %s\n", ptitle); trackmeta->title = strdup(ptitle); } if (palbum) { printf("Album: %s\n", palbum); trackmeta->album = strdup(palbum); albuminfo->name = strdup(palbum); } if (palbumartist) { printf("Album artist: %s\n", palbumartist); albuminfo->artist = strdup(palbumartist); } if (partist) { printf("Artist: %s\n", partist); trackmeta->artist = strdup(partist); if (palbumartist == NULL) albuminfo->artist = strdup(partist); } if (pcomposer) { printf("Writer or Composer: %s\n", pcomposer); trackmeta->composer = strdup(pcomposer); albuminfo->composer = strdup(pcomposer); } if (pgenre) { printf("Genre: %s\n", pgenre); trackmeta->genre = strdup(pgenre); albuminfo->genre = strdup(pgenre); } if (year > 0) { char tmp[80]; printf("Year: %d\n", year); snprintf(tmp, sizeof(tmp)-1, "%4d0101T0000.0", year); tmp[sizeof(tmp)-1] = '\0'; trackmeta->date = strdup(tmp); } if (tracknum > 0) { printf("Track no: %d\n", tracknum); trackmeta->tracknumber = tracknum; } if (length > 0) { printf("Length: %d\n", length); // Multiply by 1000 since this is in milliseconds trackmeta->duration = length * 1000; } // We should always have this if (filename != NULL) { trackmeta->filename = strdup(filename); } trackmeta->filesize = filesize; trackmeta->parent_id = parent_id; { int rc; char *desc = NULL; LIBMTP_devicestorage_t *pds = NULL; if (0 != (rc=LIBMTP_Get_Storage(device, LIBMTP_STORAGE_SORTBY_NOTSORTED))) { perror("LIBMTP_Get_Storage()"); exit(-1); } for (pds = device->storage; pds != NULL; pds = pds->next) { if (pds->id == storageid) { desc = strdup(pds->StorageDescription); break; } } if (NULL != desc) { printf("Storage ID: %s (%u)\n", desc, storageid); free(desc); } else printf("Storage ID: %u\n", storageid); trackmeta->storage_id = storageid; } printf("Sending track...\n"); ret = LIBMTP_Send_Track_From_File(device, from_path, trackmeta, progress, NULL); printf("\n"); if (ret != 0) { printf("Error sending track.\n"); LIBMTP_Dump_Errorstack(device); LIBMTP_Clear_Errorstack(device); ret = 1; } else { printf("New track ID: %d\n", trackmeta->item_id); } /* Add here add to album call */ if (palbum) ret = add_track_to_album(albuminfo, trackmeta); LIBMTP_destroy_album_t(albuminfo); LIBMTP_destroy_track_t(trackmeta); return ret; }
void Plugin::AppendAlbum (LIBMTP_mtpdevice_t *device, LIBMTP_track_t *track, const UnmountableFileInfo& info) { auto albuminfo = LIBMTP_new_album_t (); albuminfo->artist = strdup (info.Artist_.toUtf8 ().constData ()); albuminfo->name = strdup (info.Album_.toUtf8 ().constData ()); albuminfo->genre = strdup (info.Genres_.join ("; ").toUtf8 ().constData ()); auto album = LIBMTP_Get_Album_List (device); auto albumOrig = album; decltype (album) foundAlbum = nullptr, resultingAlgum = nullptr; while (album) { if (album->name && (album->artist || album->composer) && QString::fromUtf8 (album->name) == info.Album_ && (QString::fromUtf8 (album->artist) == info.Artist_ || QString::fromUtf8 (album->composer) == info.Artist_)) { foundAlbum = album; album = album->next; foundAlbum->next = nullptr; } else album = album->next; } if (foundAlbum) { auto tracks = static_cast<uint32_t*> (malloc ((foundAlbum->no_tracks + 1) * sizeof (uint32_t))); ++foundAlbum->no_tracks; if (foundAlbum->tracks) { memcpy (tracks, foundAlbum->tracks, foundAlbum->no_tracks * sizeof (uint32_t)); free (foundAlbum->tracks); } tracks [foundAlbum->no_tracks - 1] = track->item_id; foundAlbum->tracks = tracks; if (LIBMTP_Update_Album (device, foundAlbum)) { LIBMTP_Dump_Errorstack (device); LIBMTP_Clear_Errorstack (device); } resultingAlgum = foundAlbum; } else { auto trackId = static_cast<uint32_t*> (malloc (sizeof (uint32_t))); *trackId = track->item_id; albuminfo->tracks = trackId; albuminfo->no_tracks = 1; albuminfo->storage_id = track->storage_id; if (LIBMTP_Create_New_Album (device, albuminfo)) { LIBMTP_Dump_Errorstack (device); LIBMTP_Clear_Errorstack (device); } resultingAlgum = albuminfo; } SetAlbumArt (device, resultingAlgum, info.AlbumArtPath_); while (albumOrig) { auto tmp = albumOrig; albumOrig = albumOrig->next; LIBMTP_destroy_album_t (tmp); } LIBMTP_destroy_album_t (albuminfo); }