~~~~~~~
Prolog:
~~~~~~~
Was passiert, wenn man, z.B. in einer DOS-Box ist, sich z.B. im Verzeichnis c:\windows befindet und von dort aufruft:
> dir c:\
? Antwort: Der Inhalt des Root-Verzeichnisses von Laufwerk C: wird angezeigt.
Was passiert beim Aufruf von
> dir "c:\"
? Antwort: Dasselbe
~~~~~~~
Kapitel 1
~~~~~~~
Folgendes simples C-Programm 'ShowArgs' zeigt die über einen Kommandozeilenaufruf übergebenen Argumente an:
//---------------------------------------------------------------------------
#include
//---------------------------------------------------------------------------
void main(int argc, char *argv[])
{
for(int i=1; i< argc; i++)
printf("argv[%i]: %s\n", i, argv[i]);
}
//---------------------------------------------------------------------------
Rufe ich es jetzt analog zu oben auf:
Einmal mit
ShowArgs c:\
zeigt es an
argv[1]: c:\
Rufe ich es jetzt aber mit
ShowArgs "c:\"
auf, zeigt es folgendes an:
argv[1]: c:"
[Die Ursache, die mich in erster Linie weniger interessiert ist vermutlich, dass im zweiten Fall der Backslash '\' als Escape-Character gewertet wird und besagt, dass das folgende Zeichen ('"') nicht speziell interpretiert werden soll.]
???????-----------
? Meine Frage ist: Wie kann ich in C diese unerwünschte Uminterpretation vermeiden?
DIR.EXE ist doch vermutlich auch in C geschrieben?
???????-----------
(Würde DIR.EXE das Argument "c:\" als c:" interpretieren, so würde es beim Aufruf innerhalb von c:\Windows heraus den Inhalt von c:\Windows ausgeben. Einfach mal ausprobieren: dir c:" )
(Im Hinterkopf habe ich noch, dass es die Möglichkeit gibt, noch VOR main auf eine Funktion zuzugreifen (_main()), aber hatte bei einem Versuch keinen Erfolg. Vielleicht war das ja noch bei einem anderen System.)
Über das Problem gestolpert bin ich, als ein kleines Tool von mir, geschrieben zur Unterstützung von Batchdateien plötzlich unsinnig reagierte. Beim Debuggen war mir dann klar, warum...
Vielen Dank,
Mdl
Programmieren - alles kontrollieren 4.938 Themen, 20.667 Beiträge
Halllo Syntehetic_codes,
> Die " " arbeiten offensichtlich als begrenzer mit, sprich der Commandozeileninterpreter zieht alles zwischen " " zu einem Argument zusammen.
Richtig. Braucht man also z.B. um Verzeichnisse wie 'Dokumente und Einstellungen' ansprechend zu können.
> Warum dir das richtig macht? Gute Frage, aber ich gehe mal davon aus, dass dir die eingaben selbst bearbeiten darf.
Da DIR ja jetzt ein Befehl innerhalb des Betriebssystem ist und nicht außerhalb, ist es natürlich durchaus möglich, dass es mehr kann, als man den externen Prg. außerhalb erlaubt.
Trotzdem: Soweit ich weiß ruft das CMD-Kommando ja nicht gleich main() auf, sondern es wird zuvor ja noch ein Startup-Code ausgeführt, der wie ich meine auch die Argumente entsprechend verwaltet und letztlich eben dann main() aufruft...
In den müsste sich doch eingreifen lassen.
Ich hab jetzt mein ECHO-Tool um eine entsprechende Option erweitert, dass man ein Argument (d.h. einen argv-Index) angeben kann, in dem Ersetzungen stattfinden können, in diesem Fall also '"' durch '\'. Klappt auch und der Aufrufer des Batchfiles kriegt von dieser Verkünstelung ja auch nichts mit. Trotzdem ist das wieder mal eine Lösung, mit der man nicht wirklich glücklich ist...
Viele Grüße.
Mdl