Diff
checker
Texte
Texte
Images
Documents
Excel
Dossiers
Legal
Enterprise
Application de bureau
Prix
Se connecter
Télécharger Diffchecker Desktop
Comparer le texte
Trouver la différence entre deux fichiers texte
Outils
Historique
Éditeur live
Cacher identiques
Sans retour à la ligne
Vue
Divisé
Unifié
Niveau de précision
Intelligent
Mot
Caractère
Coloration syntaxique
Choisir la syntaxe
Ignorer
Transformer le texte
Aller au premier écart
Modifier l'entrée
Diffchecker Desktop
La façon la plus sécurisée d'utiliser Diffchecker. Obtenez l'application Diffchecker Desktop : vos diffs ne quittent jamais votre ordinateur !
Obtenir Desktop
Untitled diff
Créé
il y a 8 ans
Le diff n'expire jamais
Effacer
Exporter
Partager
Expliquer
3 suppressions
Lignes
Total
Supprimé
Caractères
Total
Supprimé
Pour continuer à utiliser cette fonctionnalité, passez à
Diff
checker
Pro
Voir les prix
64 lignes
Copier tout
17 ajouts
Lignes
Total
Ajouté
Caractères
Total
Ajouté
Pour continuer à utiliser cette fonctionnalité, passez à
Diff
checker
Pro
Voir les prix
75 lignes
Copier tout
Copier
Copié
Copier
Copié
#if UNITY_EDITOR
using System;
using System;
using System.Collections.Generic;
using System.Collections.Generic;
Copier
Copié
Copier
Copié
using System.Globalization;
using System.Text;
using System.Text;
using UnityEditor;
using UnityEditor;
using UnityEditor.Compilation;
using UnityEditor.Compilation;
using UnityEngine;
using UnityEngine;
Copier
Copié
Copier
Copié
/// <summary>
/// https://gist.github.com/karljj1/9c6cce803096b5cd4511cf0819ff517b
/// </summary>
[InitializeOnLoad]
[InitializeOnLoad]
public class AsmdefDebug
public class AsmdefDebug
{
{
const string AssemblyReloadEventsEditorPref = "AssemblyReloadEventsTime";
const string AssemblyReloadEventsEditorPref = "AssemblyReloadEventsTime";
const string AssemblyCompilationEventsEditorPref = "AssemblyCompilationEvents";
const string AssemblyCompilationEventsEditorPref = "AssemblyCompilationEvents";
static readonly int ScriptAssembliesPathLen = "Library/ScriptAssemblies/".Length;
static readonly int ScriptAssembliesPathLen = "Library/ScriptAssemblies/".Length;
Copier
Copié
Copier
Copié
private static string AssemblyTotalCompilationTimeEditorPref = "AssemblyTotalCompilationTime";
static Dictionary<string, DateTime> s_StartTimes = new Dictionary<string, DateTime>();
static Dictionary<string, DateTime> s_StartTimes = new Dictionary<string, DateTime>();
static StringBuilder s_BuildEvents = new StringBuilder();
static StringBuilder s_BuildEvents = new StringBuilder();
static double s_CompilationTotalTime;
static double s_CompilationTotalTime;
static AsmdefDebug()
static AsmdefDebug()
{
{
CompilationPipeline.assemblyCompilationStarted += CompilationPipelineOnAssemblyCompilationStarted;
CompilationPipeline.assemblyCompilationStarted += CompilationPipelineOnAssemblyCompilationStarted;
CompilationPipeline.assemblyCompilationFinished += CompilationPipelineOnAssemblyCompilationFinished;
CompilationPipeline.assemblyCompilationFinished += CompilationPipelineOnAssemblyCompilationFinished;
AssemblyReloadEvents.beforeAssemblyReload += AssemblyReloadEventsOnBeforeAssemblyReload;
AssemblyReloadEvents.beforeAssemblyReload += AssemblyReloadEventsOnBeforeAssemblyReload;
AssemblyReloadEvents.afterAssemblyReload += AssemblyReloadEventsOnAfterAssemblyReload;
AssemblyReloadEvents.afterAssemblyReload += AssemblyReloadEventsOnAfterAssemblyReload;
}
}
static void CompilationPipelineOnAssemblyCompilationStarted(string assembly)
static void CompilationPipelineOnAssemblyCompilationStarted(string assembly)
{
{
s_StartTimes[assembly] = DateTime.UtcNow;
s_StartTimes[assembly] = DateTime.UtcNow;
}
}
static void CompilationPipelineOnAssemblyCompilationFinished(string assembly, CompilerMessage[] arg2)
static void CompilationPipelineOnAssemblyCompilationFinished(string assembly, CompilerMessage[] arg2)
{
{
Copier
Copié
Copier
Copié
var time = s_StartTimes[assembly];
var timeSpan = DateTime.UtcNow - s_StartTimes[assembly];
var timeSpan = DateTime.UtcNow - s_StartTimes[assembly];
s_CompilationTotalTime += timeSpan.TotalMilliseconds;
s_CompilationTotalTime += timeSpan.TotalMilliseconds;
Copier
Copié
Copier
Copié
s_BuildEvents.AppendFormat("{0:0.00}s {1}\n", timeSpan.TotalMilliseconds / 1000f,
assembly.Substring(ScriptAssembliesPathLen, assembly.Length - ScriptAssembliesPathLen));
s_BuildEvents.AppendFormat("{0:0.00}s {1}\n", timeSpan.TotalMilliseconds / 1000f,
assembly.Substring(ScriptAssembliesPathLen, assembly.Length - ScriptAssembliesPathLen));
}
}
static void AssemblyReloadEventsOnBeforeAssemblyReload()
static void AssemblyReloadEventsOnBeforeAssemblyReload()
{
{
Copier
Copié
Copier
Copié
s_BuildEvents.AppendFormat("compilation total: {0:0.00}s\n",
s_CompilationTotalTime / 1000f
);
var totalCompilationTimeSeconds = s_CompilationTotalTime / 1000f;
s_BuildEvents.AppendFormat("compilation total: {0:0.00}s\n",
totalCompilationTimeSeconds
);
EditorPrefs.SetString(AssemblyReloadEventsEditorPref, DateTime.UtcNow.ToBinary().ToString());
EditorPrefs.SetString(AssemblyReloadEventsEditorPref, DateTime.UtcNow.ToBinary().ToString());
EditorPrefs.SetString(AssemblyCompilationEventsEditorPref, s_BuildEvents.ToString());
EditorPrefs.SetString(AssemblyCompilationEventsEditorPref, s_BuildEvents.ToString());
Copier
Copié
Copier
Copié
EditorPrefs.SetString(AssemblyTotalCompilationTimeEditorPref, totalCompilationTimeSeconds.ToString(CultureInfo.InvariantCulture));
}
}
static void AssemblyReloadEventsOnAfterAssemblyReload()
static void AssemblyReloadEventsOnAfterAssemblyReload()
{
{
var binString = EditorPrefs.GetString(AssemblyReloadEventsEditorPref);
var binString = EditorPrefs.GetString(AssemblyReloadEventsEditorPref);
Copier
Copié
Copier
Copié
var totalCompilationTimeSeconds = float.Parse(EditorPrefs.GetString(AssemblyTotalCompilationTimeEditorPref, AssemblyTotalCompilationTimeEditorPref));
Copier
Copié
Copier
Copié
long bin
= 0
;
long bin
;
if (long.TryParse(binString, out bin))
if (long.TryParse(binString, out bin))
{
{
var date = DateTime.FromBinary(bin);
var date = DateTime.FromBinary(bin);
var time = DateTime.UtcNow - date;
var time = DateTime.UtcNow - date;
var compilationTimes = EditorPrefs.GetString(AssemblyCompilationEventsEditorPref);
var compilationTimes = EditorPrefs.GetString(AssemblyCompilationEventsEditorPref);
Copier
Copié
Copier
Copié
var totalTimeSeconds = totalCompilationTimeSeconds + time.TotalSeconds;
if (!string.IsNullOrEmpty(compilationTimes))
if (!string.IsNullOrEmpty(compilationTimes))
{
{
Copier
Copié
Copier
Copié
Debug.Log(
"Compilation Report
\n" + compilationTimes + "Assembly Reload Time: " + time.TotalSeconds + "s\n");
Debug.Log(
$
"Compilation Report
: {totalTimeSeconds:F2} seconds
\n" + compilationTimes + "Assembly Reload Time: " + time.TotalSeconds + "s\n");
}
}
}
}
}
}
}
}
Copier
Copié
Copier
Copié
#endif
Différences enregistrées
Texte d'origine
Ouvrir un fichier
using System; using System.Collections.Generic; using System.Text; using UnityEditor; using UnityEditor.Compilation; using UnityEngine; [InitializeOnLoad] public class AsmdefDebug { const string AssemblyReloadEventsEditorPref = "AssemblyReloadEventsTime"; const string AssemblyCompilationEventsEditorPref = "AssemblyCompilationEvents"; static readonly int ScriptAssembliesPathLen = "Library/ScriptAssemblies/".Length; static Dictionary<string, DateTime> s_StartTimes = new Dictionary<string, DateTime>(); static StringBuilder s_BuildEvents = new StringBuilder(); static double s_CompilationTotalTime; static AsmdefDebug() { CompilationPipeline.assemblyCompilationStarted += CompilationPipelineOnAssemblyCompilationStarted; CompilationPipeline.assemblyCompilationFinished += CompilationPipelineOnAssemblyCompilationFinished; AssemblyReloadEvents.beforeAssemblyReload += AssemblyReloadEventsOnBeforeAssemblyReload; AssemblyReloadEvents.afterAssemblyReload += AssemblyReloadEventsOnAfterAssemblyReload; } static void CompilationPipelineOnAssemblyCompilationStarted(string assembly) { s_StartTimes[assembly] = DateTime.UtcNow; } static void CompilationPipelineOnAssemblyCompilationFinished(string assembly, CompilerMessage[] arg2) { var time = s_StartTimes[assembly]; var timeSpan = DateTime.UtcNow - s_StartTimes[assembly]; s_CompilationTotalTime += timeSpan.TotalMilliseconds; s_BuildEvents.AppendFormat("{0:0.00}s {1}\n", timeSpan.TotalMilliseconds / 1000f, assembly.Substring(ScriptAssembliesPathLen, assembly.Length - ScriptAssembliesPathLen)); } static void AssemblyReloadEventsOnBeforeAssemblyReload() { s_BuildEvents.AppendFormat("compilation total: {0:0.00}s\n", s_CompilationTotalTime / 1000f); EditorPrefs.SetString(AssemblyReloadEventsEditorPref, DateTime.UtcNow.ToBinary().ToString()); EditorPrefs.SetString(AssemblyCompilationEventsEditorPref, s_BuildEvents.ToString()); } static void AssemblyReloadEventsOnAfterAssemblyReload() { var binString = EditorPrefs.GetString(AssemblyReloadEventsEditorPref); long bin = 0; if (long.TryParse(binString, out bin)) { var date = DateTime.FromBinary(bin); var time = DateTime.UtcNow - date; var compilationTimes = EditorPrefs.GetString(AssemblyCompilationEventsEditorPref); if (!string.IsNullOrEmpty(compilationTimes)) { Debug.Log("Compilation Report\n" + compilationTimes + "Assembly Reload Time: " + time.TotalSeconds + "s\n"); } } } }
Texte modifié
Ouvrir un fichier
#if UNITY_EDITOR using System; using System.Collections.Generic; using System.Globalization; using System.Text; using UnityEditor; using UnityEditor.Compilation; using UnityEngine; /// <summary> /// https://gist.github.com/karljj1/9c6cce803096b5cd4511cf0819ff517b /// </summary> [InitializeOnLoad] public class AsmdefDebug { const string AssemblyReloadEventsEditorPref = "AssemblyReloadEventsTime"; const string AssemblyCompilationEventsEditorPref = "AssemblyCompilationEvents"; static readonly int ScriptAssembliesPathLen = "Library/ScriptAssemblies/".Length; private static string AssemblyTotalCompilationTimeEditorPref = "AssemblyTotalCompilationTime"; static Dictionary<string, DateTime> s_StartTimes = new Dictionary<string, DateTime>(); static StringBuilder s_BuildEvents = new StringBuilder(); static double s_CompilationTotalTime; static AsmdefDebug() { CompilationPipeline.assemblyCompilationStarted += CompilationPipelineOnAssemblyCompilationStarted; CompilationPipeline.assemblyCompilationFinished += CompilationPipelineOnAssemblyCompilationFinished; AssemblyReloadEvents.beforeAssemblyReload += AssemblyReloadEventsOnBeforeAssemblyReload; AssemblyReloadEvents.afterAssemblyReload += AssemblyReloadEventsOnAfterAssemblyReload; } static void CompilationPipelineOnAssemblyCompilationStarted(string assembly) { s_StartTimes[assembly] = DateTime.UtcNow; } static void CompilationPipelineOnAssemblyCompilationFinished(string assembly, CompilerMessage[] arg2) { var timeSpan = DateTime.UtcNow - s_StartTimes[assembly]; s_CompilationTotalTime += timeSpan.TotalMilliseconds; s_BuildEvents.AppendFormat("{0:0.00}s {1}\n", timeSpan.TotalMilliseconds / 1000f, assembly.Substring(ScriptAssembliesPathLen, assembly.Length - ScriptAssembliesPathLen)); } static void AssemblyReloadEventsOnBeforeAssemblyReload() { var totalCompilationTimeSeconds = s_CompilationTotalTime / 1000f; s_BuildEvents.AppendFormat("compilation total: {0:0.00}s\n", totalCompilationTimeSeconds); EditorPrefs.SetString(AssemblyReloadEventsEditorPref, DateTime.UtcNow.ToBinary().ToString()); EditorPrefs.SetString(AssemblyCompilationEventsEditorPref, s_BuildEvents.ToString()); EditorPrefs.SetString(AssemblyTotalCompilationTimeEditorPref, totalCompilationTimeSeconds.ToString(CultureInfo.InvariantCulture)); } static void AssemblyReloadEventsOnAfterAssemblyReload() { var binString = EditorPrefs.GetString(AssemblyReloadEventsEditorPref); var totalCompilationTimeSeconds = float.Parse(EditorPrefs.GetString(AssemblyTotalCompilationTimeEditorPref, AssemblyTotalCompilationTimeEditorPref)); long bin; if (long.TryParse(binString, out bin)) { var date = DateTime.FromBinary(bin); var time = DateTime.UtcNow - date; var compilationTimes = EditorPrefs.GetString(AssemblyCompilationEventsEditorPref); var totalTimeSeconds = totalCompilationTimeSeconds + time.TotalSeconds; if (!string.IsNullOrEmpty(compilationTimes)) { Debug.Log($"Compilation Report: {totalTimeSeconds:F2} seconds\n" + compilationTimes + "Assembly Reload Time: " + time.TotalSeconds + "s\n"); } } } } #endif
Trouver la différence