![]() |
Indy-Installation funktioniert nicht
Ich habe das neueste Indy-Paket heruntergeladen von:
![]() Da ich Delphi 11 verwende, habe ich \Lib\Fullc_Alexandria.bat ausgeführt. Die Fehlermeldung ist aber unverständlich: C:\Program Files (x86)\Embarcadero\Studio\22.0\Bin\CodeGear.Delphi. Targets(412,5): warning MSB6002: The command-line fo r the "DCC" task is too long. Command-lines longer than 32000 characters are likely to fail. Try reducing the length of the command-line by breaking down the call to "DCC" into multiple calls with fewer parameters per call. [C:\COMP\Indy- master\C28\IndySystem280.dproj] C:\Program Files (x86)\Embarcadero\Studio\22.0\Bin\CodeGear.Delphi. Targets(412,5): error MSB6003: The specified task ex ecutable "dcc" could not be run. The filename or extension is too long [C:\COMP\Indy-master\C28\IndySystem280.dproj] Done Building Project "C:\COMP\Indy-master\C28\IndySystem280.dproj" (Rebuild target(s)) -- FAILED. Wie kann aber die Befehlszeile für die Installation von Indy länger als 32.000 Zeichen sein? Wenn ich aber dann aber \C28\IndySystem280.dproj in Delphi 11 lade und manuell zu compilieren versuche, kommt diese Fehlermeldung: [Fatal Error] Cannot compile package 'IndySystem280' which is currently required by Delphi 11. Was ist damit gemeint? |
AW: Indy-Installation funktioniert nicht
Die Fehlermeldung heißt normalerweise, dass du zu viele Pfade in deinem Bibliothekspfad hast.
Wird die zu lange Kommandozeile gar nicht erst angezeigt? |
AW: Indy-Installation funktioniert nicht
Wieso übergibt das Script in der Befehlszeile überhaupt ALLE Library-Paths an den Delphi Befehlszeilen-Compiler DCC32? Das ist doch völlig unlogisch und unnötig - es soll doch nur das Indy-Package compiliert werden!
Auch die Fehlermeldung "[Fatal Error] Cannot compile package 'IndySystem280' which is currently required by Delphi 11." ist unlogisch da in sich widersprüchlich. |
AW: Indy-Installation funktioniert nicht
Zitat:
Um herauszufinden, welche Units benötigt werden, wird ja bereits der Compiler benötigt und ebenso der Zugriff auf die entsprechenden Units. Deshalb gibt es rein logisch keinerlei Möglichkeit, vorher herauszufinden, welche Units benötigt werden, um dann die Pfade zu filtern und dann nur die dem Compiler zu füttern, die entsprechende Units enthalten. Davon abgesehen macht das auch keinen Sinn, denn schon dafür wird ja ebenfalls die komplette Liste der Pfade benötigt. Delphi ist schlicht fehlerhaft eingestellt, wenn so viele Pfade im Bibliothekspfad stehen. Außerdem dauert das Kompilieren dann natürlich auch viel länger. Zitat:
In den meisten Fällen braucht man auch gar keine neuere Version von Indy als die, die mit Delphi ohnehin schon mitgeliefert wird. Das sind nur wenige Spezialfälle. |
AW: Indy-Installation funktioniert nicht
Es gibt eine recht aktuelle Anleitung dafür, wie man Indy aktualisiert:
Updating Indy ![]() Und wenn man es einfacher haben möchte: * die alte Indy-Version nicht deinstallieren, sondern: * neues Indy separat installieren - einfach per Subversion svn checkout - und dann: * nur für das Projekt die Suchpfade hinzufügen für Lib\Code, Lib\Protocols, Lib\System * Komponenten wenn möglich nur zur Laufzeit instanziieren So kann man * jederzeit z.B. mit Subversion "svn update" Indy aktualisieren * auf beliebige frühere Versionen switchen * mehrere Indy-Versionen parallel verwenden p.s. alternativ kann man natürlich auch dieses neue "git" verwwenden ;-) |
AW: Indy-Installation funktioniert nicht
Abgesehen von dem, was jaenicke schon schrieb: Wenn Du neue Indy-Packages compilieren willst, solltest Du vorher die Pfade zu der mitgelieferten Indy-Version aus der IDE-Configuration entfernen, sonst werden ggf. alte Units mit neuen gemischt und man sucht sich bei Fehlern den Wolf.
|
AW: Indy-Installation funktioniert nicht
Das scheint ein allgemeines Problem bei MS Build zu sein:
Microsoft (R) Build Engine version 4.8.4084.0 [Microsoft .NET Framework, version 4.0.30319.42000] Auch TMS verwendet MS BUILD zum Installieren seiner Komponenten - dort tritt dann der gleiche Fehler auf (Befehlszeile zu lang). Die TMS-Komponenten müssen dann umständlich manuell in der IDE installiert werden! Wie kann man verhindern, dass MS Build die gesamten Library Paths (!) an dcc32 übergibt? |
AW: Indy-Installation funktioniert nicht
Gibt es keine Möglichkeit, komfortabel ganze Gruppen von Packages zu deaktivieren? (Idealerweise auch zur Laufzeit der IDE?)
Es gibt zwar einen "Expert-Manager", mit dem man außerhalb der IDE (d.h. wenn diese nicht läuft) einzelne Packages deaktivieren/aktivieren kann: ![]() Aber wirklich sinnvoll wäre es nur, wenn man ganze Gruppen von Packages bequem suchen/filtern und auswählen könnte. |
AW: Indy-Installation funktioniert nicht
Zitat:
|
AW: Indy-Installation funktioniert nicht
Zitat:
Das hat aber nicht damit zu tun, ob MSBuild den Compiler aufruft oder Delphi selbst. Zitat:
Das hat mit MSBuild nichts (!) zu tun. Das ist nur ein schönes Tool, damit man die dcc32.exe nicht selbst aufrufen muss. In Delphi sieht das dann in den Meldungen z.B. so aus: Zitat:
Das Problem ist wie schon geschrieben, dass du zu viele Pfade eingetragen hast oder diese zu lang sind. Dafür kann weder Delphi noch MSBuild etwas. Du müsstest diese einfach mal aufräumen... |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:56 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