Документация библиотеки Ant .NET? (настройка параметров консольного логгера)

Я создаю проект, который использует бэкэнд C ++ для скорости обработки и пользовательский интерфейс Java, и строю бинарные файлы бэкэнда с помощью задачи Ant под названием «msbuild» внутри библиотеки Apache .NET Ant:

http://ant.apache.org/antlibs/dotnet/

Но я не могу найти какую-либо документацию для элементов, которые поддерживает задача «msbuild». Я хотел бы поэкспериментировать с различными параметрами консольного логгера.

Есть ли какая-то документация, которую я просто не могу найти с готовностью? Или есть способ определить свойства и вложенные элементы, которые поддерживает задача msbuild, без чтения документации?

0

Решение

Вероятно, это просто оболочка для Msbuild.exe. Который поставляется с каждой версией фреймворка.

Справочник по командной строке MSBuild

http://msdn.microsoft.com/en-us/library/vstudio/ms164311%28v=vs.80%29.aspx

Снимки экрана (по вашей ссылке) показывают «2.0», что означает, что это, вероятно, оболочка для:

C: \ Windows \ Microsoft.NET \ Framework \ v2.0.50727 \ msbuild.exe

…………..

Если у вас есть пользовательское задание, которое упаковывает msbuild.exe ….., то, надеюсь, вы сможете найти исходный код для этого пользовательского задания.
Это расскажет историю о том, что на самом деле «закодировал» разработчик (пользовательской задачи).

Что я обнаружил в пользовательских задачах, так это то, что разработчик (и) добавит большинство / некоторые общие свойства, но не все из них.

Который (если вы можете получить исходный код), вы можете получить код и добавить дополнительные свойства, как вам нужно.

…………..

Если вы не можете получить исходный код ………, тогда используйте отражатель (мне нравится ILSpy), чтобы посмотреть свойства, которые можно установить в вашей задаче. (или эквивалент Java, если ваша пользовательская задача написана на Java)

……
Помните, в конце концов, пользовательская задача — это просто супер-модная оболочка для командной строки.
Вы задаете свойства для пользовательской задачи, а код задачи переводит ее в форму командной строки.
Возьмите это с крошкой соли, но обычно это то, что делает оболочка инструмента командной строки.
Я не видел исходного исходного кода, но я бы сильно предположил, что это происходит.

РЕДАКТИРОВАТЬ:

Получить исходный код:

Текущее местоположение:

http://www.gtlib.gatech.edu/pub/apache//ant/antlibs/dotnet/source/apache-ant-dotnet-1.1-src.zip

или отсюда:

http://ant.apache.org/antlibs/srcdownload.cgi

Выясните, что делает исходный код.

/*
*  Licensed to the Apache Software Foundation (ASF) under one or more
*  contributor license agreements.  See the NOTICE file distributed with
*  this work for additional information regarding copyright ownership.
*  The ASF licenses this file to You under the Apache License, Version 2.0
*  (the "License"); you may not use this file except in compliance with
*  the License.  You may obtain a copy of the License at
*
*      http://www.apache.org/licenses/LICENSE-2.0
*
*  Unless required by applicable law or agreed to in writing, software
*  distributed under the License is distributed on an "AS IS" BASIS,
*  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*  See the License for the specific language governing permissions and
*  limitations under the License.
*
*/

package org.apache.ant.dotnet.build;

import java.io.File;
import java.util.List;

import org.apache.ant.dotnet.util.CollectionUtils;

import org.w3c.dom.DocumentFragment;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

/**
* Runs a MSBuild build process.
*/
public class MSBuildTask extends AbstractBuildTask {

private static final String TARGET = "generated-by-ant";
private static final String ROOT = "Project";
private static final String MSBUILD_NS =
"http://schemas.microsoft.com/developer/msbuild/2003";

public MSBuildTask() {
super();
}

protected String getExecutable() {
return "MSBuild.exe";
}

protected String[] getBuildfileArguments(File buildFile) {
if (buildFile != null) {
return new String[] {
buildFile.getAbsolutePath()
};
} else {
return new String[0];
}
}

protected String[] getTargetArguments(List targets) {
if (targets.size() > 0) {
StringBuffer sb = new StringBuffer("/target:");
sb.append(CollectionUtils.flattenToString(targets, ";"));
return new String[]{sb.toString()};
} else {
return new String[0];
}
}

protected String[] getPropertyArguments(List properties) {
if (properties.size() > 0) {
StringBuffer sb = new StringBuffer("/property:");
sb.append(CollectionUtils.flattenToString(properties, ";"));
return new String[]{sb.toString()};
} else {
return new String[0];
}
}

/**
* Turn the DocumentFragment into a DOM tree suitable as a build
* file when serialized.
*
* <p>If we have exactly one <Project> child, return that.
* Otherwise if we have only <Task> children, wrap them into a
* <Target> which in turn gets wrapped into a <Project>.
* Otherwise, fail.</p>
*/
protected Element makeTree(DocumentFragment f) {
NodeList nl = f.getChildNodes();
if (nl.getLength() == 1
&& nl.item(0).getNodeType() == Node.ELEMENT_NODE
&& nl.item(0).getNodeName().equals(ROOT)) {
return (Element) nl.item(0);
} else {
Element p = f.getOwnerDocument().createElementNS(MSBUILD_NS,
ROOT);
p.setAttribute("DefaultTargets", TARGET);

Element t = f.getOwnerDocument().createElementNS(MSBUILD_NS,
"Target");
t.setAttribute("Name", TARGET);

p.appendChild(t);
t.appendChild(f);
return p;
}
}
}
1

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector