| Autor |
Nachricht |
Alberich
Mitglied
Benutzerprofil
Anmeldungsdatum: 28.01.2011
Beiträge: 56
|
Alberich Mitglied
19:44:24 30.07.2012 Titel: |
|
Zitieren |
Vielen Dank für die vielen hilfreichen Antworten!
Es ist also, wenn ich das jetzt richtig verstanden habe, nicht notwendig (und "unschön") nach Adminrechten für das Programm zu verlangen. OK.
Jetzt muss ich mir also beim Programmstart den Pfad ins aktuelle Verzeichnis besorgen. Das Testprogramm sieht jetzt so aus:
| C++: | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | TCHAR EXEPath[MAX_PATH + 1];
DWORD nChars = GetModuleFileName( NULL, EXEPath, MAX_PATH + 1 );
//EXEPath enthält jetzt den Pfad inklusive Dateiname der exe
//hier mache ich nen std::string draus um auf die Konsole auszugeben
std::string strPath;
strPath.assign(&EXEPath[0], &EXEPath[nChars]);
std::cout<<"\n"<<strPath;
std::ifstream CONF;
CONF.open("startup.ini");
if(CONF)
{
//Inhalt der Datei startup.ini einlesen
CONF.close();
}
else
{
std::cout<<"\nstartup.ini not found";
} | |
Die Ausgabe auf der Konsole ist jetzt wie erwartet
D:\EigeneProgramme\Test\bin\Debug\Testprogramm.exe
Hier muss ja nun noch der Dateiname entfernt und statt dessen der Name der .ini Datei (startup.ini) angefügt werden.
Gibt es für char-Arrays so etwas wie substring(pos_begin, pos_end) und find_last_of() für strings um den Dateinamen der exe abschneiden zu können?
Alberich |
|
|
|
 |
-guest-
Unregistrierter
|
-guest- Unregistrierter
20:12:22 30.07.2012 Titel: |
|
Zitieren |
|
 |
geeky
Mitglied
Benutzerprofil
Anmeldungsdatum: 04.05.2001
Beiträge: 6187
|
geeky Mitglied
21:32:15 30.07.2012 Titel: |
|
Zitieren |
|
 |
hustbaer
Mitglied
Benutzerprofil
Anmeldungsdatum: 27.10.2006
Beiträge: 16057
|
hustbaer Mitglied
21:38:28 30.07.2012 Titel: |
|
Zitieren |
| Alberich schrieb: | | Hier muss ja nun noch der Dateiname entfernt und statt dessen der Name der .ini Datei (startup.ini) angefügt werden. |
Japp.
| Zitat: | | Gibt es für char-Arrays so etwas wie substring(pos_begin, pos_end) und find_last_of() für strings um den Dateinamen der exe abschneiden zu können? |
Nö. Aber es gibt ja std::string. Willst du std::string aus irgend einem Grund dafür nicht verwenden?
Ansonsten...
PathRemoveFileSpec EDIT: zu langsam *grmpf* /EDIT
| C++: | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | #include <windows.h>
#include <shlwapi.h> // für PathRemoveFileSpec
#pragma comment(lib, "shlwapi.lib") // für PathRemoveFileSpec
// ...
// TODO: check for errors
TCHAR exeDirectory[MAX_PATH] = {}; // + 1 brauch ma nicht. Das = {} auch nicht, aber naja... hab's mir irgendwann angewöhnt so-gut-wie immer alles zu initialisieren.
// Da hier nicht Performance-kritisch schadet es auch nicht.
GetModuleFileName(NULL, exeDirectory, MAX_PATH);
PathRemoveFileSpec(exeDirectory); // Macht Filenamen inklusive dem letzten "\" weg (modifiziert direkt den übergebenen Puffer)
// Wenn schon TCHAR dann auch bei std::basic_string, sonst kompiliert das ja nichtmal mit UNICODE
// (ggf. irgendwo in nem .h File ein nettes typedef std::basic_string<TCHAR> tstring; machen)
std::basic_string<TCHAR> configFilePath = std::basic_string<TCHAR>(exeDirectory) + _T("\\startup.ini");
std::ifstream configFile(configFilePath.c_str()); // geht auch ohne extra .open() Zeile
if (configFile)
{
// Inhalt der Datei startup.ini einlesen
// configFile.close(); // kümmert sich der Destruktor drum, und bei ausschliesslich lesenden Zugriffen ist das auch vollkommen OK
}
else
{
std::cout<<"\nstartup.ini not found";
} | |
Bitte die ganzen zusätzlichen Anmerkungen nicht falsch verstehen. Wenns dich nicht interessiert überlies es einfach, falls doch hast du ein paar Tips was du besser/anders machen kannst. |
_________________ "Let there be Licht..." http://lichttools.sourceforge.net/
Sehr cooles ASCII Spiel (leider nicht von mir): ASCII-Scramble - http://www.roskakori.at/ascii/
Zuletzt bearbeitet von hustbaer am 21:40:41 30.07.2012, insgesamt 1-mal bearbeitet |
|
 |
Alberich
Mitglied
Benutzerprofil
Anmeldungsdatum: 28.01.2011
Beiträge: 56
|
Alberich Mitglied
10:04:48 31.07.2012 Titel: |
|
Zitieren |
| hustbaer schrieb: | | Bitte die ganzen zusätzlichen Anmerkungen nicht falsch verstehen. Wenns dich nicht interessiert überlies es einfach, falls doch hast du ein paar Tips was du besser/anders machen kannst. | Ganz im Gegenteil! Ich bin dankbar für jede Hilfe und Anmerkung! Dein Codebeispiel finde ich sehr lehrreich, leider spielt der Compiler/Linker nicht mit:
Zeile 4: warning: ignoring #pragma comment
Zeile 13: undefined reference to `_imp__PathRemoveFileSpecA@4'
Ich verwende Code::Blocks (10.05). |
|
|
|
 |
Oberon_0
Mitglied
Benutzerprofil
Anmeldungsdatum: 08.04.2010
Beiträge: 86
|
Oberon_0 Mitglied
10:30:49 31.07.2012 Titel: |
|
Zitieren |
#pragma comment(lib, "shlwapi.lib") führt bei MS Visual C++ dazu, dass die "shlwapi.lib", die PathRemoveFileSpec enthält automatisch zu deinem Programm gelinkt wird. Bei CodeBlocks musst du sie wohl in den (Projekt-)Einstellungen eintragen. |
|
|
|
 |
Scorcher24
Mitglied
Benutzerprofil
Anmeldungsdatum: 29.12.2004
Beiträge: 2350
|
Scorcher24 Mitglied
10:33:04 31.07.2012 Titel: |
|
Zitieren |
gcc kann mittlerweile afaik das #pragma . |
_________________ Sometimes it pays to stay in bed in Monday, rather than spending the rest of the week debugging Monday's code. ~Dan Salomon
Meine Projekte
|
|
 |
Alberich
Mitglied
Benutzerprofil
Anmeldungsdatum: 28.01.2011
Beiträge: 56
|
Alberich Mitglied
10:55:36 31.07.2012 Titel: |
|
Zitieren |
OK, werd ich mir anschauen. Danke!
Habe noch ein bischen über das "Problem" nachgedacht und dieser Satz von hustbaer hat mich in die (hoffentlich ) richtige Richtung geschubst:
| hustbaer schrieb: | | [...] Aber es gibt ja std::string. Willst du std::string aus irgend einem Grund dafür nicht verwenden? | Es ist ja eigentlich schon alles da was ich brauche...
| C++: | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | TCHAR EXEPath[ MAX_PATH ];
DWORD nChars = GetModuleFileName( NULL, EXEPath, MAX_PATH );
//in einen string schreiben
std::basic_string<TCHAR> strPath;
strPath.assign( &EXEPath[0], &EXEPath[nChars] );
//den Namen der .exe abschneiden
strPath=strPath.substr( 0, strPath.find_last_of(_T("/\\")) );
//den Namen der .ini stattdessen anfügen
strPath=strPath + _T("\\startup.ini");
//und wieder einen C-string draus machen
std::ifstream configFile( strPath.c_str() );
if(configFile)
{
//lesen
//configFile.close(); //Aber schaden würde das explizite schliessen auch nicht, oder doch?
} | |
Gibt es gegen diese Lösung Einwände?
Alberich |
Zuletzt bearbeitet von Alberich am 11:03:41 31.07.2012, insgesamt 1-mal bearbeitet |
|
 |
Swordfish
Mitglied
Benutzerprofil
Anmeldungsdatum: 27.03.2005
Beiträge: 4182
|
Swordfish Mitglied
10:59:52 31.07.2012 Titel: |
|
Zitieren |
//edit: Chupa Chups, LLLLösch mich! |
Zuletzt bearbeitet von Swordfish am 11:04:49 31.07.2012, insgesamt 2-mal bearbeitet |
|
 |
Swordfish
Mitglied
Benutzerprofil
Anmeldungsdatum: 27.03.2005
Beiträge: 4182
|
Swordfish Mitglied
11:03:40 31.07.2012 Titel: |
|
Zitieren |
| Alberich schrieb: | | C++: | std::basic_string<TCHAR> strPath;
strPath.assign( &EXEPath[0], &EXEPath[nChars] ); | |
|
Warum nicht gleich
| C++: | | [cpp]std::basic_string<TCHAR> strPath( EXEPath ); | |
? |
|
|
|
 |