Partial revert. Reimplementing the previous behaviour of accounting for differences in current working directory between the running single-launch process and later invocations of the same, as this is necessary to handle correctly any relative paths given on the command-line. Added comment.

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@30709 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Jonas Sundström 2009-05-11 19:31:18 +00:00
parent e0e7fdd350
commit b8bc570a12

View File

@ -245,8 +245,48 @@ StyledEditApp::RefsReceived(BMessage *message)
void
StyledEditApp::ArgvReceived(int32 argc, char* argv[])
{
// StyledEdit has the "single launch" flag set in its
// resources. This means that while StyledEdit is running,
// additional StyledEdit invocations will not result in a
// new process but re-use the existing one, calling the
// hook methods of the BApplication subclass: ArgvReceived(),
// RefsReceived() or MessageReceived(B_SILENT_RELAUNCH),
// depending on the nature of the invocation.
// An implication of this relevant to ArgvReceived() is
// that the running application might have a current
// working directory different from the one of a later
// invocation. Arguments received from the later invocation,
// if having relative paths, will be incorrect when
// interpreted as relative to the current working directory.
// BApplication's ArgvReceived() method does not supply
// the cwd of the invocation, but the BMessage by which
// the arguments get communicated to the BApplication
// supplies a cwd string. So we ask the BApplication,
// to show the current message - the one that triggered
// the ArgvReceived() hook method - extract the cwd
// string from it and patch any relative paths in argv.
// This does not take into account --option handling
// and how to avoid prepending a path to such arguments
const char* cwd = "";
BMessage* message = CurrentMessage();
if (message != NULL) {
if (message->FindString("cwd", &cwd) != B_OK)
cwd = "";
}
for (int i = 1 ; (i < argc) ; i++) {
BPath path(argv[i]);
BPath path;
if (argv[i][0] == '/')
path.SetTo(argv[i]);
else
path.SetTo(cwd, argv[i]);
// patch relative paths only
entry_ref ref;
get_ref_for_path(path.Path(), &ref);