More movie 2.0 stuff

This commit is contained in:
adelikat 2014-06-12 11:53:25 +00:00
parent d2ea92d254
commit 3dce396261
9 changed files with 79 additions and 47 deletions

View File

@ -148,8 +148,8 @@
<Compile Include="movie\MnemonicGenerators\NesMnemonicGenerator.cs" />
<Compile Include="movie\MnemonicsGenerator.cs" />
<Compile Include="movie\MovieImport.cs" />
<Compile Include="movie\MovieLoader.cs" />
<Compile Include="movie\MovieMnemonics.cs" />
<Compile Include="movie\MovieService.cs" />
<Compile Include="movie\MovieSession.cs" />
<Compile Include="movie\MultitrackRecording.cs" />
<Compile Include="movie\MnemonicsLookupTable.cs" />

View File

@ -119,7 +119,7 @@ namespace BizHawk.Client.Common
m = ImportZMV(path, out errorMsg, out warningMsg);
break;
}
if (errorMsg == String.Empty)
if (errorMsg == string.Empty)
{
m.Header[HeaderKeys.MOVIEVERSION] = HeaderKeys.MovieVersion1;
}
@ -198,7 +198,7 @@ namespace BizHawk.Client.Common
{
controllers["Reset"] = (sections[1][0] == '1');
// Get the first invalid command warning message that arises.
if (String.IsNullOrEmpty((warningMsg)))
if (string.IsNullOrEmpty((warningMsg)))
{
switch (sections[1][0])
{
@ -325,12 +325,12 @@ namespace BizHawk.Client.Common
// Import a text-based movie format. This works for .FM2, .MC2, and .YMV.
private static Movie ImportText(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileInfo file = new FileInfo(path);
StreamReader sr = file.OpenText();
string emulator = String.Empty;
string platform = String.Empty;
string emulator = string.Empty;
string platform = string.Empty;
switch (Path.GetExtension(path).ToUpper())
{
case ".FM2":
@ -522,8 +522,8 @@ namespace BizHawk.Client.Common
// FCM file format: http://code.google.com/p/fceu/wiki/FCM
private static Movie ImportFCM(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 4-byte signature: 46 43 4D 1A "FCM\x1A"
@ -774,8 +774,8 @@ namespace BizHawk.Client.Common
// FMV file format: http://tasvideos.org/FMV.html
private static Movie ImportFMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 4-byte signature: 46 4D 56 1A "FMV\x1A"
@ -914,8 +914,8 @@ namespace BizHawk.Client.Common
// GMV file format: http://code.google.com/p/gens-rerecording/wiki/GMV
private static Movie ImportGMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 16-byte signature and format version: "Gens Movie TEST9"
@ -1038,8 +1038,8 @@ namespace BizHawk.Client.Common
// LSMV file format: http://tasvideos.org/Lsnes/Movieformat.html
private static Movie ImportLSMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
HawkFile hf = new HawkFile(path);
// .LSMV movies are .zip files containing data files.
if (!hf.IsArchive)
@ -1270,8 +1270,8 @@ namespace BizHawk.Client.Common
*/
private static Movie ImportMCM(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 8-byte "MDFNMOVI" signature
@ -1391,8 +1391,8 @@ namespace BizHawk.Client.Common
// MMV file format: http://tasvideos.org/MMV.html
private static Movie ImportMMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 0000: 4-byte signature: "MMV\0"
@ -1459,7 +1459,7 @@ namespace BizHawk.Client.Common
m.Header[HeaderKeys.GAMENAME] = gameName;
// 00e4-00f3: binary: rom MD5 digest
byte[] md5 = r.ReadBytes(16);
m.Header[MD5] = String.Format("{0:x8}", Util.BytesToHexString(md5).ToLower());
m.Header[MD5] = string.Format("{0:x8}", Util.BytesToHexString(md5).ToLower());
SimpleController controllers = new SimpleController {Type = new ControllerDefinition {Name = "SMS Controller"}};
/*
76543210
@ -1505,8 +1505,8 @@ namespace BizHawk.Client.Common
// NMV file format: http://tasvideos.org/NMV.html
private static Movie ImportNMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 4-byte signature: 4E 53 53 1A "NSS\x1A"
@ -1732,8 +1732,8 @@ namespace BizHawk.Client.Common
private static Movie ImportSMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 4-byte signature: 53 4D 56 1A "SMV\x1A"
@ -2003,8 +2003,8 @@ namespace BizHawk.Client.Common
// VBM file format: http://code.google.com/p/vba-rerecording/wiki/VBM
private static Movie ImportVBM(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 4-byte signature: 56 42 4D 1A "VBM\x1A"
@ -2273,8 +2273,8 @@ namespace BizHawk.Client.Common
// VMV file format: http://tasvideos.org/VMV.html
private static Movie ImportVMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 12-byte signature: "VirtuaNES MV"
@ -2497,8 +2497,8 @@ namespace BizHawk.Client.Common
// ZMV file format: http://tasvideos.org/ZMV.html
private static Movie ImportZMV(string path, out string errorMsg, out string warningMsg)
{
errorMsg = warningMsg = String.Empty;
Movie m = new Movie(path + "." + Movie.Extension);
errorMsg = warningMsg = string.Empty;
Movie m = new Movie(path + "." + MovieService.DefaultExtension);
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
BinaryReader r = new BinaryReader(fs);
// 000 3-byte signature: 5A 4D 56 "ZMV"

View File

@ -4,15 +4,40 @@ using System.IO;
using System.Linq;
using System.Text;
using BizHawk.Common;
namespace BizHawk.Client.Common
{
public static class MovieService
{
public static IMovie Load(string path)
public static IMovie Get(string path)
{
// TODO: open the file and determine the format, and instantiate the appropriate implementation
// Currently we just assume it is a bkm implementation
// TODO: change IMovies to take HawkFiles only and not path
return new Movie(path);
}
/// <summary>
/// Gets the file extension for the default movie implementation used in the client
/// </summary>
public static string DefaultExtension
{
get { return "bkm"; }
}
/// <summary>
/// Returns a list of extensions for all IMovie implementations
/// </summary>
public static IEnumerable<string> MovieExtensions
{
// Movies 2.0 TODO: consider using reflection to find IMovie implementations
get
{
yield return "bkm";
yield return "bk2";
yield return "tasproj";
}
}
}
}

View File

@ -154,6 +154,11 @@ namespace BizHawk.Client.Common
}
}
public void SaveBackup()
{
throw new NotImplementedException();
}
public bool IsActive
{
get { return _mode != Moviemode.Inactive; }

View File

@ -156,9 +156,6 @@ namespace BizHawk.Client.Common
public string PreferredExtension { get { return "bkm"; } }
// Movies 2.0 TODO: delete me
public static string Extension { get { return "bkm"; } }
public MovieHeader Header { get; private set; }
public string Filename { get; set; }

View File

@ -72,6 +72,11 @@ namespace BizHawk.Client.Common
/// </summary>
IDictionary<string, string> HeaderEntries { get; }
/// <summary>
/// Forces the creation of a backup file of the current movie state
/// </summary>
void SaveBackup();
#endregion
#region File Handling API

View File

@ -202,6 +202,11 @@ namespace BizHawk.Client.Common
}
}
public void SaveBackup()
{
throw new NotImplementedException();
}
public string Filename { get; set; }
public MovieHeader Header { get; private set; }

View File

@ -1794,8 +1794,7 @@ namespace BizHawk.Client.EmuHawk
SaveMovieContextMenuItem.Visible =
Global.MovieSession.Movie.IsActive;
// Movies 2.0 TODO
BackupMovieContextMenuItem.Visible = Global.MovieSession.Movie is Movie && Global.MovieSession.Movie.IsActive;
BackupMovieContextMenuItem.Visible = Global.MovieSession.Movie.IsActive;
StopNoSaveContextMenuItem.Visible = Global.MovieSession.Movie.IsActive && Global.MovieSession.Movie.Changes;
@ -1904,12 +1903,8 @@ namespace BizHawk.Client.EmuHawk
private void BackupMovieContextMenuItem_Click(object sender, EventArgs e)
{
//Movies 2.0 TODO
if (Global.MovieSession.Movie is Movie)
{
GlobalWin.OSD.AddMessage("Backup movie saved.");
(Global.MovieSession.Movie as Movie).SaveBackup();
}
(Global.MovieSession.Movie as Movie).SaveBackup();
GlobalWin.OSD.AddMessage("Backup movie saved.");
}
private void ViewSubtitlesContextMenuItem_Click(object sender, EventArgs e)
@ -2217,8 +2212,6 @@ namespace BizHawk.Client.EmuHawk
else if (MovieImport.IsValidMovieExtension(Path.GetExtension(filePaths[0])))
{
// Movies 2.0 TODO: rethink this method
//tries to open a legacy movie format as if it were a BKM, by importing it
if (CurrentlyOpenRom == null)
{
@ -2241,10 +2234,11 @@ namespace BizHawk.Client.EmuHawk
// fix movie extension to something palatable for these purposes.
// for instance, something which doesnt clobber movies you already may have had.
// i'm evenly torn between this, and a file in %TEMP%, but since we dont really have a way to clean up this tempfile, i choose this:
movie.Filename += ".autoimported." + Movie.Extension;
movie.Filename += ".autoimported." + MovieService.DefaultExtension;
movie.Save();
StartNewMovie(movie, false);
}
GlobalWin.OSD.AddMessage(warningMsg);
}
else

View File

@ -257,8 +257,9 @@ namespace BizHawk.Client.EmuHawk
foreach(var subdir in Directory.GetDirectories(dp))
dpTodo.Enqueue(subdir);
// Movies 2.0 TODO: add tasproj, hardcoded is okay here
//add movies
fpTodo.AddRange(Directory.GetFiles(dp, "*." + Movie.Extension));
fpTodo.AddRange(Directory.GetFiles(dp, "*." + MovieService.DefaultExtension));
}
//in parallel, scan each movie
@ -606,7 +607,7 @@ namespace BizHawk.Client.EmuHawk
var ofd = new OpenFileDialog
{
// Movies 2.0 TODO - add tasproj in addition to default, hardcoded is fine in this case
Filter = "Movie Files (*." + Movie.Extension + ")|*." + MovieService.DefaultExtension + "|All Files|*.*",
Filter = "Movie Files (*." + MovieService.DefaultExtension + ")|*." + MovieService.DefaultExtension + "|All Files|*.*",
InitialDirectory = PathManager.MakeAbsolutePath(Global.Config.PathEntries.MoviesPathFragment, null)
};