<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Aptos;
        panose-1:2 11 0 4 2 2 2 2 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        font-size:12.0pt;
        font-family:"Aptos",sans-serif;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;
        mso-ligatures:none;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style>
</head>
<body lang="EN-US" link="#467886" vlink="#96607D" style="word-wrap:break-word;line-break:after-white-space">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<div id="mail-editor-reference-message-container">
<div>
<div>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="margin-bottom:12.0pt"><b><span style="color:black">From:
</span></b><span style="color:black">Paul Sandoz <paul.sandoz@oracle.com><br>
<br>
</span></p>
</div>
<div>
<p class="MsoNormal">> In your modeling approach (ignoring multi-catch for now) I think it may be possible to refer directly to the catch blocks as successors for both exit and enter, thereby avoiding a level of indirection.
</p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">I think it would be a good start with significant effect. However, the position of each handler in the exception region stack would be very unclear and I would implicitly position them out of any stack. It
 is much simple to calculate which exception regions should each handler re-enter, rather than which regions to exit. It will also make much simpler modeling of variables modified in the try blocks. Exception regions exit and immediate re-enter after the variable
 modification fixes the flow graph.  <o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">> It would be interesting to expand on your example to include finally
</p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
</div>
<div>
<div>
<p class="MsoNormal"><span style="font-size:11.0pt">Finally blocks are just complex compositions of try/catch blocks (with duplications of the finally block code to all exit points).
<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">When lifting from bytecode I do not recognize try/finally, it would require further analysis to identify specific try/catch structures and lift it to try/finally.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">The example code:<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">    static void nestedCatch(int i) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">        PrintStream out = System.out;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">        while (true) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            try {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                try {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    if (i == 0) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                        break;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    } else if (i == 1) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                        continue;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                } catch (NullPointerException npe) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    out.println("CATCH NPE");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                } finally {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    out.println("FINALLY INNER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                out.println("AFTER TRY INNER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            } catch (RuntimeException re) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                out.println("CATCH RE");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            } finally {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                out.println("FINALLY OUTER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">        }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">    }<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#212121"><o:p> </o:p></span></p>
<p class="MsoNormal">Can be desugar the try/finally as:</p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">    static void nestedCatch(int i) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">        PrintStream out = System.out;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">        while (true) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            try {<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                try {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    try {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                        try {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                            if (i == 0) {<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                                out.println("FINALLY INNER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                                out.println("FINALLY OUTER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                                break;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                            } else if (i == 1) {<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                                out.println("FINALLY INNER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                                out.println("FINALLY OUTER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                                continue;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                            }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                        } catch (NullPointerException npe) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                            out.println("CATCH NPE");<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                        }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    } catch (Throwable t)  {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                        out.println("FINALLY INNER");<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                        throw t;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    out.println("FINALLY INNER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    out.println("AFTER TRY INNER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                } catch (RuntimeException re) {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                    out.println("CATCH RE");<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                }<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            } catch (Throwable t)  {</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                out.println("FINALLY OUTER");<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">                throw t;</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">            out.println("FINALLY OUTER");</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">        }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New";color:#212121">    }</span><span style="color:#212121"><o:p></o:p></span></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>