Example #1
0
        /// <summary>
        /// Creates an <see cref="SVR_AnimeGroup"/> instance.
        /// </summary>
        /// <remarks>
        /// This method only creates an <see cref="SVR_AnimeGroup"/> instance. It does NOT save it to the database.
        /// </remarks>
        /// <param name="session">The NHibernate session.</param>
        /// <param name="mainSeries">The <see cref="SVR_AnimeSeries"/> whose name will represent the group (Optional. Pass <c>null</c> if not available).</param>
        /// <param name="mainAnimeId">The ID of the anime whose name will represent the group if <paramref name="mainSeries"/> is <c>null</c>.</param>
        /// <param name="now">The current date/time.</param>
        /// <returns>The created <see cref="SVR_AnimeGroup"/>.</returns>
        private SVR_AnimeGroup CreateAnimeGroup(SVR_AnimeSeries mainSeries, int mainAnimeId,
                                                DateTime now)
        {
            SVR_AnimeGroup animeGroup = new SVR_AnimeGroup();
            string         groupName;

            if (mainSeries != null)
            {
                animeGroup.Populate_RA(mainSeries, now);
                groupName = animeGroup.GroupName;
            }
            else // The anime chosen as the group's main anime doesn't actually have a series
            {
                SVR_AniDB_Anime mainAnime = Repo.Instance.AniDB_Anime.GetByAnimeID(mainAnimeId);

                animeGroup.Populate_RA(mainAnime, now);
                groupName = animeGroup.GroupName;
            }

            // If the title appears to end with a year suffix, then remove it
            groupName            = _truncateYearRegex.Replace(groupName, string.Empty);
            animeGroup.GroupName = groupName;
            animeGroup.SortName  = groupName;

            return(animeGroup);
        }
Example #2
0
 public static void Populate_RA(this SVR_AnimeGroup agroup_ra, SVR_AnimeSeries series)
 {
     agroup_ra.Populate_RA(series, DateTime.Now);
 }