Sub scripts

There are 2 sub-scripts for each log analysis script. The context when executing script will be shared across all sub-scripts belong to same script.

Script to Setup Analysis

To perform custom actions before analyzing logs. The script will be invoked one time after applying the log analysis script.
Example:
Context.Data["messageRegex"] = new Regex("ULogViewer");

Script to Analyze Log

Script to be invoked for each log to be analyzed. The returned value should be boolean to indicate whether results added by script should be taken or not.
⬆️ Back to top

Namespaces

The following namespaces are imported by default:
  • System.Text.RegularExpressions
  • CarinaStudio.ULogViewer.LogsDeprecated in v3.0+
    To access types and functions related to log.
  • CarinaStudio.ULogViewer.ViewModels.Analysis.ScriptingDeprecated in v3.0+
    To access types and functions related to log analysis by script.
CarinaStudio.* namespaces should not be imported manually starting from ULogViewer 3.0. All necessary types will be imported automatically.
⬆️ Back to top

Context

The followings are members of Context other than basic members:
  • AddResult(Result result)
    Add analysis result. The followings are members of Result structure:v3.0+
    • BeginningLog: ILog?
      The beginning log which is related to result.
    • ByteSize: long?
      The size in bytes related to result.
    • Duration: TimeSpan?
      The duration which is related to result.
    • EndingLog: ILog?
      The ending log which is related to result.
    • Log: ILog?
      The log which is related to result.
    • Message: string?
      Message of result.
    • Quantity: long?
      The quantity which is related to result.
    • Type: ResultType
      Type of result. Please refer to Type of Analysis Result for possible values.
    The followings are constructors of Result before ULogViewer 3.0:
    • Result(ResultType type, string message, ILog log)
      • type
        Type of result. Please refer to Type of Analysis Result for possible values.
      • message
        Message of result.
      • log
        The log which is related to result.
    • Result(ResultType type, string message, ILog beginningLog, ILog endingLog)
      • type
        Type of result. Please refer to Type of Analysis Result for possible values.
      • message
        Message of result.
      • beginningLog
        The beginning log which is related to result.
      • endingLog
        The ending log which is related to result.
  • Log: ILog
    The log to be analyzed. The followings are members of ILog:
    • GetProperty(string name, object? defaultValue = default): object?
    • GetProperty<T>(string name, T? defaultValue = default): T?
      Get property of log with specific name. The defaultValue will be returned if property doesn't exist. Please refer to Name of Log Properties for valid names.
    • Text: string
      Get full text of log. The format of text is same as text for log text filtering.
Example:v3.0+
var regex = (Regex)Context.Data["messageRegex"]!;
var message = Context.Log.GetProperty<string>("Message");
if (message != null && regex.IsMatch(message))
{
    Context.AddResult(new Result()
    {
        Log = Context.Log,
        Message = "Log found!!",
        Type = ResultType.Information,
    });
    return true;
}
return false;
Example before ULogViewer 3.0:
var regex = (Regex)Context.Data["messageRegex"]!;
var message = Context.Log.GetProperty<string>("Message");
if (message != null && regex.IsMatch(message))
{
    Context.AddResult(new Result(ResultType.Information, "Log found!!", Context.Log));
    return true;
}
return false;
⬆️ Back to top

Type of Analysis Result

All types of analysis results are defined in ResultType enumeration:
  • Error (Default)
  • Warning
  • OperationStart
  • OperationEnd
  • Increasev3.0+
  • Decreasev3.0+
  • Steadyv3.0+
  • Fastv3.0+
  • Slowv3.0+
  • Checkpoint
  • TimeSpan
  • Performance
  • Frequencyv3.0+
  • Trendv3.0+
  • Information
  • SkippedOperationv3.0+
  • Debugv3.0+
⬆️ Back to top

Name of Log Properties

  • BeginningTimeSpan
    Beginning time span. The type is TimeSpan.
  • BeginningTimestamp
    Beginning timestamp. The type is DateTime.
  • Category
    Category. The type is String.
  • DeviceId
    ID of device. The type is String.
  • DeviceName
    Name of device. The type is String.
  • EndingTimeSpan
    Ending time span. The type is TimeSpan.
  • EndingTimestamp
    Ending time span. The type is DateTime.
  • Event
    Event. The type is String.
  • Extra1
  • Extra10
  • Extra11v4.0+
  • Extra12v4.0+
  • Extra13v4.0+
  • Extra14v4.0+
  • Extra15v4.0+
  • Extra16v4.0+
  • Extra17v4.0+
  • Extra18v4.0+
  • Extra19v4.0+
  • Extra2
  • Extra20v4.0+
  • Extra3
  • Extra4
  • Extra5
  • Extra6
  • Extra7
  • Extra8
  • Extra9
    Extra information. The type is String.
  • FileName
    Name of file to read log. The type is String.
  • Level
    Level of log. The type is LogLevel defined by ULogViewer. The followings are values defined in LogLevel from the highest priority to the lowest:
    • Fatal
    • Error
    • Failure
    • Warn
    • Success
    • Info
    • Debug
    • Trace
    • Verbose
    • Undefined
  • LineNumber
    Line number. The type is Int32.
  • Message
    Message. The type is String.
  • ProcessId
    ID of process. The type is Int32.
  • ProcessName
    Name of process. The type is String.
  • ReadTimev3.0+
    Timestamp of log to be read. The type is DateTime.
  • SourceName
    Name of log source. The type is String.
  • Summary
    Summary. The type is String.
  • Tags
    Tags. The type is String.
  • ThreadId
    ID of thread. The type is Int32.
  • ThreadName
    Name of thread. The type is String.
  • TimeSpan
    Time span. The type is TimeSpan.
  • Timestamp
    Timestamp. The type is DateTime.
  • Title
    Title. The type is String.
  • UserId
    ID of user. The type is String.
  • UserName
    Name of user. The type is String.
⬆️ Back to top