File: RTCoverageDataPersister.java

package info (click to toggle)
emma-coverage 2.0.5312%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd, stretch, wheezy
  • size: 2,000 kB
  • ctags: 3,667
  • sloc: java: 23,109; xml: 414; makefile: 22
file content (78 lines) | stat: -rw-r--r-- 3,069 bytes parent folder | download | duplicates (3)
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/* Copyright (C) 2003 Vladimir Roubtsov. All rights reserved.
 * 
 * This program and the accompanying materials are made available under
 * the terms of the Common Public License v1.0 which accompanies this distribution,
 * and is available at http://www.eclipse.org/legal/cpl-v10.html
 * 
 * $Id: RTCoverageDataPersister.java,v 1.1.2.2 2004/07/16 23:32:03 vlad_r Exp $
 */
package com.vladium.emma.rt;

import java.io.File;

import com.vladium.emma.IAppConstants;
import com.vladium.emma.data.DataFactory;
import com.vladium.emma.data.ICoverageData;
import com.vladium.logging.Logger;

// ----------------------------------------------------------------------------
/**
 * @author Vlad Roubtsov, (C) 2004
 */
abstract
class RTCoverageDataPersister
{
    // public: ................................................................
    
    // protected: .............................................................

    // package: ...............................................................
    
    /*
     * Stateless package-private method shared by RT and RTExitHook for coverage
     * data persistence. This method was moved out of RT class after build 4120
     * in order to decrease classloading dependency set for RTExitHook
     * (FR SF978671).
     */
    static void dumpCoverageData (final ICoverageData cdata, final boolean useSnapshot,
                                  final File outFile, final boolean merge)
    {
        try
        {
            if (cdata != null)
            {
                // use method-scoped loggers everywhere in RT:
                final Logger log = Logger.getLogger ();
                final boolean info = log.atINFO ();
                
                final long start = info ? System.currentTimeMillis () : 0;
                {
                    final ICoverageData cdataView = useSnapshot ? cdata.shallowCopy () : cdata;
                    
                    synchronized (Object.class) // fake a JVM-global critical section when multilply loaded RT's write to the same file
                    {
                        DataFactory.persist (cdataView, outFile, merge);
                    }
                }
                if (info)
                {
                    final long end = System.currentTimeMillis ();
                    
                    log.info ("runtime coverage data " + (merge ? "merged into" : "written to") + " [" + outFile.getAbsolutePath () + "] {in " + (end - start) + " ms}");
                }
            }
        }
        catch (Throwable t)
        {
            // log
            t.printStackTrace ();
            
            // TODO: do better chaining in JRE 1.4+
            throw new RuntimeException (IAppConstants.APP_NAME + " failed to dump coverage data: " + t.toString ());
        }
    }
    
    // private: ...............................................................

} // end of class
// ----------------------------------------------------------------------------