mirror of
https://github.com/twiglet/cs2j.git
synced 2025-01-18 13:15:17 +01:00
fix support for IDisposable.close(), it was broken in SE/Logic :(
This commit is contained in:
parent
4e9f105c54
commit
7e85ac4a83
55
CS2JLibrary/src/CS2JNet/System/Disposable.java
Normal file
55
CS2JLibrary/src/CS2JNet/System/Disposable.java
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2010,2011 Kevin Glynn (kevin.glynn@twigletsoftware.com)
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
|
||||||
|
Author(s):
|
||||||
|
|
||||||
|
Kevin Glynn (kevin.glynn@twigletsoftware.com)
|
||||||
|
*/
|
||||||
|
|
||||||
|
package CS2JNet.System;
|
||||||
|
|
||||||
|
import java.io.Closeable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author keving
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class Disposable implements IDisposable {
|
||||||
|
|
||||||
|
private Closeable closerVal = null;
|
||||||
|
private IDisposable dispVal = null;
|
||||||
|
|
||||||
|
public static Disposable mkDisposable(Closeable obj) {
|
||||||
|
Disposable ret = new Disposable();
|
||||||
|
ret.closerVal = obj;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
public static Disposable mkDisposable(IDisposable obj) {
|
||||||
|
Disposable ret = new Disposable();
|
||||||
|
ret.dispVal = obj;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see CS2JNet.System.IDisposable#Dispose()
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void Dispose() throws Exception {
|
||||||
|
if (dispVal != null)
|
||||||
|
dispVal.Dispose();
|
||||||
|
else if (closerVal != null)
|
||||||
|
closerVal.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,3 +1,23 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2007,2008,2009,2010 Rustici Software, LLC
|
||||||
|
Copyright 2010,2011 Kevin Glynn (kevin.glynn@twigletsoftware.com)
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
|
||||||
|
Author(s):
|
||||||
|
|
||||||
|
Kevin Glynn (kevin.glynn@twigletsoftware.com)
|
||||||
|
*/
|
||||||
package CS2JNet.System;
|
package CS2JNet.System;
|
||||||
|
|
||||||
public interface IDisposable {
|
public interface IDisposable {
|
||||||
|
@ -193,15 +193,15 @@ scope TypeContext {
|
|||||||
// for ["conn", "conn1", "conn2"] generate:
|
// for ["conn", "conn1", "conn2"] generate:
|
||||||
//
|
//
|
||||||
// if (conn != null)
|
// if (conn != null)
|
||||||
// ((IDisposable)conn).Dispose();
|
// Disposable.mkDisposable(conn).Dispose();
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
// if (conn2 != null)
|
// if (conn2 != null)
|
||||||
// ((IDisposable)conn2).Dispose();
|
// Disposable.mkDisposable(conn2).Dispose();
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
// if (conn3 != null)
|
// if (conn3 != null)
|
||||||
// ((IDisposable)conn3).Dispose();
|
// Disposable.mkDisposable(conn3).Dispose();
|
||||||
// used in the finally block of the using translation
|
// used in the finally block of the using translation
|
||||||
protected CommonTree addDisposeVars(IToken tok, List<string> vars) {
|
protected CommonTree addDisposeVars(IToken tok, List<string> vars) {
|
||||||
|
|
||||||
@ -222,26 +222,35 @@ scope TypeContext {
|
|||||||
|
|
||||||
adaptor.AddChild(root_1, (CommonTree)adaptor.Create(SEP, "SEP"));
|
adaptor.AddChild(root_1, (CommonTree)adaptor.Create(SEP, "SEP"));
|
||||||
|
|
||||||
|
// Disposable.mkDisposable(var).Dispose()
|
||||||
root_2 = (CommonTree)adaptor.Nil;
|
root_2 = (CommonTree)adaptor.Nil;
|
||||||
root_2 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(APPLY, tok, "APPLY"), root_2);
|
root_2 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(APPLY, tok, "APPLY"), root_2);
|
||||||
|
|
||||||
|
// Disposable.mkDisposable(var).Dispose
|
||||||
CommonTree root_3 = (CommonTree)adaptor.Nil;
|
CommonTree root_3 = (CommonTree)adaptor.Nil;
|
||||||
root_3 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(DOT, tok, "."), root_3);
|
root_3 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(DOT, tok, "."), root_3);
|
||||||
|
|
||||||
|
// Disposable.mkDisposable(var)
|
||||||
CommonTree root_4 = (CommonTree)adaptor.Nil;
|
CommonTree root_4 = (CommonTree)adaptor.Nil;
|
||||||
root_4 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(CAST_EXPR, tok, "CAST"), root_4);
|
root_4 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(APPLY, tok, "APPLY"), root_4);
|
||||||
|
|
||||||
|
// Disposable.mkDisposable
|
||||||
CommonTree root_5 = (CommonTree)adaptor.Nil;
|
CommonTree root_5 = (CommonTree)adaptor.Nil;
|
||||||
root_5 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(TYPE, tok, "TYPE"), root_5);
|
root_5 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(DOT, tok, "."), root_5);
|
||||||
|
|
||||||
adaptor.AddChild(root_5, (CommonTree)adaptor.Create(IDENTIFIER, tok, "IDisposable"));
|
adaptor.AddChild(root_5, (CommonTree)adaptor.Create(IDENTIFIER, tok, "Disposable"));
|
||||||
|
adaptor.AddChild(root_5, (CommonTree)adaptor.Create(IDENTIFIER, tok, "mkDisposable"));
|
||||||
|
|
||||||
|
CommonTree root_6 = (CommonTree)adaptor.Nil;
|
||||||
|
root_6 = (CommonTree)adaptor.BecomeRoot((CommonTree)adaptor.Create(ARGS, tok, "ARGS"), root_6);
|
||||||
|
|
||||||
|
adaptor.AddChild(root_6, (CommonTree)adaptor.Create(IDENTIFIER, tok, var));
|
||||||
|
|
||||||
adaptor.AddChild(root_4, root_5);
|
adaptor.AddChild(root_4, root_5);
|
||||||
|
adaptor.AddChild(root_4, root_6);
|
||||||
|
|
||||||
adaptor.AddChild(root_4, (CommonTree)adaptor.Create(IDENTIFIER, tok, var));
|
|
||||||
|
|
||||||
adaptor.AddChild(root_3, root_4);
|
adaptor.AddChild(root_3, root_4);
|
||||||
|
|
||||||
adaptor.AddChild(root_3, (CommonTree)adaptor.Create(IDENTIFIER, tok, "Dispose"));
|
adaptor.AddChild(root_3, (CommonTree)adaptor.Create(IDENTIFIER, tok, "Dispose"));
|
||||||
|
|
||||||
adaptor.AddChild(root_2, root_3);
|
adaptor.AddChild(root_2, root_3);
|
||||||
@ -1628,7 +1637,8 @@ using_statement[bool isStatementListCtxt]
|
|||||||
}:
|
}:
|
||||||
// see http://msdn.microsoft.com/en-us/library/yh598w02.aspx for translation
|
// see http://msdn.microsoft.com/en-us/library/yh598w02.aspx for translation
|
||||||
u='using' '(' resource_acquisition c=')' embedded_statement[/* isStatementListCtxt */ false]
|
u='using' '(' resource_acquisition c=')' embedded_statement[/* isStatementListCtxt */ false]
|
||||||
{ disposers = addDisposeVars($c.token, $resource_acquisition.resourceNames); }
|
{ disposers = addDisposeVars($c.token, $resource_acquisition.resourceNames);
|
||||||
|
AddToImports("CS2JNet.System.Disposable"); }
|
||||||
f=magicFinally[$c.token, disposers]
|
f=magicFinally[$c.token, disposers]
|
||||||
magicTry[$u.token, state.backtracking == 0 ? embeddedStatementToBlock($u.token, $embedded_statement.tree) : null, null, $f.tree]
|
magicTry[$u.token, state.backtracking == 0 ? embeddedStatementToBlock($u.token, $embedded_statement.tree) : null, null, $f.tree]
|
||||||
-> {isStatementListCtxt}? OPEN_BRACE[$u.token, "{"] resource_acquisition SEMI[$c.token, ";"] magicTry CLOSE_BRACE[$u.token, "}"]
|
-> {isStatementListCtxt}? OPEN_BRACE[$u.token, "{"] resource_acquisition SEMI[$c.token, ";"] magicTry CLOSE_BRACE[$u.token, "}"]
|
||||||
@ -1869,7 +1879,7 @@ magicTry[IToken tok, CommonTree body, CommonTree catches, CommonTree fin]:
|
|||||||
|
|
||||||
magicDispose[IToken tok, string var]:
|
magicDispose[IToken tok, string var]:
|
||||||
-> ^(IF[tok, "if"] ^(NOT_EQUAL[tok, "!="] IDENTIFIER[tok, var] NULL[tok, "null"]) SEP
|
-> ^(IF[tok, "if"] ^(NOT_EQUAL[tok, "!="] IDENTIFIER[tok, var] NULL[tok, "null"]) SEP
|
||||||
^(APPLY[tok, "APPLY"] ^(DOT[tok, "."] ^(CAST_EXPR[tok, "CAST"] ^(TYPE[tok, "TYPE"] IDENTIFIER[tok, "IDisposable"]) IDENTIFIER[tok, var]) IDENTIFIER[tok, "Dispose"])) SEMI[tok, ";"])
|
^(APPLY[tok, "APPLY"] ^(DOT[tok,"."] ^(APPLY[tok, "APPLY"] ^(DOT[tok, "."] IDENTIFIER[tok, "Disposable"] IDENTIFIER[tok, "mkDisposable"]) ^(ARGS[tok,"ARGS"] IDENTIFIER[tok, var])) IDENTIFIER[tok, "Dispose"])) SEMI[tok, ";"])
|
||||||
;
|
;
|
||||||
|
|
||||||
magicFinally[IToken tok, CommonTree statement_list]:
|
magicFinally[IToken tok, CommonTree statement_list]:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user