/// <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); }
public static void Populate_RA(this SVR_AnimeGroup agroup_ra, SVR_AnimeSeries series) { agroup_ra.Populate_RA(series, DateTime.Now); }