diff options
Diffstat (limited to 'linden/indra/newview/llappviewer.cpp')
-rw-r--r-- | linden/indra/newview/llappviewer.cpp | 44 |
1 files changed, 11 insertions, 33 deletions
diff --git a/linden/indra/newview/llappviewer.cpp b/linden/indra/newview/llappviewer.cpp index e3d7073..30ac8fa 100644 --- a/linden/indra/newview/llappviewer.cpp +++ b/linden/indra/newview/llappviewer.cpp | |||
@@ -2610,43 +2610,36 @@ void LLAppViewer::setCrashBehavior(S32 cb) | |||
2610 | 2610 | ||
2611 | bool LLAppViewer::anotherInstanceRunning() | 2611 | bool LLAppViewer::anotherInstanceRunning() |
2612 | { | 2612 | { |
2613 | // We create a marker file when the program starts and remove the file when it finishes. | 2613 | // We create a marker file when the program starts and remove the file when it finishes. |
2614 | // If the file is currently locked, that means another process is already running. | 2614 | // If the file is currently locked, that means another process is already running. |
2615 | 2615 | ||
2616 | std::string marker_file = gDirUtilp->getExpandedFilename(LL_PATH_LOGS, MARKER_FILE_NAME); | 2616 | std::string marker_file = gDirUtilp->getExpandedFilename(LL_PATH_LOGS, MARKER_FILE_NAME); |
2617 | llinfos << "Checking marker file for lock..." << llendl; | 2617 | llinfos << "Checking marker file for lock..." << llendl; |
2618 | 2618 | ||
2619 | // If file doesn't exist, we create it | 2619 | //Freeze case checks |
2620 | // If file does exist, try to get writing privileges | 2620 | apr_file_t* fMarker = ll_apr_file_open(marker_file, LL_APR_RB); |
2621 | FILE* fMarker = LLFile::fopen(marker_file.c_str(), "rb"); // Flawfinder: ignore | ||
2622 | if (fMarker != NULL) | 2621 | if (fMarker != NULL) |
2623 | { | 2622 | { |
2624 | // File exists, try opening with write permissions | 2623 | // File exists, try opening with write permissions |
2625 | fclose(fMarker); | 2624 | apr_file_close(fMarker); |
2626 | fMarker = LLFile::fopen(marker_file.c_str(), "wb"); // Flawfinder: ignore | 2625 | fMarker = ll_apr_file_open(marker_file, LL_APR_WB); |
2627 | if (fMarker == NULL) | 2626 | if (fMarker == NULL) |
2628 | { | 2627 | { |
2628 | // Another instance is running. Skip the rest of these operations. | ||
2629 | llinfos << "Marker file is locked." << llendl; | 2629 | llinfos << "Marker file is locked." << llendl; |
2630 | return TRUE; | 2630 | return TRUE; |
2631 | } | 2631 | } |
2632 | 2632 | if (apr_file_lock(fMarker, APR_FLOCK_NONBLOCK | APR_FLOCK_EXCLUSIVE) != APR_SUCCESS) //flock(fileno(fMarker), LOCK_EX | LOCK_NB) == -1) | |
2633 | // *FIX:Mani - rather than have this exception here, | ||
2634 | // LLFile::fopen() have consistent behavior across platforms? | ||
2635 | #if LL_DARWIN || LL_LINUX || LL_SOLARIS | ||
2636 | // Try to lock it. On Mac, this is the only way to test if it's actually locked. | ||
2637 | if (flock(fileno(fMarker), LOCK_EX | LOCK_NB) == -1) | ||
2638 | { | 2633 | { |
2639 | // Lock failed - somebody else has it. | 2634 | apr_file_close(fMarker); |
2640 | fclose(fMarker); | ||
2641 | llinfos << "Marker file is locked." << llendl; | 2635 | llinfos << "Marker file is locked." << llendl; |
2642 | return TRUE; | 2636 | return TRUE; |
2643 | } | 2637 | } |
2644 | #endif | 2638 | // No other instances; we'll lock this file now & delete on quit. |
2645 | fclose(fMarker); | 2639 | apr_file_close(fMarker); |
2646 | } | 2640 | } |
2647 | llinfos << "Marker file isn't locked." << llendl; | 2641 | llinfos << "Marker file isn't locked." << llendl; |
2648 | return FALSE; | 2642 | return FALSE; |
2649 | |||
2650 | } | 2643 | } |
2651 | 2644 | ||
2652 | void LLAppViewer::initMarkerFile() | 2645 | void LLAppViewer::initMarkerFile() |
@@ -2688,25 +2681,10 @@ void LLAppViewer::initMarkerFile() | |||
2688 | ll_apr_file_remove(error_marker_file); | 2681 | ll_apr_file_remove(error_marker_file); |
2689 | 2682 | ||
2690 | //Freeze case checks | 2683 | //Freeze case checks |
2684 | if(anotherInstanceRunning()) return; | ||
2691 | fMarker = ll_apr_file_open(mMarkerFileName, LL_APR_RB); | 2685 | fMarker = ll_apr_file_open(mMarkerFileName, LL_APR_RB); |
2692 | if (fMarker != NULL) | 2686 | if (fMarker != NULL) |
2693 | { | 2687 | { |
2694 | // File exists, try opening with write permissions | ||
2695 | apr_file_close(fMarker); | ||
2696 | fMarker = ll_apr_file_open(mMarkerFileName, LL_APR_WB); | ||
2697 | if (fMarker == NULL) | ||
2698 | { | ||
2699 | // Another instance is running. Skip the rest of these operations. | ||
2700 | llinfos << "Marker file is locked." << llendl; | ||
2701 | return; | ||
2702 | } | ||
2703 | if (apr_file_lock(fMarker, APR_FLOCK_NONBLOCK | APR_FLOCK_EXCLUSIVE) != APR_SUCCESS) //flock(fileno(fMarker), LOCK_EX | LOCK_NB) == -1) | ||
2704 | { | ||
2705 | apr_file_close(fMarker); | ||
2706 | llinfos << "Marker file is locked." << llendl; | ||
2707 | return; | ||
2708 | } | ||
2709 | // No other instances; we'll lock this file now & delete on quit. | ||
2710 | apr_file_close(fMarker); | 2688 | apr_file_close(fMarker); |
2711 | gLastExecEvent = LAST_EXEC_FROZE; | 2689 | gLastExecEvent = LAST_EXEC_FROZE; |
2712 | llinfos << "Exec marker found: program froze on previous execution" << llendl; | 2690 | llinfos << "Exec marker found: program froze on previous execution" << llendl; |