Skip to content

Commit

Permalink
[msbuild] Port the SpotlightIndexer task to subclass XamarinTask. (#2…
Browse files Browse the repository at this point in the history
…1613)

This has a few advantages:

* We simplify and unify more of our code.
* We have more control over the error reporting / logging behavior.

Additionally:

* Use 'xcrun' to invoke 'mdimport' (partial fix for #3931).
* Allow for overriding the path to the command-line tool in question.
* Add support for cancellation.
* Fix nullability.
  • Loading branch information
rolfbjarne authored Nov 22, 2024
1 parent 585d811 commit dabf10e
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 32 deletions.
6 changes: 6 additions & 0 deletions docs/build-apps/build-properties.md
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,12 @@ Example:

This property was introduced in .NET 9.

## MdimportPath

The full path to the `mdimport` tool.

The default behavior is to use `xcrun mdimport`.

## MetalLibPath

The full path to the `metallib` tool (the Metal Linker).
Expand Down
59 changes: 27 additions & 32 deletions msbuild/Xamarin.MacDev.Tasks/Tasks/SpotlightIndexer.cs
Original file line number Diff line number Diff line change
@@ -1,63 +1,58 @@
using System;
using System.Collections.Generic;
using System.IO;
using System.Threading;
using System.Threading.Tasks;

using Microsoft.Build.Framework;
using Microsoft.Build.Utilities;

using Xamarin.Messaging.Build.Client;

#nullable enable

namespace Xamarin.MacDev.Tasks {
public class SpotlightIndexer : XamarinToolTask {
public class SpotlightIndexer : XamarinTask, ICancelableTask {
CancellationTokenSource? cancellationTokenSource;
#region Inputs

[Required]
public string Input { get; set; } = string.Empty;

#endregion

protected override string ToolName {
get { return "mdimport"; }
}

protected override string GenerateFullPathToTool ()
{
if (!string.IsNullOrEmpty (ToolPath))
return Path.Combine (ToolPath, ToolExe);

var path = Path.Combine ("/usr/bin", ToolExe);

return File.Exists (path) ? path : ToolExe;
}

protected override string GenerateCommandLineCommands ()
{
var args = new CommandLineBuilder ();

args.AppendFileNameIfNotNull (Input);
public string MdimportPath { get; set; } = string.Empty;

return args.ToString ();
}
#endregion

protected override void LogEventsFromTextOutput (string singleLine, MessageImportance messageImportance)
static string GetExecutable (List<string> arguments, string toolName, string toolPathOverride)
{
// TODO: do proper parsing of error messages and such
Log.LogMessage (messageImportance, "{0}", singleLine);
if (string.IsNullOrEmpty (toolPathOverride)) {
arguments.Insert (0, toolName);
return "xcrun";
}
return toolPathOverride;
}

public override bool Execute ()
{
if (ShouldExecuteRemotely ())
return new TaskRunner (SessionId, BuildEngine4).RunAsync (this).Result;

return base.Execute ();
var args = new List<string> () {
Input
};
var executable = GetExecutable (args, "mdimport", MdimportPath);
cancellationTokenSource = new CancellationTokenSource ();
ExecuteAsync (Log, executable, args, cancellationToken: cancellationTokenSource.Token).Wait ();
return !Log.HasLoggedErrors;
}

public override void Cancel ()
public void Cancel ()
{
if (ShouldExecuteRemotely ())
if (ShouldExecuteRemotely ()) {
BuildConnection.CancelAsync (BuildEngine4).Wait ();

base.Execute ();
} else {
cancellationTokenSource?.Cancel ();
}
}
}
}
1 change: 1 addition & 0 deletions msbuild/Xamarin.Shared/Xamarin.Shared.targets
Original file line number Diff line number Diff line change
Expand Up @@ -2964,6 +2964,7 @@ Copyright (C) 2018 Microsoft. All rights reserved.
SessionId="$(BuildSessionId)"
Condition="'$(IsMacEnabled)' == 'true'"
Input="$(_AppContainerDir)"
MdimportPath="$(MdimportPath)"
/>
</Target>

Expand Down

6 comments on commit dabf10e

@vs-mobiletools-engineering-service2

This comment was marked as outdated.

@vs-mobiletools-engineering-service2

This comment was marked as outdated.

@vs-mobiletools-engineering-service2

This comment was marked as outdated.

@vs-mobiletools-engineering-service2

This comment was marked as outdated.

@vs-mobiletools-engineering-service2

This comment was marked as outdated.

@vs-mobiletools-engineering-service2

This comment was marked as outdated.

Please sign in to comment.