Görev yazma
Görevler, derleme işlemi sırasında çalışan kodu sağlar. Görevler hedeflerde yer alır. MSBuild'e tipik görev kitaplığı eklenmiştir ve kendi görevlerinizi de oluşturabilirsiniz. MSBuild'e dahil edilen görev kitaplığı hakkında daha fazla bilgi için bkz . Görev başvurusu.
Görevler
Görevlere örnek olarak bir veya daha fazla dosyayı kopyalayan Kopyala, dizin oluşturan MakeDir ve C# kaynak kodu dosyalarını derleyen Csc verilebilir. Her görev, Microsoft.Build.Framework.dll derlemesinde tanımlanan arabirimi uygulayan ITask bir .NET sınıfı olarak uygulanır.
Görev uygularken kullanabileceğiniz iki yaklaşım vardır:
ITask Arabirimi doğrudan uygulayın.
sınıfınızı Microsoft.Build.Utilities.dll derlemesinde tanımlanan yardımcı sınıfından Tasktüretin. Görev ITask uygular ve bazı ITask üyelerinin varsayılan uygulamalarını sağlar. Ayrıca günlük kaydı daha kolaydır.
Her iki durumda da sınıfınıza, görev çalıştırıldığında çağrılan yöntem olan adlı Execute
bir yöntem eklemeniz gerekir. Bu yöntem parametre almaz ve bir Boolean
değer döndürür: true
görev başarılıysa veya false
başarısız olduysa. Aşağıdaki örnekte, hiçbir eylem gerçekleştirmeden başarıyla tamamlayan (döndürür) bir görev gösterilmektedir true
.
using System;
using Microsoft.Build.Framework;
using Microsoft.Build.Utilities;
namespace MyTasks
{
public class SimpleTask : Task
{
public override bool Execute()
{
return true;
}
}
}
Aşağıdaki proje dosyası bu görevi çalıştırır:
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<Target Name="MyTarget">
<SimpleTask />
</Target>
</Project>
Görevler çalıştırıldığında, görev sınıfında .NET özellikleri oluşturursanız proje dosyasından da giriş alabilirler. MSBuild, görevin Execute
yöntemini çağırmadan hemen önce bu özellikleri ayarlar. Dize özelliği oluşturmak için aşağıdaki gibi görev kodunu kullanın:
using System;
using Microsoft.Build.Framework;
using Microsoft.Build.Utilities;
namespace MyTasks
{
public class SimpleTask : Task
{
public override bool Execute()
{
return true;
}
public string MyProperty { get; set; }
}
}
Aşağıdaki proje dosyası bu görevi çalıştırır ve verilen değere ayarlar MyProperty
:
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<Target Name="MyTarget">
<SimpleTask MyProperty="Value for MyProperty" />
</Target>
</Project>
Görevleri kaydetme
Bir proje bir görevi çalıştıracaksa, MSBuild görev sınıfını içeren derlemenin nasıl bulunacağını ve çalıştırıldığını bilmelidir. Görevler UsingTask öğesi (MSBuild) kullanılarak kaydedilir.
Görevinizin çalışma zamanına özgü bağımlılıkları varsa, ve/veya Runtime
usingTask değerini belirterek MSBuild'e görevi belirli bir ortamda çalıştırması Architecture
gerektiğini bildirmeniz gerekir.
MSBuild dosyası Microsoft.Common.tasks, MSBuild ile sağlanan tüm görevleri kaydeden öğelerin listesini UsingTask
içeren bir proje dosyasıdır. Bu dosya, herhangi bir proje oluşturulurken otomatik olarak eklenir. Microsoft.Common.tasks dosyasına kaydedilmiş bir görev de geçerli proje dosyasına kayıtlıysa, geçerli proje dosyası önceliklidir, böylece varsayılan görevi aynı ada sahip kendi görevinizle geçersiz kılabilirsiniz.
İpucu
Microsoft.Common.tasks içindekileri görüntüleyerek MSBuild'in belirli bir sürümüyle sağlanan görevlerin listesini görebilirsiniz.
Görevden olay oluşturma
Göreviniz yardımcı sınıfından Task türetilirse, herhangi bir kayıtlı günlüğe kaydeden tarafından yakalanacak ve görüntülenecek olayları yükseltmek için sınıfındaki Task aşağıdaki yardımcı yöntemlerden herhangi birini kullanabilirsiniz:
public override bool Execute()
{
Log.LogError("messageResource1", "1", "2", "3");
Log.LogWarning("messageResource2");
Log.LogMessage(MessageImportance.High, "messageResource3");
...
}
Göreviniz doğrudan uygulanıyorsa ITask , yine de bu tür olaylar oluşturabilirsiniz, ancak IBuildEngine arabirimini kullanmanız gerekir. Aşağıdaki örnekte ITask uygulayan ve özel olay oluşturan bir görev gösterilmektedir:
public class SimpleTask : ITask
{
public IBuildEngine BuildEngine { get; set; }
public override bool Execute()
{
TaskEventArgs taskEvent =
new TaskEventArgs(BuildEventCategory.Custom,
BuildEventImportance.High, "Important Message",
"SimpleTask");
BuildEngine.LogBuildEvent(taskEvent);
return true;
}
}
Görev parametrelerinin ayarlanmasını gerektir
Görevi çalıştıran tüm proje dosyalarının bu özellikler için değer ayarlaması veya derlemenin başarısız olması için belirli görev özelliklerini "gerekli" olarak işaretleyebilirsiniz. özniteliğini [Required]
görevinizdeki .NET özelliğine aşağıdaki gibi uygulayın:
[Required]
public string RequiredProperty { get; set; }
[Required]
özniteliği, ad alanında Microsoft.Build.Framework tarafından RequiredAttribute tanımlanır.
MSBuild bir görevi nasıl çağırır?
Bir görevi çağırırken, MSBuild önce görev sınıfını başlatır, sonra bu nesnenin özellik ayarlayıcılarını proje dosyasındaki görev öğesinde ayarlanan görev parametreleri için çağırır. Görev öğesi bir parametre belirtmezse veya öğesinde belirtilen ifade boş bir dize olarak değerlendirilirse, özellik ayarlayıcısı çağrılmaz.
Örneğin, projede
<Project>
<Target Name="InvokeCustomTask">
<CustomTask Input1=""
Input2="$(PropertyThatIsNotDefined)"
Input3="value3" />
</Target>
</Project>
yalnızca için Input3
ayarlayıcı çağrılır.
Bir görev, parametre-özellik ayarlayıcısı çağırmasının göreli sırasına bağlı olmamalıdır.
Görev parametresi türleri
MSBuild, , bool
ITaskItem
ve ITaskItem[]
türündeki string
özellikleri yerel olarak işler. Bir görev farklı türde bir parametre kabul ederse, MSBuild hedef türe dönüştürmek string
için çağırır ChangeType (tüm özellik ve öğe başvuruları genişletilmiş olarak). Dönüştürme herhangi bir giriş parametresi için başarısız olursa, MSBuild bir hata yayar ve görevin Execute()
yöntemini çağırmaz.
Görevi paketleme
Bir görevi dağıtmanın önerilen yolu NuGet paketindedir. Paketin tüm bağımlılıkları paketlemesi gerekir. Bu konu, özel görev oluşturma işleminde size yol gösteren bir öğreticide ayrıntılı olarak açıklanmıştır. Bkz . NuGet paketi oluşturma.
Örnek 1
Açıklama
Aşağıdaki C# sınıfı, yardımcı sınıfından Task türetilen bir görevi gösterir. Bu görev, başarılı olduğunu belirten değerini döndürür true
.
Kod
using System;
using Microsoft.Build.Utilities;
namespace SimpleTask1
{
public class SimpleTask1: Task
{
public override bool Execute()
{
// This is where the task would presumably do its work.
return true;
}
}
}
Örnek 2
Açıklama
Aşağıdaki C# sınıfı arabirimini uygulayan ITask bir görevi gösterir. Bu görev, başarılı olduğunu belirten değerini döndürür true
.
Kod
using System;
using Microsoft.Build.Framework;
namespace SimpleTask2
{
public class SimpleTask2: ITask
{
//When implementing the ITask interface, it is necessary to
//implement a BuildEngine property of type
//Microsoft.Build.Framework.IBuildEngine. This is done for
//you if you derive from the Task class.
public IBuildEngine BuildEngine { get; set; }
// When implementing the ITask interface, it is necessary to
// implement a HostObject property of type object.
// This is done for you if you derive from the Task class.
public object HostObject { get; set; }
public bool Execute()
{
// This is where the task would presumably do its work.
return true;
}
}
}
Örnek 3
Açıklama
Bu C# sınıfı, yardımcı sınıfından türetilen Task bir görevi gösterir. Gerekli bir dize özelliğine sahiptir ve tüm kayıtlı günlükçüler tarafından görüntülenen bir olay oluşturur.
Kod
using System;
using Microsoft.Build.Framework;
using Microsoft.Build.Utilities;
namespace SimpleTask3
{
public class SimpleTask3 : Task
{
private string myProperty;
// The [Required] attribute indicates a required property.
// If a project file invokes this task without passing a value
// to this property, the build will fail immediately.
[Required]
public string MyProperty
{
get
{
return myProperty;
}
set
{
myProperty = value;
}
}
public override bool Execute()
{
// Log a high-importance comment
Log.LogMessage(MessageImportance.High,
"The task was passed \"" + myProperty + "\".");
return true;
}
}
}
Örnek 4
Açıklama
Aşağıdaki örnekte, önceki örnek görev olan SimpleTask3'i çağıran bir proje dosyası gösterilmektedir.
Kod
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<UsingTask TaskName="SimpleTask3.SimpleTask3"
AssemblyFile="SimpleTask3\bin\debug\simpletask3.dll"/>
<Target Name="MyTarget">
<SimpleTask3 MyProperty="Hello!"/>
</Target>
</Project>