Example #1
0
bool CMusicLibrary::SaveMedia(CMedia* pMedia)
{
    CSong* pSong = static_cast<CSong*>(pMedia);
    long ID = pSong->GetID();

    // save the song to the device
    wxString Path = this->GetLibraryPath();
    bool OK = true;
    OK = OK | m_pDevice->AddFolder(cms::ReplaceIllegalPathCharsWithUnderscore(pSong->GetArtist() ), Path);
    OK = OK | m_pDevice->AddFolder(cms::ReplaceIllegalPathCharsWithUnderscore(pSong->GetAlbum() ), Path);
    Path << cms::ReplaceIllegalPathCharsWithUnderscore(pSong->GetTitle() ) << ".";
    Path << CMedia::GetFileTypeStr(pSong->GetFullPath() );
    if (!OK)
    {
        return false;
    }
    if (!m_pDevice->SaveMedia(pSong, Path) )
    {
        return false;
    }

    // add song to library database
    wxString str;
    if (pSong->GetID() < 0)
    {
        str << "INSERT INTO main." << m_pDevice->GetDeviceName()
            << " (col_Artist,col_Album,col_Title,col_Genre,"
            << "col_Time,col_Track,col_Year,col_Type,col_BitRate,col_SampleRate,"
            << "col_Channels,col_Comment,col_FullPath) VALUES ("
            << "'" << cms::sqlEscapeQuotes(pSong->GetArtist() ) << "',"
            << "'" << cms::sqlEscapeQuotes(pSong->GetAlbum() ) << "',"
            << "'" << cms::sqlEscapeQuotes(pSong->GetTitle() ) << "',"
            << "'" << cms::sqlEscapeQuotes(pSong->GetGenre() ) << "',"
            << "'" << pSong->GetTimeString() << "',"
            << "'" << pSong->GetTrack() << "',"
            << "'" << pSong->GetYear() << "',"
            << "'" << pSong->GetType() << "',"
            << "'" << pSong->GetBitRate() << "',"
            << "'" << pSong->GetSampleRate() << "',"
            << "'" << pSong->GetChannels() << "',"
            << "'" << cms::sqlEscapeQuotes(pSong->GetComment() ) << "',"
            << "'" << cms::sqlEscapeQuotes(pSong->GetFullPath() ) << "')";
    }
    else
    {
        str << "UPDATE main." << m_pDevice->GetDeviceName() << " SET "
            << "col_Artist=" << cms::sqlEscapeQuotes(pSong->GetArtist() ) << ","
            << "col_Album=" << cms::sqlEscapeQuotes(pSong->GetAlbum() ) << ","
            << "col_Title=" << cms::sqlEscapeQuotes(pSong->GetTitle() ) << ","
            << "col_Genre=" << cms::sqlEscapeQuotes(pSong->GetGenre() ) << ","
            << "col_Time=" << pSong->GetTimeString() << ","
            << "col_Track=" << pSong->GetTrack() << ","
            << "col_Year=" << pSong->GetYear() << ","
            << "col_Type=" << pSong->GetType() << ","
            << "col_BitRate=" << pSong->GetBitRate() << ","
            << "col_SampleRate=" << pSong->GetSampleRate() << ","
            << "col_Channels=" << pSong->GetChannels() << ","
            << "col_Comment=" << cms::sqlEscapeQuotes(pSong->GetComment() ) << ","
            << "col_FullPath=" << cms::sqlEscapeQuotes(pSong->GetFullPath() )
            << " WHERE ROWID=" << pSong->GetID();
    }
    if (!m_pDatabase->ProcessStatement(str) )
    {
        return false;
    }
    return true;
}
Example #2
0
bool CMusicLibrary::InsertMediaInList(CMedia* pMedia)
{
    CSong* pThisSong = static_cast<CSong*>(pMedia);

    wxTreeListItem ArtistItem,
                   AlbumItem,
                   TitleItem,
                   ThisItem,
                   LastArtistItem,
                   LastAlbumItem,
                   LastTitleItem;

    // artist
    ThisItem = m_pTreelistCtrl->GetFirstChild(m_pTreelistCtrl->GetRootItem() );
    if (!ThisItem.IsOk() )
    {
        ArtistItem = m_pTreelistCtrl->AppendItem(m_pTreelistCtrl->GetRootItem(), pThisSong->GetArtist() );
    }
    else
    {
        while (ThisItem.IsOk() )
        {
            int comp = pThisSong->GetArtist().CmpNoCase(m_pTreelistCtrl->GetItemText(ThisItem, 0) );
            if (comp > 0) // keep going
            {
                LastArtistItem = ThisItem;
                ThisItem = m_pTreelistCtrl->GetNextSibling(LastArtistItem);
                if (!ThisItem.IsOk() )
                {
                    ArtistItem = m_pTreelistCtrl->AppendItem(m_pTreelistCtrl->GetRootItem(), pThisSong->GetArtist() );
                    break;
                }
            }
            else if (comp < 0)  // prepend
            {
                if (LastArtistItem.IsOk() )
                    ArtistItem = m_pTreelistCtrl->InsertItem(m_pTreelistCtrl->GetRootItem(), LastArtistItem, pThisSong->GetArtist() );
                else
                    ArtistItem = m_pTreelistCtrl->PrependItem(m_pTreelistCtrl->GetRootItem(), pThisSong->GetArtist() );
                break;
            }
            else if (comp == 0) // append here
            {
                ArtistItem = ThisItem;
                break;
            }
        }
    }

    // album
    ThisItem = m_pTreelistCtrl->GetFirstChild(ArtistItem);
    if (!ThisItem.IsOk() )
    {
        AlbumItem = m_pTreelistCtrl->AppendItem(ArtistItem, pThisSong->GetAlbum() );
    }
    else
    {
        while (ThisItem.IsOk() )
        {
            int comp = pThisSong->GetAlbum().CmpNoCase(m_pTreelistCtrl->GetItemText(ThisItem, 0) );
            if (comp > 0)  // append
            {
                LastAlbumItem = ThisItem;
                ThisItem = m_pTreelistCtrl->GetNextSibling(LastAlbumItem);
                if (!ThisItem.IsOk() )
                {
                    AlbumItem = m_pTreelistCtrl->AppendItem(ArtistItem, pThisSong->GetAlbum() );
                    break;
                }
            }
            else if (comp < 0)  // prepend
            {
                if (LastAlbumItem.IsOk() )
                    AlbumItem = m_pTreelistCtrl->InsertItem(ArtistItem, LastAlbumItem, pThisSong->GetAlbum() );
                else
                    AlbumItem = m_pTreelistCtrl->PrependItem(ArtistItem, pThisSong->GetAlbum() );
                break;
            }
            else if (comp == 0) // append here
            {
                AlbumItem = ThisItem;
                break;
            }
        }
    }

    // track
    ThisItem = m_pTreelistCtrl->GetFirstChild(AlbumItem);
    if (!ThisItem.IsOk() )
    {
        TitleItem = m_pTreelistCtrl->AppendItem(AlbumItem, pThisSong->GetTitle() );
    }
    else
    {
        while (ThisItem.IsOk() )
        {
            wxString temp = m_pTreelistCtrl->GetItemText(ThisItem, TRACK_COLUMN_NUM);
            long CurrentTrack = -1;
            temp.ToLong(&CurrentTrack);
            int ThisTrack = pThisSong->GetTrack();
            if (ThisTrack > CurrentTrack)  // append
            {
                LastTitleItem = ThisItem;
                ThisItem = m_pTreelistCtrl->GetNextSibling(LastTitleItem);
                if (!ThisItem.IsOk() )
                {
                    TitleItem = m_pTreelistCtrl->AppendItem(AlbumItem, pThisSong->GetTitle() );
                    break;
                }
            }
            else if (ThisTrack < CurrentTrack)  // prepend
            {
                if (LastTitleItem.IsOk() )
                    TitleItem = m_pTreelistCtrl->InsertItem(AlbumItem, LastTitleItem, pThisSong->GetTitle() );
                else
                    TitleItem = m_pTreelistCtrl->PrependItem(AlbumItem, pThisSong->GetTitle() );
                break;
            }
            else if (ThisTrack == CurrentTrack) // duplicate item
            {
                return true;
            }
        }
    }

    // song info
    m_pTreelistCtrl->SetItemText(TitleItem, GENRE_COLUMN_NUM, pThisSong->GetGenre() );
    m_pTreelistCtrl->SetItemText(TitleItem, TIME_COLUMN_NUM, pThisSong->GetTimeString() );
    m_pTreelistCtrl->SetItemText(TitleItem, TRACK_COLUMN_NUM, wxString::Format("%d", pThisSong->GetTrack() ) );
    m_pTreelistCtrl->SetItemText(TitleItem, YEAR_COLUMN_NUM, wxString::Format("%d", pThisSong->GetYear() ) );
    m_pTreelistCtrl->SetItemText(TitleItem, TYPE_COLUMN_NUM, pThisSong->GetType() );
    m_pTreelistCtrl->SetItemText(TitleItem, BITRATE_COLUMN_NUM, wxString::Format("%d", pThisSong->GetBitRate() ) );
    m_pTreelistCtrl->SetItemText(TitleItem, SAMPLERATE_COLUMN_NUM, wxString::Format("%d", pThisSong->GetSampleRate() ) );
    CListItemData* pData = new CListItemData(pThisSong->GetID() );
    m_pTreelistCtrl->SetItemData(TitleItem, pData);
    m_ItemCount++;

    return true;
}