├── .gitattributes
├── .gitignore
├── MKVToolNixWrapper.sln
├── MKVToolNixWrapper
├── App.xaml
├── App.xaml.cs
├── AssemblyInfo.cs
├── Assets
│ ├── Berserk.ico
│ ├── Info.txt
│ ├── SH2Menu.wav
│ ├── SH3Menu.wav
│ └── Screenshots
│ │ ├── Screenshot1.png
│ │ ├── Screenshot2.png
│ │ └── Screenshot3.png
├── Dtos
│ ├── FileMeta.cs
│ ├── FileStatusEnum.cs
│ ├── MkvIdentifyDto.cs
│ └── TrackListMeta.cs
├── MKVToolNixWrapper.csproj
├── MainWindow.xaml
└── MainWindow.xaml.cs
└── README.md
/.gitattributes:
--------------------------------------------------------------------------------
1 | ###############################################################################
2 | # Set default behavior to automatically normalize line endings.
3 | ###############################################################################
4 | * text=auto
5 |
6 | ###############################################################################
7 | # Set default behavior for command prompt diff.
8 | #
9 | # This is need for earlier builds of msysgit that does not have it on by
10 | # default for csharp files.
11 | # Note: This is only used by command line
12 | ###############################################################################
13 | #*.cs diff=csharp
14 |
15 | ###############################################################################
16 | # Set the merge driver for project and solution files
17 | #
18 | # Merging from the command prompt will add diff markers to the files if there
19 | # are conflicts (Merging from VS is not affected by the settings below, in VS
20 | # the diff markers are never inserted). Diff markers may cause the following
21 | # file extensions to fail to load in VS. An alternative would be to treat
22 | # these files as binary and thus will always conflict and require user
23 | # intervention with every merge. To do so, just uncomment the entries below
24 | ###############################################################################
25 | #*.sln merge=binary
26 | #*.csproj merge=binary
27 | #*.vbproj merge=binary
28 | #*.vcxproj merge=binary
29 | #*.vcproj merge=binary
30 | #*.dbproj merge=binary
31 | #*.fsproj merge=binary
32 | #*.lsproj merge=binary
33 | #*.wixproj merge=binary
34 | #*.modelproj merge=binary
35 | #*.sqlproj merge=binary
36 | #*.wwaproj merge=binary
37 |
38 | ###############################################################################
39 | # behavior for image files
40 | #
41 | # image files are treated as binary by default.
42 | ###############################################################################
43 | #*.jpg binary
44 | #*.png binary
45 | #*.gif binary
46 |
47 | ###############################################################################
48 | # diff behavior for common document formats
49 | #
50 | # Convert binary document formats to text before diffing them. This feature
51 | # is only available from the command line. Turn it on by uncommenting the
52 | # entries below.
53 | ###############################################################################
54 | #*.doc diff=astextplain
55 | #*.DOC diff=astextplain
56 | #*.docx diff=astextplain
57 | #*.DOCX diff=astextplain
58 | #*.dot diff=astextplain
59 | #*.DOT diff=astextplain
60 | #*.pdf diff=astextplain
61 | #*.PDF diff=astextplain
62 | #*.rtf diff=astextplain
63 | #*.RTF diff=astextplain
64 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | ## Ignore Visual Studio temporary files, build results, and
2 | ## files generated by popular Visual Studio add-ons.
3 | ##
4 | ## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore
5 |
6 | # User-specific files
7 | *.rsuser
8 | *.suo
9 | *.user
10 | *.userosscache
11 | *.sln.docstates
12 |
13 | # User-specific files (MonoDevelop/Xamarin Studio)
14 | *.userprefs
15 |
16 | # Mono auto generated files
17 | mono_crash.*
18 |
19 | # Build results
20 | [Dd]ebug/
21 | [Dd]ebugPublic/
22 | [Rr]elease/
23 | [Rr]eleases/
24 | x64/
25 | x86/
26 | [Ww][Ii][Nn]32/
27 | [Aa][Rr][Mm]/
28 | [Aa][Rr][Mm]64/
29 | bld/
30 | [Bb]in/
31 | [Oo]bj/
32 | [Oo]ut/
33 | [Ll]og/
34 | [Ll]ogs/
35 |
36 | # Visual Studio 2015/2017 cache/options directory
37 | .vs/
38 | # Uncomment if you have tasks that create the project's static files in wwwroot
39 | #wwwroot/
40 |
41 | # Visual Studio 2017 auto generated files
42 | Generated\ Files/
43 |
44 | # MSTest test Results
45 | [Tt]est[Rr]esult*/
46 | [Bb]uild[Ll]og.*
47 |
48 | # NUnit
49 | *.VisualState.xml
50 | TestResult.xml
51 | nunit-*.xml
52 |
53 | # Build Results of an ATL Project
54 | [Dd]ebugPS/
55 | [Rr]eleasePS/
56 | dlldata.c
57 |
58 | # Benchmark Results
59 | BenchmarkDotNet.Artifacts/
60 |
61 | # .NET Core
62 | project.lock.json
63 | project.fragment.lock.json
64 | artifacts/
65 |
66 | # ASP.NET Scaffolding
67 | ScaffoldingReadMe.txt
68 |
69 | # StyleCop
70 | StyleCopReport.xml
71 |
72 | # Files built by Visual Studio
73 | *_i.c
74 | *_p.c
75 | *_h.h
76 | *.ilk
77 | *.meta
78 | *.obj
79 | *.iobj
80 | *.pch
81 | *.pdb
82 | *.ipdb
83 | *.pgc
84 | *.pgd
85 | *.rsp
86 | *.sbr
87 | *.tlb
88 | *.tli
89 | *.tlh
90 | *.tmp
91 | *.tmp_proj
92 | *_wpftmp.csproj
93 | *.log
94 | *.vspscc
95 | *.vssscc
96 | .builds
97 | *.pidb
98 | *.svclog
99 | *.scc
100 |
101 | # Chutzpah Test files
102 | _Chutzpah*
103 |
104 | # Visual C++ cache files
105 | ipch/
106 | *.aps
107 | *.ncb
108 | *.opendb
109 | *.opensdf
110 | *.sdf
111 | *.cachefile
112 | *.VC.db
113 | *.VC.VC.opendb
114 |
115 | # Visual Studio profiler
116 | *.psess
117 | *.vsp
118 | *.vspx
119 | *.sap
120 |
121 | # Visual Studio Trace Files
122 | *.e2e
123 |
124 | # TFS 2012 Local Workspace
125 | $tf/
126 |
127 | # Guidance Automation Toolkit
128 | *.gpState
129 |
130 | # ReSharper is a .NET coding add-in
131 | _ReSharper*/
132 | *.[Rr]e[Ss]harper
133 | *.DotSettings.user
134 |
135 | # TeamCity is a build add-in
136 | _TeamCity*
137 |
138 | # DotCover is a Code Coverage Tool
139 | *.dotCover
140 |
141 | # AxoCover is a Code Coverage Tool
142 | .axoCover/*
143 | !.axoCover/settings.json
144 |
145 | # Coverlet is a free, cross platform Code Coverage Tool
146 | coverage*.json
147 | coverage*.xml
148 | coverage*.info
149 |
150 | # Visual Studio code coverage results
151 | *.coverage
152 | *.coveragexml
153 |
154 | # NCrunch
155 | _NCrunch_*
156 | .*crunch*.local.xml
157 | nCrunchTemp_*
158 |
159 | # MightyMoose
160 | *.mm.*
161 | AutoTest.Net/
162 |
163 | # Web workbench (sass)
164 | .sass-cache/
165 |
166 | # Installshield output folder
167 | [Ee]xpress/
168 |
169 | # DocProject is a documentation generator add-in
170 | DocProject/buildhelp/
171 | DocProject/Help/*.HxT
172 | DocProject/Help/*.HxC
173 | DocProject/Help/*.hhc
174 | DocProject/Help/*.hhk
175 | DocProject/Help/*.hhp
176 | DocProject/Help/Html2
177 | DocProject/Help/html
178 |
179 | # Click-Once directory
180 | publish/
181 |
182 | # Publish Web Output
183 | *.[Pp]ublish.xml
184 | *.azurePubxml
185 | # Note: Comment the next line if you want to checkin your web deploy settings,
186 | # but database connection strings (with potential passwords) will be unencrypted
187 | *.pubxml
188 | *.publishproj
189 |
190 | # Microsoft Azure Web App publish settings. Comment the next line if you want to
191 | # checkin your Azure Web App publish settings, but sensitive information contained
192 | # in these scripts will be unencrypted
193 | PublishScripts/
194 |
195 | # NuGet Packages
196 | *.nupkg
197 | # NuGet Symbol Packages
198 | *.snupkg
199 | # The packages folder can be ignored because of Package Restore
200 | **/[Pp]ackages/*
201 | # except build/, which is used as an MSBuild target.
202 | !**/[Pp]ackages/build/
203 | # Uncomment if necessary however generally it will be regenerated when needed
204 | #!**/[Pp]ackages/repositories.config
205 | # NuGet v3's project.json files produces more ignorable files
206 | *.nuget.props
207 | *.nuget.targets
208 |
209 | # Microsoft Azure Build Output
210 | csx/
211 | *.build.csdef
212 |
213 | # Microsoft Azure Emulator
214 | ecf/
215 | rcf/
216 |
217 | # Windows Store app package directories and files
218 | AppPackages/
219 | BundleArtifacts/
220 | Package.StoreAssociation.xml
221 | _pkginfo.txt
222 | *.appx
223 | *.appxbundle
224 | *.appxupload
225 |
226 | # Visual Studio cache files
227 | # files ending in .cache can be ignored
228 | *.[Cc]ache
229 | # but keep track of directories ending in .cache
230 | !?*.[Cc]ache/
231 |
232 | # Others
233 | ClientBin/
234 | ~$*
235 | *~
236 | *.dbmdl
237 | *.dbproj.schemaview
238 | *.jfm
239 | *.pfx
240 | *.publishsettings
241 | orleans.codegen.cs
242 |
243 | # Including strong name files can present a security risk
244 | # (https://github.com/github/gitignore/pull/2483#issue-259490424)
245 | #*.snk
246 |
247 | # Since there are multiple workflows, uncomment next line to ignore bower_components
248 | # (https://github.com/github/gitignore/pull/1529#issuecomment-104372622)
249 | #bower_components/
250 |
251 | # RIA/Silverlight projects
252 | Generated_Code/
253 |
254 | # Backup & report files from converting an old project file
255 | # to a newer Visual Studio version. Backup files are not needed,
256 | # because we have git ;-)
257 | _UpgradeReport_Files/
258 | Backup*/
259 | UpgradeLog*.XML
260 | UpgradeLog*.htm
261 | ServiceFabricBackup/
262 | *.rptproj.bak
263 |
264 | # SQL Server files
265 | *.mdf
266 | *.ldf
267 | *.ndf
268 |
269 | # Business Intelligence projects
270 | *.rdl.data
271 | *.bim.layout
272 | *.bim_*.settings
273 | *.rptproj.rsuser
274 | *- [Bb]ackup.rdl
275 | *- [Bb]ackup ([0-9]).rdl
276 | *- [Bb]ackup ([0-9][0-9]).rdl
277 |
278 | # Microsoft Fakes
279 | FakesAssemblies/
280 |
281 | # GhostDoc plugin setting file
282 | *.GhostDoc.xml
283 |
284 | # Node.js Tools for Visual Studio
285 | .ntvs_analysis.dat
286 | node_modules/
287 |
288 | # Visual Studio 6 build log
289 | *.plg
290 |
291 | # Visual Studio 6 workspace options file
292 | *.opt
293 |
294 | # Visual Studio 6 auto-generated workspace file (contains which files were open etc.)
295 | *.vbw
296 |
297 | # Visual Studio LightSwitch build output
298 | **/*.HTMLClient/GeneratedArtifacts
299 | **/*.DesktopClient/GeneratedArtifacts
300 | **/*.DesktopClient/ModelManifest.xml
301 | **/*.Server/GeneratedArtifacts
302 | **/*.Server/ModelManifest.xml
303 | _Pvt_Extensions
304 |
305 | # Paket dependency manager
306 | .paket/paket.exe
307 | paket-files/
308 |
309 | # FAKE - F# Make
310 | .fake/
311 |
312 | # CodeRush personal settings
313 | .cr/personal
314 |
315 | # Python Tools for Visual Studio (PTVS)
316 | __pycache__/
317 | *.pyc
318 |
319 | # Cake - Uncomment if you are using it
320 | # tools/**
321 | # !tools/packages.config
322 |
323 | # Tabs Studio
324 | *.tss
325 |
326 | # Telerik's JustMock configuration file
327 | *.jmconfig
328 |
329 | # BizTalk build output
330 | *.btp.cs
331 | *.btm.cs
332 | *.odx.cs
333 | *.xsd.cs
334 |
335 | # OpenCover UI analysis results
336 | OpenCover/
337 |
338 | # Azure Stream Analytics local run output
339 | ASALocalRun/
340 |
341 | # MSBuild Binary and Structured Log
342 | *.binlog
343 |
344 | # NVidia Nsight GPU debugger configuration file
345 | *.nvuser
346 |
347 | # MFractors (Xamarin productivity tool) working folder
348 | .mfractor/
349 |
350 | # Local History for Visual Studio
351 | .localhistory/
352 |
353 | # BeatPulse healthcheck temp database
354 | healthchecksdb
355 |
356 | # Backup folder for Package Reference Convert tool in Visual Studio 2017
357 | MigrationBackup/
358 |
359 | # Ionide (cross platform F# VS Code tools) working folder
360 | .ionide/
361 |
362 | # Fody - auto-generated XML schema
363 | FodyWeavers.xsd
--------------------------------------------------------------------------------
/MKVToolNixWrapper.sln:
--------------------------------------------------------------------------------
1 |
2 | Microsoft Visual Studio Solution File, Format Version 12.00
3 | # Visual Studio Version 17
4 | VisualStudioVersion = 17.2.32630.192
5 | MinimumVisualStudioVersion = 10.0.40219.1
6 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MKVToolNixWrapper", "MKVToolNixWrapper\MKVToolNixWrapper.csproj", "{656595C5-4917-4DB9-8037-CBA1567C4F64}"
7 | EndProject
8 | Global
9 | GlobalSection(SolutionConfigurationPlatforms) = preSolution
10 | Debug|Any CPU = Debug|Any CPU
11 | Release|Any CPU = Release|Any CPU
12 | EndGlobalSection
13 | GlobalSection(ProjectConfigurationPlatforms) = postSolution
14 | {656595C5-4917-4DB9-8037-CBA1567C4F64}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15 | {656595C5-4917-4DB9-8037-CBA1567C4F64}.Debug|Any CPU.Build.0 = Debug|Any CPU
16 | {656595C5-4917-4DB9-8037-CBA1567C4F64}.Release|Any CPU.ActiveCfg = Release|Any CPU
17 | {656595C5-4917-4DB9-8037-CBA1567C4F64}.Release|Any CPU.Build.0 = Release|Any CPU
18 | EndGlobalSection
19 | GlobalSection(SolutionProperties) = preSolution
20 | HideSolutionNode = FALSE
21 | EndGlobalSection
22 | GlobalSection(ExtensibilityGlobals) = postSolution
23 | SolutionGuid = {1E07A08A-C748-4FBB-BBB1-6C52A4498F4C}
24 | EndGlobalSection
25 | EndGlobal
26 |
--------------------------------------------------------------------------------
/MKVToolNixWrapper/App.xaml:
--------------------------------------------------------------------------------
1 |
6 |
7 |
8 |
9 |
10 |
--------------------------------------------------------------------------------
/MKVToolNixWrapper/App.xaml.cs:
--------------------------------------------------------------------------------
1 | using System.Windows;
2 |
3 | namespace MKVToolNixWrapper
4 | {
5 | ///
6 | /// Interaction logic for App.xaml
7 | ///
8 | public partial class App : Application
9 | {
10 | public App()
11 | {
12 |
13 | }
14 | }
15 | }
--------------------------------------------------------------------------------
/MKVToolNixWrapper/AssemblyInfo.cs:
--------------------------------------------------------------------------------
1 | using System.Windows;
2 |
3 | [assembly: ThemeInfo(
4 | ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located
5 | //(used if a resource is not found in the page,
6 | // or application resource dictionaries)
7 | ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located
8 | //(used if a resource is not found in the page,
9 | // app, or any theme specific resource dictionaries)
10 | )]
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Assets/Berserk.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/H3X1C/MKVToolNixWrapper/4fd5ccd4c93e51c5ce26152cfb2f6f2ac7612a9d/MKVToolNixWrapper/Assets/Berserk.ico
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Assets/Info.txt:
--------------------------------------------------------------------------------
1 | ==========================
2 | --- MKVToolNix Wrapper ---
3 | ==========================
4 |
5 | ------ Introduction ------
6 | This program is a wrapper for mkvmerge.exe which ships as part of MKVToolNix (collection of tools for .mkv files).
7 | This programs purpose is to facilitate the quick bulk editing of .MKV files, allowing you to edit audio, video and subtitle tracks.
8 | Editing includes removal of tracks, defaulting tracks, forcing tracks, renaming tracks and setting track language.
9 | It also accounts for scenarios where files have differing track setups, the analyse button flags offending files so they can be dealt with in isolation.
10 |
11 | -- Installing MKV Merge --
12 | The easiest way to get mkvmerge.exe is to download and install mkvtoolnix which you can find here: https://mkvtoolnix.download/downloads.html#windows
13 |
14 | ----- Best Practices -----
15 | Be consistent with naming! Here are some examples of practices to follow:
16 | e.g.
17 | Subtitle naming: 'English Full'
18 | Video naming: '' Removing video name if it's just being used for branding as it serves no purpose, media players will just call it Track 1
19 | Video langauge: 'und'
20 | Audio naming: 'Japanese'
21 |
22 | Only set the forced flag for subtitles! It makes sense to set this flag on english subtitles if the audio track is Japanese and you are are an english speaker.
23 | Advised to also set the default flag on the best suited sub title track, in most cases this will be the same track as the forced track.
24 | Also a good idea to default both the audio and video track
25 |
26 | ------ Instructions ------
27 | 1) Click 'Browse' and select the folder that contains your .mkv files (This can be at season level: "~\Attack On Titan (2013)\Season 1" or show level "~\Attack On Titan (2013)")
28 | 2) You will now see on the left panel a list of all the .mkv files it has found, double check this list contains the files you expect, you also have the opportunity to not include certain files, you can do this by unchecking them
29 | 3) When happy with your selection click the 'Analyse' button (This will use your first file as a comparison point and compare it against all other files in the directory you selected, it checks to ensure subtitle names, audio tracks,.. match)
30 | To see progress look at the 'Output:' at the bottom of the window
31 | 4) On completion of a successful analysis the 'Start Batch' button will now be enabled and the tracks table will be populated
32 | Now customise the track settings to your liking, keep in mind you can rename tracks and languages! (See FAQ below for explanations on what each column does)
33 | 5) click 'Start Batch' and watch the 'Output:' text to see the progress, upon completion you will find the outputted files in the 'MasteredFiles' folder (Located in same directory as your .mkv files)
34 | Your done, open your outputted files in your favourite media player to confirm they are as you expected!
35 |
36 | ---------- FAQ ----------
37 | Q) During analysis one or more of my files had a 'FAIL' so I am unable to click 'Start Batch', help!
38 | A) A file fails when there are differences in track count, track naming, track language and or track ordering when compared to the first file it analysed
39 | (Audio, Video and Subtitle each having their own set of tracks e.g. 'English Subs' is it's own subtitle track)
40 | FAILs can happen when authors of these files use a variety of sources to make up a season or just aren't very consistent with their settings
41 | To progress all you have to do is deselect the files that have the 'FAIL' status, you can see which have failed by reviewing the 'Output:' section / red highlighting.
42 | Once you have done this click 'Analyse' again, if all is well you should now have PASSES unlocking the 'Start Batch' button the track view panel.
43 |
44 | Q) What do the colours in the file list mean?
45 | A) Red = The file failed it's analysis | Dark Red = An error occured while writing the file during the batch process | Green = File successfully written as part of batch | Orange = File writing is in progress as part of batch
46 |
47 | Q) What does the 'Including' column mean in the Tracks table?
48 | A) If it is ticked it will be included as part of the outputted files, if it is unchecked the given track will be removed
49 | E.g. Deselecting the 'English' Audio will result in the outputted file no longer having a English audio track
50 |
51 | Q) What does the 'Id' column mean in the Tracks table?
52 | A) the track ID is a unique identifier assigned to each track within the container. A track refers to a specific type of data within the MKV file, such as video, audio, subtitles, or attachments.
53 | The track ID allows the media player or decoder to correctly identify and play each track. (You cannot edit this id in this tool)
54 |
55 | Q) What does the 'Name' column mean in the Tracks table?
56 | A) This is simply the display name for the given track that is shown in your media player when selecting subtitle tracks / audio tracks / video tracks e.g. 'English Signs & Songs'
57 | This field is also optional meaning you can delete the text and then your media player will simply reference your track via it's ID e.g. Track 1, Track 2,...
58 |
59 | Q) What does the 'Language' column mean in the Tracks table?
60 | A) Each track can be assigned a ISO 639-2 language code e.g. jpn,eng,... that identifies the language of the content in that track.
61 | This language code can help media players and other software to select and display the appropriate language for the user, such as for subtitles or audio tracks. You may edit this field!
62 |
63 | Q) What does the 'Type' column mean in the Tracks table?
64 | A) Each track can be assigned a track type that identifies the type of content in that track. This information is used by media players and other software to identify how to play and display the content in the track.
65 | e.g. Video track, Audio track, Subtitle track
66 |
67 | Q) What does the 'Codec' column mean in the Tracks table?
68 | A) Displays the type of codec used for the given track e.g. subtitle track could have a codec of type 'S_TEXT/ASS'
69 | This info is purely there to provide you with more information to more easily distinguish between the tracks
70 |
71 | Q) What does the 'Default Flag' column mean in the Tracks table?
72 | A) Each track can have a default flag that indicates whether that track should be used as the default track when playing the file.
73 | The default track is the track that is selected by default when the MKV file is played, without the user needing to manually choose it given they have subtitles turned on globally for the player.
74 | e.g. if you set the 'English Subs' track as default your media player will automatically select this track
75 | Note: Not all media players respect this flag
76 |
77 | Q) What does the 'Forced Flag' column mean in the Tracks table?
78 | A) The "forced flag" is a metadata attribute that can be assigned to certain subtitle tracks to indicate that the subtitles in that track should always be displayed, even if the user has turned off subtitles.
79 | It is typically used for subtitles that are essential to the understanding of the content.
80 | Note: Not all media players respect this flag and this flag is only applicable to Subtitle tracks!
81 |
82 | -------- Changelog -------
83 | 15/02/2023 - v1.0.0.0 - Initial release
84 |
85 | 15/02/2023 - v1.0.0.1 - Code cleanup
86 | Removed uneeded usings
87 | Renamed and better organised DTO's
88 | Removed filelistbox from the disable ui method that occurs during batch and analysis
89 | Updated the info file instructions
90 |
91 | 15/02/2023 - v1.0.0.2 - QOL changes
92 | Progress % output on batching now updates the line instead of output a new line for each percent
93 | Track spawned mkvmerge processes and kill them on exit
94 | Added basic taskbar progress support
95 | Added a deselect fails button for the file list
96 |
97 | 23/07/2023 - v1.0.0.3 - Attachment analysis
98 | During analysis step files are scanned for attachments and a summary of attachment count is provided and of which are cover art
99 | Added remove attachments checkbox (When ticked will remove all attachments (cover art, fonts etc.) during processing) - Useful for removing watermarked cover art
100 | Fixed bug with some buttons in the UI being placed incorrectly when window maximised
101 |
102 | 29/07/2023 - v1.0.0.4 - Custom MKV path & UI Fix
103 | Select Unprocessed is now correctly disabled during analysis and batching process
104 | If MkvMerge cannot be found in the default install location (C:\Program Files\MKVToolNix\mkvmerge.exe) user will be prompted to select a custom location which is saved to config
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Assets/SH2Menu.wav:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/H3X1C/MKVToolNixWrapper/4fd5ccd4c93e51c5ce26152cfb2f6f2ac7612a9d/MKVToolNixWrapper/Assets/SH2Menu.wav
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Assets/SH3Menu.wav:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/H3X1C/MKVToolNixWrapper/4fd5ccd4c93e51c5ce26152cfb2f6f2ac7612a9d/MKVToolNixWrapper/Assets/SH3Menu.wav
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Assets/Screenshots/Screenshot1.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/H3X1C/MKVToolNixWrapper/4fd5ccd4c93e51c5ce26152cfb2f6f2ac7612a9d/MKVToolNixWrapper/Assets/Screenshots/Screenshot1.png
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Assets/Screenshots/Screenshot2.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/H3X1C/MKVToolNixWrapper/4fd5ccd4c93e51c5ce26152cfb2f6f2ac7612a9d/MKVToolNixWrapper/Assets/Screenshots/Screenshot2.png
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Assets/Screenshots/Screenshot3.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/H3X1C/MKVToolNixWrapper/4fd5ccd4c93e51c5ce26152cfb2f6f2ac7612a9d/MKVToolNixWrapper/Assets/Screenshots/Screenshot3.png
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Dtos/FileMeta.cs:
--------------------------------------------------------------------------------
1 | namespace MKVToolNixWrapper.Dtos
2 | {
3 | public class FileMeta
4 | {
5 | public string FilePath { get; set; }
6 | public bool Include { get; set; }
7 | public FileStatusEnum Status { get; set; }
8 | }
9 | }
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Dtos/FileStatusEnum.cs:
--------------------------------------------------------------------------------
1 | namespace MKVToolNixWrapper.Dtos
2 | {
3 | public enum FileStatusEnum
4 | {
5 | Unprocessed = 0, // No colour
6 | PassedAnalysis = 1, // No colour
7 | FailedAnalysis = 2, // Red
8 | WritingFile = 3, // Orange
9 | WrittenFile = 4, // Green
10 | Error = 5 // Dark Red
11 | }
12 | }
--------------------------------------------------------------------------------
/MKVToolNixWrapper/Dtos/MkvIdentifyDto.cs:
--------------------------------------------------------------------------------
1 | using System.Collections.Generic;
2 |
3 | namespace MKVToolNixWrapper
4 | {
5 | public class Properties
6 | {
7 | public double uid { get; set; }
8 | }
9 |
10 | public class Attachment
11 | {
12 | public string content_type { get; set; }
13 | public string description { get; set; }
14 | public string file_name { get; set; }
15 | public double id { get; set; }
16 | public Properties properties { get; set; }
17 | public double size { get; set; }
18 | }
19 |
20 | public class Chapter
21 | {
22 | public double num_entries { get; set; }
23 | }
24 |
25 | public class ContainerProperties
26 | {
27 | public double container_type { get; set; }
28 | public string date_local { get; set; }
29 | public string date_utc { get; set; }
30 | public long duration { get; set; }
31 | public bool is_providing_timestamps { get; set; }
32 | public string muxing_application { get; set; }
33 | public string segment_uid { get; set; }
34 | public string title { get; set; }
35 | public string writing_application { get; set; }
36 | }
37 |
38 | public class Container
39 | {
40 | public ContainerProperties properties { get; set; }
41 | public bool recognized { get; set; }
42 | public bool supported { get; set; }
43 | public string type { get; set; }
44 | }
45 |
46 | public class Properties2
47 | {
48 | public string codec_id { get; set; }
49 | public string codec_private_data { get; set; }
50 | public double codec_private_length { get; set; }
51 | public double default_duration { get; set; }
52 | public bool default_track { get; set; }
53 | public bool enabled_track { get; set; }
54 | public bool forced_track { get; set; }
55 | public string language { get; set; }
56 | public double minimum_timestamp { get; set; }
57 | public double number { get; set; }
58 | public string packetizer { get; set; }
59 | public string pixel_dimensions { get; set; }
60 | public double uid { get; set; }
61 | public string track_name { get; set; }
62 | }
63 |
64 | public class Track
65 | {
66 | public string codec { get; set; }
67 | public double id { get; set; }
68 | public Properties2 properties { get; set; }
69 | public string type { get; set; }
70 | }
71 |
72 | public class RootObject
73 | {
74 | public List attachments { get; set; }
75 | public List chapters { get; set; }
76 | public Container container { get; set; }
77 | public List