AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Werkzeuge MSBuild manuell aus FinalBuilder aufrufen
Thema durchsuchen
Ansicht
Themen-Optionen

MSBuild manuell aus FinalBuilder aufrufen

Ein Thema von himitsu · begonnen am 21. Feb 2025 · letzter Beitrag vom 21. Feb 2025
Antwort Antwort
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.287 Beiträge
 
Delphi 12 Athens
 
#1

MSBuild manuell aus FinalBuilder aufrufen

  Alt Gestern, 11:18
Moin Moin,

ich versuche immernoch aus Powershell (später FinalBuilder) den MSBuild aufzurufen,
aber irgendwie will das einfach nicht. (zwei was auszuführen)

Ja, FinalBuilder hat Delphi- und MSBuild-Actions, aber die sind unbrauchbar.
* einmal braucht man unbedingt jedesmal sofort eine neue Version, wenn neues Delphi raus kommt
* und dann lassen sie sich eh nur via BeforeAction "dynamisch" konfigurieren (und in AfterAction reseten, damit die fbp8 nicht ständig Änderungen im GIT anzeigt)
* also kann man das auch gleich alles selbst im Script machen



Also erstmal in PowerShell ISE rumgespielt.

* rsvars.bat + MSBuild.exe
* oder selbst das Environment zusammenstellen und damit MSBuild starten

* Wenn ich die Variablen aus rsvars lade und 1:1 übergebe, dann werden die enthalten Variablen nicht ersetzt und es heißt "MSBuild not found".
* Mit Replace bleibt aber CMD hängen und läuft in den Timeout. (oder läuft ewig)
* Über SET angesehn, sieht das Environment aber OK aus.

* Aber auch rsvars.bat & MSBuild.exe will nicht.
Hab auch schon alles mögliche bezüglich dem Escaping versucht ... für CMD /C mit oder ohne /S, ist das ja oft bissl verzickt.

Code:
$DelphiDir    = "C:\Program Files (x86)\Embarcadero\Studio\22.0"
$BuildPlatform = "Win32"
$BuildConfig  = "Debug"
$ProjectDir   = "C:\Irgendwo"
$ProjectFile  = "C:\Irgendwo\MyTest.dproj"



## INIT
$PInfo = New-Object System.Diagnostics.ProcessStartInfo
$PInfo.WorkingDirectory      = $ProjectDir
$PInfo.FileName              = "cmd.exe" # oder $Env.ComSpec
#$PInfo.Arguments             = "/s", "/c", "call `"$DelphiDir\bin\rsvars.bat`" `& MSBuild.exe /nologo /target:Build /property:Platform=$BuildPlatform /property:Config=$BuildConfig `"$ProjectFile`""
#$PInfo.Arguments             = "/s", "/c", "call `"$DelphiDir\bin\rsvars.bat`" `& echo MSBuild.exe /nologo /target:Build /property:Platform=$BuildPlatform /property:Config=$BuildConfig `"$ProjectFile`" `& set"
#$PInfo.Arguments             = "/c", "MSBuild.exe /nologo /target:Build /property:Platform=$BuildPlatform /property:Config=$BuildConfig `"$ProjectFile`""
$PInfo.Arguments             = "/c", "set"
$PInfo.RedirectStandardError = $true
$PInfo.RedirectStandardOutput = $true
$PInfo.UseShellExecute       = $false

## LOAD rsvars.bat
if ($true) {  #if ($PInfo.Arguments -NotContains "rsvars") {
  foreach ($Line in (Get-Content "C:\Program Files (x86)\Embarcadero\Studio\22.0\bin\rsvars.bat")) {
    if ($Line.Trim() -ne "") {
      $Key  = $Line.Split('=')[0].TrimStart("@SET").Trim()
      $Value = ($Line.Split('=')[1] + "").Trim()
      foreach ($Match in (Select-String "%([a-z0-9_]+)%" -input $Value -AllMatches).Matches) {
        $Value2 = ($PInfo.EnvironmentVariables[$Match.Value.Trim("%")] + "").Trim()
        #if ( ($Value2 -ne $null) -And ($Value2 -ne "") ) {
          $Value = $Value.Replace($Match.Value, $Value2)
        #}
      }
      Write-Host "set `"$Key`" = `"$Value`""
      $PInfo.EnvironmentVariables[$Key] = $Value
    }
  }
}

## EXECUTE
$Process = New-Object System.Diagnostics.Process
$Process.StartInfo = $pinfo
$Process.Start() | Out-Null
#$Process.WaitForExit()
if ($Process.WaitForExit(10 * 1000) -ne $true) {
  $Process.Kill()
  #throw "TIMEOUT"
  Write-Host "{TIMEOUT}"
}
$StdOut = $Process.StandardOutput.ReadToEnd()
$StdErr = $Process.StandardError.ReadToEnd()

## LOG
Write-Host "ExitCode:", $Process.ExitCode
Write-Host "StdOut:`n$StdOut"
Write-Host "StdErr:`n$StdErr"
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (Gestern um 13:47 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.574 Beiträge
 
Delphi 12 Athens
 
#2

AW: MSBuild manuell aus FinalBuilder aufrufen

  Alt Gestern, 11:44
Vielleicht erkenne ich das Problem noch nicht, aber mit dieser CMD-Datei funktioniert das tadellos:
Code:
call "c:\Program Files (x86)\Embarcadero\Studio\22.0\bin\rsvars.bat"
msbuild "BuildAll.proj" /t:build /p:config="Release" /fileLogger /flp:ErrorsOnly /nologo /maxcpucount:2 > build.log
Die BuildAll.proj Datei besteht im Wesentlichen aus mehreren _Project Include=-Nodes mit den groupproj bzw. dproj Dateien, die verarbeitet werden sollen:
XML-Code:
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <ItemGroup>
    <_Project Include="xxx.groupproj"/>
    ...
  </ItemGroup>
</Project>
Das mit dem maxcpucount funktioniert natürlich nur wenn die Projektgruppen unabhängig voneinander sind. Hier wird das z.B. benutzt, um in einem Projekt alle externen Libraries in einem Rutsch zu erzeugen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.287 Beiträge
 
Delphi 12 Athens
 
#3

AW: MSBuild manuell aus FinalBuilder aufrufen

  Alt Gestern, 11:53
Hatte auch mit Start-Process rumgespielt, aber dort gab es ein Problem, dass des mit dem Environment "so" noch nicht funktioniert.
Überall ist es ja PowerShell 5.1, aber den nötigen Parameter gibt es erst in 7.5 und die zu installieren bringt wieder andere Nachteile mit sich.

Wir kompilieren Einiges multithreaded, im FinalBuilder,
drum fällt das mit der LogDatei besser weg.
Die Redirection in eine Variable funktioniert aber so weit erstmal.


Jupp, die Aufrufe an sich, in CMD oder Batch, funktionieren grundsätzlich.

Eine externe Batchstatei wollte ich aber auch gern ersparen ... lieber möglichst alles im FinalBuilder drin.

Und eigentlich ist es ja möglich, diese beiden Befehle von der CMD.exe direkt ausführen zu lassen,
nur mach ich da bestimmt irgendwo einen Fehler. (bestimmt Escaping im Parameter der CMD.exe selbst und nochmal im PowerShell-Script)
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (Gestern um 11:55 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.574 Beiträge
 
Delphi 12 Athens
 
#4

AW: MSBuild manuell aus FinalBuilder aufrufen

  Alt Gestern, 13:47
Eine externe Batchstatei wollte ich aber auch gern ersparen ... lieber möglichst alles im FinalBuilder drin.
Im FinalBuilder benutze ich es zwar nicht, aber im ContinuaCI. Dort kopiere ich den Inhalt der rsvars.bat in die Environment Variables der MSBuild Action (ohne die @SET davor). Das gibt es aber wohl in der entsprechenden FinalBuilder Action (noch) nicht.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.287 Beiträge
 
Delphi 12 Athens
 
#5

AW: MSBuild manuell aus FinalBuilder aufrufen

  Alt Gestern, 13:52
Teilweise gibt es sowas,
aber an einige Optionen kommt man via BeforeAction nicht ran.

Hart rein kopieren will ich aber auch nicht.
Zu Beginn geht ein Dialog auf, oder alternativ via Parameter an den FinalBuilder,
und da lässt sich dann z.B. die Delphi-Version umstellen, weswegen es auch direkt aus der jeweiligen rsvars.bat kommen muß.


Wir arbeiten noch mit D11 und für 'nen Test würde ich schon gern mal auf D12 umstellen.
(für XE hatten wir ein zweites FB-Script, aber seit D10.2 versuche ich es dynamisch zu halten)
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (Gestern um 13:55 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:58 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz