1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 08:02:55 +08:00

Initial documentation pass on BeatmapStore

This commit is contained in:
Dean Herbert 2017-07-26 22:48:16 +09:00
parent 898a601098
commit 99e53b5109

View File

@ -108,6 +108,7 @@ namespace osu.Game.Beatmaps
/// <summary> /// <summary>
/// Delete a beatmap from the store. /// Delete a beatmap from the store.
/// Is a no-op for already deleted beatmaps.
/// </summary> /// </summary>
/// <param name="beatmapSet">The beatmap to delete.</param> /// <param name="beatmapSet">The beatmap to delete.</param>
public void Delete(BeatmapSetInfo beatmapSet) public void Delete(BeatmapSetInfo beatmapSet)
@ -118,6 +119,11 @@ namespace osu.Game.Beatmaps
files.Dereference(beatmapSet.Files); files.Dereference(beatmapSet.Files);
} }
/// <summary>
/// Returns a <see cref="BeatmapSetInfo"/> to a usable state if it has previously been deleted but not yet purged.
/// Is a no-op for already usable beatmaps.
/// </summary>
/// <param name="beatmapSet">The beatmap to restore.</param>
public void Undelete(BeatmapSetInfo beatmapSet) public void Undelete(BeatmapSetInfo beatmapSet)
{ {
if (!Database.Undelete(beatmapSet)) return; if (!Database.Undelete(beatmapSet)) return;
@ -125,6 +131,12 @@ namespace osu.Game.Beatmaps
files.Reference(beatmapSet.Files); files.Reference(beatmapSet.Files);
} }
/// <summary>
/// Retrieve a <see cref="WorkingBeatmap"/> instance for the provided <see cref="BeatmapInfo"/>
/// </summary>
/// <param name="beatmapInfo">The beatmap to lookup.</param>
/// <param name="previous">The currently loaded <see cref="WorkingBeatmap"/>. Allows for optimisation where elements are shared with the new beatmap.</param>
/// <returns>A <see cref="WorkingBeatmap"/> instance correlating to the provided <see cref="BeatmapInfo"/>.</returns>
public WorkingBeatmap GetWorkingBeatmap(BeatmapInfo beatmapInfo, WorkingBeatmap previous = null) public WorkingBeatmap GetWorkingBeatmap(BeatmapInfo beatmapInfo, WorkingBeatmap previous = null)
{ {
if (beatmapInfo == null || beatmapInfo == DefaultBeatmap?.BeatmapInfo) if (beatmapInfo == null || beatmapInfo == DefaultBeatmap?.BeatmapInfo)
@ -155,6 +167,11 @@ namespace osu.Game.Beatmaps
Database.Reset(); Database.Reset();
} }
/// <summary>
/// Creates an <see cref="ArchiveReader"/> from a valid storage path.
/// </summary>
/// <param name="path">A file or folder path resolving the beatmap content.</param>
/// <returns>A reader giving access to the beatmap's content.</returns>
private ArchiveReader getReaderFrom(string path) private ArchiveReader getReaderFrom(string path)
{ {
if (ZipFile.IsZipFile(path)) if (ZipFile.IsZipFile(path))
@ -163,20 +180,26 @@ namespace osu.Game.Beatmaps
return new LegacyFilesystemReader(path); return new LegacyFilesystemReader(path);
} }
private BeatmapSetInfo importToStorage(ArchiveReader archiveReader) /// <summary>
/// Import a beamap into our local <see cref="FileDatabase"/> storage.
/// If the beatmap is already imported, the existing instance will be returned.
/// </summary>
/// <param name="reader">The beatmap archive to be read.</param>
/// <returns>The imported beatmap, or an existing instance if it is already present.</returns>
private BeatmapSetInfo importToStorage(ArchiveReader reader)
{ {
BeatmapMetadata metadata; BeatmapMetadata metadata;
using (var stream = new StreamReader(archiveReader.GetStream(archiveReader.Filenames.First(f => f.EndsWith(".osu"))))) using (var stream = new StreamReader(reader.GetStream(reader.Filenames.First(f => f.EndsWith(".osu")))))
metadata = BeatmapDecoder.GetDecoder(stream).Decode(stream).Metadata; metadata = BeatmapDecoder.GetDecoder(stream).Decode(stream).Metadata;
MemoryStream hashable = new MemoryStream(); MemoryStream hashable = new MemoryStream();
List<FileInfo> fileInfos = new List<FileInfo>(); List<FileInfo> fileInfos = new List<FileInfo>();
foreach (string file in archiveReader.Filenames) foreach (string file in reader.Filenames)
{ {
using (Stream s = archiveReader.GetStream(file)) using (Stream s = reader.GetStream(file))
{ {
fileInfos.Add(files.Add(s, file)); fileInfos.Add(files.Add(s, file));
s.CopyTo(hashable); s.CopyTo(hashable);
@ -190,9 +213,7 @@ namespace osu.Game.Beatmaps
if (existing != null) if (existing != null)
{ {
Database.GetChildren(existing); Database.GetChildren(existing);
Undelete(existing); Undelete(existing);
return existing; return existing;
} }
@ -205,11 +226,11 @@ namespace osu.Game.Beatmaps
Metadata = metadata Metadata = metadata
}; };
var mapNames = archiveReader.Filenames.Where(f => f.EndsWith(".osu")); var mapNames = reader.Filenames.Where(f => f.EndsWith(".osu"));
foreach (var name in mapNames) foreach (var name in mapNames)
{ {
using (var raw = archiveReader.GetStream(name)) using (var raw = reader.GetStream(name))
using (var ms = new MemoryStream()) //we need a memory stream so we can seek and shit using (var ms = new MemoryStream()) //we need a memory stream so we can seek and shit
using (var sr = new StreamReader(ms)) using (var sr = new StreamReader(ms))
{ {