Ticket #6346: MythVideo.SubSeasEp.31709.diff

File MythVideo.SubSeasEp.31709.diff, 41.8 KB (added by robert.mcnamara@…, 12 years ago)

UI/DB Support, bugfixes

  • mythvideo/theme/default/video-ui.xml

     
    867867        <!-- Labels  -->
    868868
    869869        <textarea name="title_text" from="basetextarea">
    870             <area>50,90,250,40</area>
    871             <value>Name:</value>
     870            <area>50,80,250,40</area>
     871            <value>Title:</value>
    872872            <align>right,top</align>
    873873        </textarea>
    874874
     875        <textarea name="subtitle_text" from="basetextarea">
     876            <area>50,138,250,40</area>
     877            <value>Subtitle:</value>
     878            <align>right,top</align>
     879        </textarea>
     880
     881        <textarea name="season_text" from="basetextarea">
     882            <area>50,185,250,40</area>
     883            <value>Season:</value>
     884            <align>right,top</align>
     885        </textarea>
     886
     887        <textarea name="episode_text" from="basetextarea">
     888            <area>370,185,150,40</area>
     889            <value>Episode:</value>
     890            <align>right,top</align>
     891        </textarea>
     892
    875893        <textarea name="category_text" from="title_text">
    876             <position>50,152</position>
     894            <area>370,232,150,40</area>
     895            <align>right</align>
    877896            <value>Category:</value>
    878897        </textarea>
    879898
    880899        <textarea name="level_text" from="title_text">
    881             <position>50,202</position>
     900            <area>20,232,200,40</area>
     901            <align>right</align>
    882902            <value>Parental Control:</value>
    883903        </textarea>
    884904
    885905        <textarea name="child_text" from="title_text">
    886             <position>50,247</position>
     906            <area>20,277,200,40</area>
     907            <align>right</align>
    887908            <value>File to Always Play Next:</value>
    888909        </textarea>
    889910
    890911        <textarea name="browse_text" from="title_text">
    891             <position>50,292</position>
     912            <area>500,277,200,40</area>
     913            <align>left</align>
    892914            <value>Include while Browsing:</value>
    893915        </textarea>
    894916
     
    925947        <!-- Widgets -->
    926948
    927949        <textedit name="title_edit" from="basetextedit">
    928             <position>310,80</position>
     950            <position>310,70</position>
    929951        </textedit>
    930952
    931         <buttonlist name="category_select" from="baseselector">
    932             <position>310,145</position>
    933         </buttonlist>
     953        <textedit name="subtitle_edit" from="basetextedit">
     954            <position>310,126</position>
     955        </textedit>
    934956
     957        <spinbox name="season" from="basespinbox">
     958            <position>310,181</position>
     959        </spinbox>
     960
     961        <spinbox name="episode" from="basespinbox">
     962            <position>530,181</position>
     963        </spinbox>
     964
    935965        <buttonlist name="level_select" from="baseselector">
    936             <position>310,195</position>
     966            <position>230,225</position>
    937967        </buttonlist>
    938968
     969        <buttonlist name="category_select" from="baseselector">
     970            <position>530,225</position>
     971        </buttonlist>
     972
    939973        <buttonlist name="child_select" from="baseselector">
    940             <position>310,240</position>
     974            <position>230,270</position>
    941975        </buttonlist>
    942976
    943977        <checkbox name="browse_check" from="basecheckbox">
    944             <position>310,290</position>
     978            <position>680,275</position>
    945979        </checkbox>
    946980
    947981        <button name="coverart_button" from="basesearchbutton">
  • mythvideo/theme/default-wide/video-ui.xml

     
    843853    <window name="edit_metadata">
    844854
    845855        <textarea name="title" from="basetextarea">
    846             <area>10,50,1260,50</area>
     856            <area>10,30,760,50</area>
    847857            <value>Edit Video Information</value>
    848858            <align>hcenter,vcenter</align>
    849859            <font>baselarge</font>
     
    852862        <!-- Labels  -->
    853863
    854864        <textarea name="title_text" from="basetextarea">
    855             <area>250,110,250,40</area>
    856             <value>Name:</value>
     865            <area>50,80,250,40</area>
     866            <value>Title:</value>
    857867            <align>right,top</align>
    858868        </textarea>
    859869
     870        <textarea name="subtitle_text" from="basetextarea">
     871            <area>50,138,250,40</area>
     872            <value>Subtitle:</value>
     873            <align>right,top</align>
     874        </textarea>
     875
     876        <textarea name="season_text" from="basetextarea">
     877            <area>50,185,250,40</area>
     878            <value>Season:</value>
     879            <align>right,top</align>
     880        </textarea>
     881
     882        <textarea name="episode_text" from="basetextarea">
     883            <area>370,185,150,40</area>
     884            <value>Episode:</value>
     885            <align>right,top</align>
     886        </textarea>
     887
    860888        <textarea name="category_text" from="title_text">
    861             <position>250,172</position>
     889            <area>420,232,150,40</area>
     890            <align>right</align>
    862891            <value>Category:</value>
    863892        </textarea>
    864893
    865894        <textarea name="level_text" from="title_text">
    866             <position>250,222</position>
     895            <area>20,232,200,40</area>
     896            <align>right</align>
    867897            <value>Parental Control:</value>
    868898        </textarea>
    869899
    870900        <textarea name="child_text" from="title_text">
    871             <position>250,267</position>
     901            <area>20,277,200,40</area>
     902            <align>right</align>
    872903            <value>File to Always Play Next:</value>
    873904        </textarea>
    874905
    875906        <textarea name="browse_text" from="title_text">
    876             <position>250,312</position>
     907            <area>470,277,280,40</area>
     908            <align>left</align>
    877909            <value>Include while Browsing:</value>
    878910        </textarea>
    879911
    880912        <textarea name="coverart_text_label" from="title_text">
    881             <position>250,348</position>
     913            <position>50,328</position>
    882914            <value>Cover Art:</value>
    883915        </textarea>
    884916
    885917        <textarea name="screenshot_text_label" from="title_text">
    886             <position>250,377</position>
     918            <position>50,357</position>
    887919            <value>Screenshot:</value>
    888920        </textarea>
    889921
    890922        <textarea name="banner_text_label" from="title_text">
    891             <position>250,406</position>
     923            <position>50,386</position>
    892924            <value>Banner:</value>
    893925        </textarea>
    894926
    895927        <textarea name="fanart_text_label" from="title_text">
    896             <position>250,435</position>
     928            <position>50,415</position>
    897929            <value>Fanart:</value>
    898930        </textarea>
    899931
    900932        <textarea name="trailer_text_label" from="title_text">
    901             <position>250,464</position>
     933            <position>50,447</position>
    902934            <value>Trailer:</value>
    903935        </textarea>
    904936
    905937        <textarea name="player_text" from="title_text">
    906             <position>250,510</position>
     938            <position>50,487</position>
    907939            <value>Unique Player Command:</value>
    908940        </textarea>
    909941
    910942        <!-- Widgets -->
    911943
    912944        <textedit name="title_edit" from="basetextedit">
    913             <position>510,100</position>
     945            <position>310,70</position>
    914946        </textedit>
    915947
    916         <buttonlist name="category_select" from="baseselector">
    917             <position>510,165</position>
    918         </buttonlist>
     948        <textedit name="subtitle_edit" from="basetextedit">
     949            <position>310,126</position>
     950        </textedit>
    919951
     952        <spinbox name="season" from="basespinbox">
     953            <position>310,181</position>
     954        </spinbox>
     955
     956        <spinbox name="episode" from="basespinbox">
     957            <position>530,181</position>
     958        </spinbox>
     959
    920960        <buttonlist name="level_select" from="baseselector">
    921             <position>510,215</position>
     961            <position>230,225</position>
    922962        </buttonlist>
    923963
     964        <buttonlist name="category_select" from="baseselector">
     965            <position>580,225</position>
     966        </buttonlist>
     967
    924968        <buttonlist name="child_select" from="baseselector">
    925             <position>510,260</position>
     969            <position>230,270</position>
    926970        </buttonlist>
    927971
    928972        <checkbox name="browse_check" from="basecheckbox">
    929             <position>510,310</position>
     973            <position>735,275</position>
    930974        </checkbox>
    931975
    932         <button name="coverart_button" from="basesearchbutton">
    933             <position>510,343</position>
     976        <button name="coverart_button">
     977            <area>310,323,32,32</area>
     978            <statetype name="buttonstate">
     979                <state name="active">
     980                    <imagetype name="background">
     981                        <filename>blankbutton_off.png</filename>
     982                    </imagetype>
     983                </state>
     984                <state name="selected" from="active">
     985                    <imagetype name="background">
     986                        <filename>blankbutton_on.png</filename>
     987                    </imagetype>
     988                </state>
     989                <state name="disabled" from="active" />
     990                <state name="pushed" from="active">
     991                    <imagetype name="background">
     992                        <filename>blankbutton_pushed.png</filename>
     993                    </imagetype>
     994                </state>
     995            </statetype>
    934996        </button>
    935997
    936998        <textarea name="coverart_text" from="basetextarea">
    937             <area>550,348,250,40</area>
     999            <area>350,328,250,40</area>
    9381000            <value>/path/to/the/thing.jpg</value>
    9391001        </textarea>
    9401002
    941         <button name="screenshot_button" from="basesearchbutton">
    942             <position>510,372</position>
     1003        <button name="screenshot_button">
     1004            <area>310,352,32,32</area>
     1005            <statetype name="buttonstate">
     1006                <state name="active">
     1007                    <imagetype name="background">
     1008                        <filename>blankbutton_off.png</filename>
     1009                    </imagetype>
     1010                </state>
     1011                <state name="selected" from="active">
     1012                    <imagetype name="background">
     1013                        <filename>blankbutton_on.png</filename>
     1014                    </imagetype>
     1015                </state>
     1016                <state name="disabled" from="active" />
     1017                <state name="pushed" from="active">
     1018                    <imagetype name="background">
     1019                        <filename>blankbutton_pushed.png</filename>
     1020                    </imagetype>
     1021                </state>
     1022            </statetype>
    9431023        </button>
    9441024
    9451025        <textarea name="screenshot_text" from="basetextarea">
    946             <area>550,377,250,40</area>
     1026            <area>350,357,250,40</area>
    9471027            <value>/path/to/the/thing.jpg</value>
    9481028        </textarea>
    9491029
    950         <button name="banner_button" from="basesearchbutton">
    951             <position>510,401</position>
     1030        <button name="banner_button">
     1031            <area>310,381,32,32</area>
     1032            <statetype name="buttonstate">
     1033                <state name="active">
     1034                    <imagetype name="background">
     1035                        <filename>blankbutton_off.png</filename>
     1036                    </imagetype>
     1037                </state>
     1038                <state name="selected" from="active">
     1039                    <imagetype name="background">
     1040                        <filename>blankbutton_on.png</filename>
     1041                    </imagetype>
     1042                </state>
     1043                <state name="disabled" from="active" />
     1044                <state name="pushed" from="active">
     1045                    <imagetype name="background">
     1046                        <filename>blankbutton_pushed.png</filename>
     1047                    </imagetype>
     1048                </state>
     1049            </statetype>
    9521050        </button>
    9531051
    9541052        <textarea name="banner_text" from="basetextarea">
    955             <area>550,406,250,40</area>
     1053            <area>350,386,250,40</area>
    9561054            <value>/path/to/the/thing.jpg</value>
    9571055        </textarea>
    9581056
    959         <button name="fanart_button" from="basesearchbutton">
    960             <position>510,430</position>
     1057        <button name="fanart_button">
     1058            <area>310,412,32,32</area>
     1059            <statetype name="buttonstate">
     1060                <state name="active">
     1061                    <imagetype name="background">
     1062                        <filename>blankbutton_off.png</filename>
     1063                    </imagetype>
     1064                </state>
     1065                <state name="selected" from="active">
     1066                    <imagetype name="background">
     1067                        <filename>blankbutton_on.png</filename>
     1068                    </imagetype>
     1069                </state>
     1070                <state name="disabled" from="active" />
     1071                <state name="pushed" from="active">
     1072                    <imagetype name="background">
     1073                        <filename>blankbutton_pushed.png</filename>
     1074                    </imagetype>
     1075                </state>
     1076            </statetype>
    9611077        </button>
    9621078
    9631079        <textarea name="fanart_text" from="basetextarea">
    964             <area>550,435,250,40</area>
     1080            <area>350,415,250,40</area>
    9651081            <value>/path/to/the/thing.jpg</value>
    9661082        </textarea>
    9671083
    968         <button name="trailer_button" from="basesearchbutton">
    969             <position>510,460</position>
     1084        <button name="trailer_button">
     1085            <area>310,442,32,32</area>
     1086            <statetype name="buttonstate">
     1087                <state name="active">
     1088                    <imagetype name="background">
     1089                        <filename>blankbutton_off.png</filename>
     1090                    </imagetype>
     1091                </state>
     1092                <state name="selected" from="active">
     1093                    <imagetype name="background">
     1094                        <filename>blankbutton_on.png</filename>
     1095                    </imagetype>
     1096                </state>
     1097                <state name="disabled" from="active" />
     1098                <state name="pushed" from="active">
     1099                    <imagetype name="background">
     1100                        <filename>blankbutton_pushed.png</filename>
     1101                    </imagetype>
     1102                </state>
     1103            </statetype>
    9701104        </button>
    9711105
    9721106        <textarea name="trailer_text" from="basetextarea">
    973             <area>550,465,250,40</area>
     1107            <area>350,447,250,40</area>
    9741108            <value>/path/to/the/thing.jpg</value>
    9751109        </textarea>
    9761110
     1111
    9771112        <textedit name="player_edit" from="basetextedit">
    978             <position>510,495</position>
     1113            <position>310,477</position>
    9791114        </textedit>
    9801115
    9811116        <button name="done_button" from="basebutton">
    982             <position>510,565</position>
     1117            <position>310,537</position>
    9831118            <value>Done</value>
    9841119        </button>
    9851120
  • mythvideo/mythvideo/metadatalistmanager.cpp

     
    112112    MSqlQuery query(MSqlQuery::InitCon());
    113113    query.setForwardOnly(true);
    114114    const QString BaseMetadataQuery(
    115         "SELECT title, director, plot, rating, year, userrating,"
    116         "length, filename, showlevel, coverfile, inetref, childid,"
    117         "browse, playcommand, category, intid, trailer, screenshot,"
    118         "banner, fanart, host FROM videometadata");
     115        "SELECT title, director, plot, rating, year, "
     116        "userrating, length, filename, showlevel, "
     117        "coverfile, inetref, childid, browse, playcommand, category, "
     118        "intid, trailer, screenshot, banner, fanart, "
     119        "subtitle, season, episode, host FROM videometadata");
    119120
    120121    query.prepare(BaseMetadataQuery);
    121122
  • mythvideo/mythvideo/metadata.cpp

     
    8989  public:
    9090    MetadataImp(const QString &filename, const QString &trailer, const QString &coverfile,
    9191             const QString &screenshot, const QString &banner, const QString &fanart,
    92              const QString &title, int year,
     92             const QString &title, const QString &subtitle, int year,
    9393             const QString &inetref, const QString &director,
    9494             const QString &plot, float userrating,
    9595             const QString &rating, int length,
     96             unsigned int season, unsigned int episode,
    9697             int id, ParentalLevel::Level showlevel, int categoryID,
    9798             int childID, bool browse,
    9899             const QString &playcommand, const QString &category,
     
    100101             const country_list &countries,
    101102             const cast_list &cast,
    102103             const QString &host = "") :
    103         m_title(title),
     104        m_title(title), m_subtitle(subtitle),
    104105        m_inetref(inetref), m_director(director), m_plot(plot),
    105106        m_rating(rating), m_playcommand(playcommand), m_category(category),
    106107        m_genres(genres), m_countries(countries), m_cast(cast),
    107108        m_filename(filename), m_trailer(trailer), m_coverfile(coverfile),
    108109        m_screenshot(screenshot), m_banner(banner), m_fanart(fanart),
    109110        m_host(host), m_categoryID(categoryID), m_childID(childID),
    110         m_year(year), m_length(length), m_showlevel(showlevel),
     111        m_year(year), m_length(length), m_season(season),
     112        m_episode(episode), m_showlevel(showlevel),
    111113        m_browse(browse), m_id(id), m_userrating(userrating)
    112114    {
    113115        VideoCategory::GetCategory().get(m_categoryID, m_category);
     
    128130        if (this != &rhs)
    129131        {
    130132            m_title = rhs.m_title;
     133            m_subtitle = rhs.m_subtitle;
    131134            m_inetref = rhs.m_inetref;
    132135            m_director = rhs.m_director;
    133136            m_plot = rhs.m_plot;
     
    148151            m_childID = rhs.m_childID;
    149152            m_year = rhs.m_year;
    150153            m_length = rhs.m_length;
     154            m_season = rhs.m_season;
     155            m_episode = rhs.m_episode;
    151156            m_showlevel = rhs.m_showlevel;
    152157            m_browse = rhs.m_browse;
    153158            m_id = rhs.m_id;
     
    180185        m_title = title;
    181186    }
    182187
     188    const QString &getSubtitle() const { return m_subtitle; }
     189    void SetSubtitle(const QString &subtitle) { m_subtitle = subtitle; }
     190
    183191    const QString &GetInetRef() const { return m_inetref; }
    184192    void SetInetRef(const QString &inetRef) { m_inetref = inetRef; }
    185193
     
    249257    int GetLength() const { return m_length; }
    250258    void SetLength(int length) { m_length = length; }
    251259
     260    int GetSeason() const { return m_season; }
     261    void SetSeason(int season) { m_season = season; }
     262
     263    int GetEpisode() const { return m_episode; }
     264    void SetEpisode(int episode) { m_episode = episode; }
     265
    252266    ParentalLevel::Level GetShowLevel() const { return m_showlevel; }
    253267    void SetShowLevel(ParentalLevel::Level showLevel)
    254268    {
     
    289303
    290304  private:
    291305    QString m_title;
     306    QString m_subtitle;
    292307    QString m_inetref;
    293308    QString m_director;
    294309    QString m_plot;
     
    310325    int m_childID;
    311326    int m_year;
    312327    int m_length;
     328    int m_season;
     329    int m_episode;
    313330    ParentalLevel::Level m_showlevel;
    314331    bool m_browse;
    315332    unsigned int m_id;  // videometadata.intid
     
    384401    MetadataImp tmp(m_filename, VIDEO_TRAILER_DEFAULT, VIDEO_COVERFILE_DEFAULT,
    385402                    VIDEO_SCREENSHOT_DEFAULT, VIDEO_BANNER_DEFAULT,
    386403                    VIDEO_FANART_DEFAULT, Metadata::FilenameToTitle(m_filename),
    387                     VIDEO_YEAR_DEFAULT, VIDEO_INETREF_DEFAULT,
     404                    VIDEO_SUBTITLE_DEFAULT, VIDEO_YEAR_DEFAULT, VIDEO_INETREF_DEFAULT,
    388405                    VIDEO_DIRECTOR_DEFAULT, VIDEO_PLOT_DEFAULT, 0.0,
    389                     VIDEO_RATING_DEFAULT, 0, m_id,
     406                    VIDEO_RATING_DEFAULT, 0,
     407                    Metadata::FilenameToSeasonEpisode(m_filename, 1),
     408                    Metadata::FilenameToSeasonEpisode(m_filename, 2), m_id,
    390409                    ParentalLevel::plLowest, 0, -1, true, "", "",
    391410                    Metadata::genre_list(), Metadata::country_list(),
    392411                    Metadata::cast_list(), m_host);
     
    484503    m_screenshot = query.value(17).toString();
    485504    m_banner = query.value(18).toString();
    486505    m_fanart = query.value(19).toString();
    487     m_host = query.value(20).toString();
     506    m_subtitle = query.value(20).toString();
     507    m_season = query.value(21).toInt();
     508    m_episode = query.value(22).toInt();
     509    m_host = query.value(23).toString();
    488510
    489511    VideoCategory::GetCategory().get(m_categoryID, m_category);
    490512
     
    502524{
    503525    if (m_title.isEmpty())
    504526        m_title = Metadata::FilenameToTitle(m_filename);
     527    if (m_subtitle.isEmpty())
     528        m_subtitle = VIDEO_SUBTITLE_DEFAULT;
    505529    if (m_director.isEmpty())
    506530        m_director = VIDEO_DIRECTOR_UNKNOWN;
    507531    if (m_plot.isEmpty())
    508532        m_plot = VIDEO_PLOT_DEFAULT;
    509533    if (m_rating.isEmpty())
    510534        m_rating = VIDEO_RATING_DEFAULT;
     535    if (m_season == 0)
     536        m_season = Metadata::FilenameToSeasonEpisode(m_filename, 1);
     537    if (m_episode == 0)
     538        m_episode = Metadata::FilenameToSeasonEpisode(m_filename, 2);
    511539    if (m_coverfile.isEmpty())
    512540        m_coverfile = VIDEO_COVERFILE_DEFAULT;
    513541    if (m_screenshot.isEmpty())
     
    533561    {
    534562        m_browse = gContext->GetNumSetting("VideoNewBrowsable", 1);
    535563
    536         query.prepare("INSERT INTO videometadata (title,director,plot,"
    537                       "rating,year,userrating,length,filename,showlevel,"
    538                       "coverfile,inetref,browse,trailer,screenshot,banner,"
    539                       "fanart,host) VALUES (:TITLE, :DIRECTOR, :PLOT, :RATING, "
    540                       ":YEAR, :USERRATING, :LENGTH, :FILENAME, :SHOWLEVEL, "
    541                       ":COVERFILE, :INETREF, :BROWSE, :TRAILER, :SCREENSHOT, "
    542                       ":BANNER, :FANART, :HOST)");
     564        query.prepare("INSERT INTO videometadata (title,subtitle,director,plot,"
     565                      "rating,year,userrating,length,season,episode,filename,"
     566                      "showlevel,coverfile,inetref,browse,trailer,screenshot,banner,"
     567                      "fanart,host) VALUES (:TITLE, :SUBTITLE, :DIRECTOR, :PLOT, "
     568                      ":RATING, :YEAR, :USERRATING, :LENGTH, :SEASON, :EPISODE, "
     569                      ":FILENAME, :SHOWLEVEL, :COVERFILE, :INETREF, :BROWSE, "
     570                      ":TRAILER, :SCREENSHOT, :BANNER, :FANART, :HOST)");
    543571    }
    544572    else
    545573    {
    546         query.prepare("UPDATE videometadata SET title = :TITLE, "
     574        query.prepare("UPDATE videometadata SET title = :TITLE, subtitle = :SUBTITLE, "
    547575                      "director = :DIRECTOR, plot = :PLOT, rating= :RATING, "
    548576                      "year = :YEAR, userrating = :USERRATING, "
    549                       "length = :LENGTH, filename = :FILENAME, trailer = :TRAILER, "
     577                      "length = :LENGTH, season = :SEASON, episode = :EPISODE, "
     578                      "filename = :FILENAME, trailer = :TRAILER, "
    550579                      "showlevel = :SHOWLEVEL, coverfile = :COVERFILE, "
    551580                      "screenshot = :SCREENSHOT, banner = :BANNER, fanart = :FANART, "
    552581                      "inetref = :INETREF, browse = :BROWSE, host = :HOST, "
     
    560589    }
    561590
    562591    query.bindValue(":TITLE", m_title);
     592    query.bindValue(":SUBTITLE", m_subtitle);
    563593    query.bindValue(":DIRECTOR", m_director);
    564594    query.bindValue(":PLOT", m_plot);
    565595    query.bindValue(":RATING", m_rating);
    566596    query.bindValue(":YEAR", m_year);
    567597    query.bindValue(":USERRATING", m_userrating);
    568598    query.bindValue(":LENGTH", m_length);
     599    query.bindValue(":SEASON", m_season);
     600    query.bindValue(":EPISODE", m_episode);
    569601    query.bindValue(":FILENAME", m_filename);
    570602    query.bindValue(":TRAILER", m_trailer);
    571603    query.bindValue(":SHOWLEVEL", m_showlevel);
     
    811843    return title.trimmed();
    812844}
    813845
     846unsigned int Metadata::FilenameToSeasonEpisode(const QString &file_name,
     847                                    int position)
     848{
     849    // position 1 returns season, 2 returns episode
     850
     851    QString title = file_name.right(file_name.length() -
     852                                    file_name.lastIndexOf('/') - 1);
     853    QRegExp group("(\\d{1,3})(?:\\s|-|_|\\.)?(?:[ex])" //Season
     854                  "(?:\\s|-|_|\\.)?(\\d{1,3})", // Episode
     855                  Qt::CaseInsensitive);
     856    int pos = group.indexIn(title);
     857    if (pos > -1)
     858    {
     859        QString groupResult = group.cap(0);
     860        QString season = group.cap(1);
     861        QString episode = group.cap(2);
     862        if (position == 1)
     863            return season.toInt();
     864        else if (position == 2)
     865            return episode.toInt();
     866    }
     867    return 0;
     868}
     869
    814870namespace
    815871{
    816872    const QRegExp &getTitleTrim(bool ignore_case)
     
    829885    return ret;
    830886}
    831887
    832 Metadata::Metadata(const QString &filename, const QString &trailer,
    833              const QString &coverfile, const QString &screenshot,
    834              const QString &banner, const QString &fanart,
    835              const QString &title, int year,
     888Metadata::Metadata(const QString &filename, const QString &trailer, 
     889             const QString &coverfile, const QString &screenshot, 
     890             const QString &banner, const QString &fanart, 
     891             const QString &title, const QString &subtitle, int year,
    836892             const QString &inetref, const QString &director,
    837893             const QString &plot, float userrating,
    838894             const QString &rating, int length,
     895             int season, int episode,
    839896             int id, ParentalLevel::Level showlevel, int categoryID,
    840897             int childID, bool browse,
    841898             const QString &playcommand, const QString &category,
     
    845902             const QString &host)
    846903{
    847904    m_imp = new MetadataImp(filename, trailer, coverfile, screenshot, banner,
    848                             fanart, title, year, inetref, director, plot,
    849                             userrating, rating, length, id, showlevel,
    850                             categoryID, childID, browse, playcommand, category,
    851                             genres, countries, cast, host);
     905                            fanart, title, subtitle, year, inetref, director, plot,
     906                            userrating, rating, length, season, episode, id,
     907                            showlevel, categoryID, childID, browse, playcommand,
     908                            category, genres, countries, cast, host);
    852909}
    853910
    854911Metadata::~Metadata()
     
    911968    m_imp->SetTitle(title);
    912969}
    913970
     971const QString &Metadata::GetSubtitle() const
     972{
     973    return m_imp->getSubtitle();
     974}
     975 
     976void Metadata::SetSubtitle(const QString &subtitle)
     977{
     978    m_imp->SetSubtitle(subtitle);
     979}
     980
    914981int Metadata::GetYear() const
    915982{
    916983    return m_imp->getYear();
     
    9811048    m_imp->SetLength(length);
    9821049}
    9831050
     1051int Metadata::GetSeason() const
     1052{
     1053    return m_imp->GetSeason();
     1054}
     1055
     1056void Metadata::SetSeason(int season)
     1057{
     1058    m_imp->SetSeason(season);
     1059}
     1060
     1061int Metadata::GetEpisode() const
     1062{
     1063    return m_imp->GetEpisode();
     1064}
     1065
     1066void Metadata::SetEpisode(int episode)
     1067{
     1068    m_imp->SetEpisode(episode);
     1069}
     1070
    9841071unsigned int Metadata::GetID() const
    9851072{
    9861073    return m_imp->GetID();
  • mythvideo/mythvideo/videofilter.h

     
    5454        kOrderByUserRatingDescending = 2,
    5555        kOrderByLength = 3,
    5656        kOrderByFilename = 4,
    57         kOrderByID = 5
     57        kOrderByID = 5,
     58        kOrderBySeasonEp = 6
    5859    };
    5960
    6061    int GetCategory() const { return category; }
  • mythvideo/mythvideo/dbcheck.cpp

     
    3838    const QString lastMythDVDDBVersion = "1002";
    3939    const QString lastMythVideoVersion = "1010";
    4040
    41     const QString currentDatabaseVersion = "1023";
     41    const QString currentDatabaseVersion = "1024";
    4242
    4343    const QString OldMythVideoVersionName = "VideoDBSchemaVer";
    4444    const QString OldMythDVDVersionName = "DVDDBSchemaVer";
     
    834834            performActualUpdate(updates, "1023", dbver, MythVideoVersionName);
    835835        }
    836836
     837        if (dbver == "1023")
     838        {
     839            QStringList updates;
     840            updates += "ALTER TABLE videometadata ADD `subtitle` TEXT "
     841                       "NOT NULL AFTER `title`;";
     842            updates += "ALTER TABLE videometadata ADD `season` SMALLINT "
     843                       "UNSIGNED NOT NULL DEFAULT '0' AFTER `length`;";
     844            updates += "ALTER TABLE videometadata ADD `episode` SMALLINT "
     845                       "UNSIGNED NOT NULL DEFAULT '0' AFTER `season`;";
     846            performActualUpdate(updates, "1024", dbver, MythVideoVersionName);
     847        }
    837848
    838849    }
    839850}
  • mythvideo/mythvideo/videoutils.cpp

     
    139142    return QString("%1 minutes").arg(length);
    140143}
    141144
     145QString GetDisplaySeasonEpisode(int seasEp, int digits)
     146{
     147    QString seasEpNum = QString::number(seasEp);
     148
     149    if (digits == 2 && seasEpNum.size() < 2)
     150        seasEpNum.prepend("0");
     151       
     152    return seasEpNum;
     153}
     154
    142155QString GetDisplayBrowse(bool browse)
    143156{
    144157    return browse ? QObject::tr("Yes") : QObject::tr("No");
  • mythvideo/mythvideo/editmetadata.h

     
    1010class MythUIText;
    1111class MythUITextEdit;
    1212class MythUIButton;
     13class MythUISpinBox;
    1314class MythUICheckBox;
    1415
    1516class EditMetadataDialog : public MythScreenType
     
    3435  public slots:
    3536    void SaveAndExit();
    3637    void SetTitle();
     38    void SetSubtitle();
    3739    void SetCategory(MythUIButtonListItem*);
    3840    void SetPlayer();
     41    void SetSeason();
     42    void SetEpisode();
    3943    void SetLevel(MythUIButtonListItem*);
    4044    void SetChild(MythUIButtonListItem*);
    4145    void ToggleBrowse();
     
    6064    //
    6165
    6266    MythUITextEdit      *m_titleEdit;
     67    MythUITextEdit      *m_subtitleEdit;
    6368    MythUITextEdit      *m_playerEdit;
     69    MythUISpinBox       *m_seasonSpin;
     70    MythUISpinBox       *m_episodeSpin;
    6471    MythUIButtonList      *m_categoryList;
    6572    MythUIButtonList      *m_levelList;
    6673    MythUIButtonList      *m_childList;
  • mythvideo/mythvideo/videodlg.cpp

     
    10161084
    10171085            tmp["filename"] = metadata->GetFilename();
    10181086            tmp["title"] = metadata->GetTitle();
     1087            tmp["subtitle"] = metadata->GetSubtitle();
    10191088            tmp["director"] = metadata->GetDirector();
    10201089            tmp["plot"] = metadata->GetPlot();
    10211090            tmp["genres"] = GetDisplayGenres(*metadata);
     
    10251094            tmp["length"] = GetDisplayLength(metadata->GetLength());
    10261095            tmp["year"] = GetDisplayYear(metadata->GetYear());
    10271096            tmp["userrating"] = GetDisplayUserRating(metadata->GetUserRating());
     1097            tmp["season"] = GetDisplaySeasonEpisode(metadata->GetSeason(), 1);
     1098            tmp["episode"] = GetDisplaySeasonEpisode(metadata->GetEpisode(), 1);
    10281099
     1100            if (metadata->GetSeason() > 0 && metadata->GetEpisode() >= 0)
     1101            {
     1102                tmp["s##e##"] = QString("s%1e%2").arg(GetDisplaySeasonEpisode
     1103                                                     (metadata->GetSeason(), 2))
     1104                                .arg(GetDisplaySeasonEpisode(metadata->GetEpisode(), 2));
     1105                tmp["##x##"] = QString("%1x%2").arg(GetDisplaySeasonEpisode
     1106                                                     (metadata->GetSeason(), 1))           
     1107                                .arg(GetDisplaySeasonEpisode(metadata->GetEpisode(), 2));
     1108            }
     1109            else
     1110                tmp["s##e##"] = tmp["##x##"] = "";
     1111
    10291112            tmp["userratingstate"] =
    10301113                    QString::number((int)(metadata->GetUserRating()));
    10311114            tmp["videolevel"] = ParentalLevelToState(metadata->GetShowLevel());
     
    10751158        h.handleText("player");
    10761159        h.handleText("filename");
    10771160        h.handleText("title");
     1161        h.handleText("subtitle");
    10781162        h.handleText("director");
    10791163        h.handleText("plot");
    10801164        h.handleText("genres");
     
    10821166        h.handleText("cast");
    10831167        h.handleText("rating");
    10841168        h.handleText("length");
     1169        h.handleText("season");
     1170        h.handleText("s##e##");
     1171        h.handleText("##x##");
     1172        h.handleText("episode");
    10851173        h.handleText("year");
    10861174        h.handleText("userrating");
    10871175
     
    30233130        }
    30243131        // set known values
    30253132        metadata->SetTitle(data["Title"]);
     3133        metadata->SetSubtitle(data["Subtitle"]);
    30263134        metadata->SetYear(data["Year"].toInt());
    30273135        metadata->SetDirector(data["Director"]);
    30283136        metadata->SetPlot(data["Plot"]);
    30293137        metadata->SetUserRating(data["UserRating"].toFloat());
    30303138        metadata->SetRating(data["MovieRating"]);
    30313139        metadata->SetLength(data["Runtime"].toInt());
     3140        metadata->SetSeason(data["Season"].toInt());
     3141        metadata->SetEpisode(data["Episode"].toInt());
    30323142
    30333143        m_d->AutomaticParentalAdjustment(metadata);
    30343144
  • mythvideo/mythvideo/videoscan.cpp

     
    268268                                 VIDEO_BANNER_DEFAULT,
    269269                                 VIDEO_FANART_DEFAULT,
    270270                                 Metadata::FilenameToTitle(p->first),
     271                                 VIDEO_SUBTITLE_DEFAULT,
    271272                                 VIDEO_YEAR_DEFAULT,
    272273                                 VIDEO_INETREF_DEFAULT, VIDEO_DIRECTOR_DEFAULT,
    273                                  VIDEO_PLOT_DEFAULT, 0.0, VIDEO_RATING_DEFAULT,
    274                                  0, 0, ParentalLevel::plLowest);
     274                                 VIDEO_PLOT_DEFAULT, 0.0, VIDEO_RATING_DEFAULT, 0,
     275                                 Metadata::FilenameToSeasonEpisode(p->first, 1),
     276                                 Metadata::FilenameToSeasonEpisode(p->first, 2),
     277                                 0, ParentalLevel::plLowest);
    275278
    276279                VERBOSE(VB_GENERAL, QString("Adding : %1 : %2")
    277280                        .arg(newFile.GetHost()).arg(newFile.GetFilename()));
  • mythvideo/mythvideo/videofilter.cpp

     
    353353            ret = lhs_key < rhs_key;
    354354            break;
    355355        }
     356        case kOrderBySeasonEp:
     357        {
     358            if (lhs.GetSeason() == rhs.GetSeason())
     359                ret = lhs.GetEpisode() < rhs.GetEpisode();
     360            else
     361                ret = lhs.GetSeason() < rhs.GetSeason();
     362            break;
     363        }
    356364        case kOrderByYearDescending:
    357365        {
    358366            ret = lhs.GetYear() > rhs.GetYear();
     
    649657    // Order by
    650658    new MythUIButtonListItem(m_orderbyList, QObject::tr("Title"),
    651659                           VideoFilterSettings::kOrderByTitle);
     660    new MythUIButtonListItem(m_orderbyList, QObject::tr("Season/Episode"),
     661                           VideoFilterSettings::kOrderBySeasonEp);
    652662    new MythUIButtonListItem(m_orderbyList, QObject::tr("Year"),
    653663                           VideoFilterSettings::kOrderByYearDescending);
    654664    new MythUIButtonListItem(m_orderbyList, QObject::tr("User Rating"),
  • mythvideo/mythvideo/metadata.h

     
    1313
    1414enum { VIDEO_YEAR_DEFAULT = 1895 };
    1515
     16const QString VIDEO_SUBTITLE_DEFAULT = "";
     17
    1618struct SortData;
    1719
    1820class Metadata
     
    4547  public:
    4648    static SortKey GenerateDefaultSortKey(const Metadata &m, bool ignore_case);
    4749    static QString FilenameToTitle(const QString &file_name);
     50    static unsigned int FilenameToSeasonEpisode(const QString &file_name,
     51                            int position);
    4852    static QString TrimTitle(const QString &title, bool ignore_case);
    4953
    5054  public:
     
    5559             const QString &banner = QString(),
    5660             const QString &fanart = QString(),
    5761             const QString &title = QString(),
     62             const QString &subtitle = QString(),
    5863             int year = VIDEO_YEAR_DEFAULT,
    5964             const QString &inetref = QString(),
    6065             const QString &director = QString(),
     
    6267             float userrating = 0.0,
    6368             const QString &rating = QString(),
    6469             int length = 0,
     70             int season = 0,
     71             int episode = 0,
    6572             int id = 0,
    6673             ParentalLevel::Level showlevel = ParentalLevel::plLowest,
    6774             int categoryID = 0,
     
    8996    const QString &GetTitle() const;
    9097    void SetTitle(const QString& title);
    9198
     99    const QString &GetSubtitle() const;
     100    void SetSubtitle(const QString &subtitle);
     101
    92102    int GetYear() const;
    93103    void SetYear(int year);
    94104
     
    110120    int GetLength() const;
    111121    void SetLength(int length);
    112122
     123    int GetSeason() const;
     124    void SetSeason(int season);
     125
     126    int GetEpisode() const;
     127    void SetEpisode(int episode);
     128
    113129    unsigned int GetID() const;
    114130    void SetID(int id);
    115131
  • mythvideo/mythvideo/editmetadata.cpp

     
    1212#include <mythtv/libmythui/mythuitextedit.h>
    1313#include <mythtv/libmythui/mythuibutton.h>
    1414#include <mythtv/libmythui/mythuicheckbox.h>
     15#include <mythtv/libmythui/mythuispinbox.h>
    1516
    1617#include "globals.h"
    1718#include "dbaccess.h"
     
    2223EditMetadataDialog::EditMetadataDialog(MythScreenStack *lparent,
    2324        QString lname, Metadata *source_metadata,
    2425        const MetadataListManager &cache) : MythScreenType(lparent, lname),
    25     m_origMetadata(source_metadata), m_titleEdit(0), m_playerEdit(0),
    26     m_categoryList(0), m_levelList(0), m_childList(0), m_browseCheck(0),
    27     m_coverartButton(0), m_coverartText(0),
     26    m_origMetadata(source_metadata), m_titleEdit(0), m_subtitleEdit(0),
     27    m_playerEdit(0), m_seasonSpin(0), m_episodeSpin(0),
     28    m_categoryList(0), m_levelList(0), m_childList(0),
     29    m_browseCheck(0), m_coverartButton(0), m_coverartText(0),
    2830    m_screenshotButton(0), m_screenshotText(0),
    2931    m_bannerButton(0), m_bannerText(0),
    3032    m_fanartButton(0), m_fanartText(0),
     
    4749
    4850    bool err = false;
    4951    UIUtilE::Assign(this, m_titleEdit, "title_edit", &err);
     52    UIUtilE::Assign(this, m_subtitleEdit, "subtitle_edit", &err);
    5053    UIUtilE::Assign(this, m_playerEdit, "player_edit", &err);
    5154
     55    UIUtilE::Assign(this, m_seasonSpin, "season", &err);
     56    UIUtilE::Assign(this, m_episodeSpin, "episode", &err);
     57
    5258    UIUtilE::Assign(this, m_coverartText, "coverart_text", &err);
    5359    UIUtilE::Assign(this, m_screenshotText, "screenshot_text", &err);
    5460    UIUtilE::Assign(this, m_bannerText, "banner_text", &err);
     
    7985        VERBOSE(VB_IMPORTANT, "Failed to build a focuslist.");
    8086
    8187    connect(m_titleEdit, SIGNAL(valueChanged()), SLOT(SetTitle()));
     88    connect(m_subtitleEdit, SIGNAL(valueChanged()), SLOT(SetSubtitle()));
    8289    connect(m_playerEdit, SIGNAL(valueChanged()), SLOT(SetPlayer()));
    8390
     91    connect(m_seasonSpin, SIGNAL(LosingFocus()), SLOT(SetSeason()));
     92    connect(m_episodeSpin, SIGNAL(LosingFocus()), SLOT(SetEpisode()));
     93
    8494    connect(m_doneButton, SIGNAL(Clicked()), SLOT(SaveAndExit()));
    8595    connect(m_coverartButton, SIGNAL(Clicked()), SLOT(FindCoverArt()));
    8696    connect(m_bannerButton, SIGNAL(Clicked()), SLOT(FindBanner()));
     
    154164void EditMetadataDialog::fillWidgets()
    155165{
    156166    m_titleEdit->SetText(m_workingMetadata->GetTitle());
     167    m_subtitleEdit->SetText(m_workingMetadata->GetSubtitle());
    157168
     169    m_seasonSpin->SetRange(0,100,1);
     170    m_seasonSpin->SetValue(m_workingMetadata->GetSeason());
     171    m_episodeSpin->SetRange(0,999,1);
     172    m_episodeSpin->SetValue(m_workingMetadata->GetEpisode());
     173
    158174    MythUIButtonListItem *button =
    159175        new MythUIButtonListItem(m_categoryList, VIDEO_CATEGORY_UNKNOWN);
    160176    const VideoCategory::entry_list &vcl =
     
    312328    m_workingMetadata->SetTitle(m_titleEdit->GetText());
    313329}
    314330
     331void EditMetadataDialog::SetSubtitle()
     332{
     333    m_workingMetadata->SetSubtitle(m_subtitleEdit->GetText());
     334}
     335
    315336void EditMetadataDialog::SetCategory(MythUIButtonListItem *item)
    316337{
    317338    m_workingMetadata->SetCategoryID(item->GetData().toInt());
    318339}
    319340
     341void EditMetadataDialog::SetSeason()
     342{
     343    m_workingMetadata->SetSeason(m_seasonSpin->GetIntValue());
     344}
     345
     346void EditMetadataDialog::SetEpisode()
     347{
     348    m_workingMetadata->SetEpisode(m_episodeSpin->GetIntValue());
     349}
     350
    320351void EditMetadataDialog::SetPlayer()
    321352{
    322353    m_workingMetadata->SetPlayCommand(m_playerEdit->GetText());
  • mythvideo/mythvideo/videoutils.h

     
    3333
    3434QString GetDisplayUserRating(float userrating);
    3535QString GetDisplayLength(int length);
     36QString GetDisplaySeasonEpisode(int seasEp, int digits);
    3637QString GetDisplayBrowse(bool browse);
    3738QString GetDisplayYear(int year);
    3839QString GetDisplayRating(const QString &rating);