New default Java enum wrapping approach which uses the type safe enum pattern
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@5917 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
80b89d662c
commit
1b1dadc9de
6 changed files with 1099 additions and 11 deletions
|
|
@ -1,7 +1,7 @@
|
|||
|
||||
import java_enums.*;
|
||||
|
||||
public class java_enums_runme implements java_enumsConstants {
|
||||
public class java_enums_runme implements stuff {
|
||||
static {
|
||||
try {
|
||||
System.loadLibrary("java_enums");
|
||||
|
|
@ -18,26 +18,26 @@ public class java_enums_runme implements java_enumsConstants {
|
|||
// Switch statement will only compile if these enums are initialised
|
||||
// from a constant Java value, that is not from a function call
|
||||
switch(number) {
|
||||
case java_enums.FIDDLE:
|
||||
case stuff.FIDDLE:
|
||||
break;
|
||||
case java_enums.STICKS:
|
||||
case stuff.STICKS:
|
||||
break;
|
||||
case java_enums.BONGO:
|
||||
case stuff.BONGO:
|
||||
break;
|
||||
case java_enums.DRUMS:
|
||||
case stuff.DRUMS:
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
if (java_enums.DRUMS != 15)
|
||||
if (stuff.DRUMS != 15)
|
||||
throw new RuntimeException("Incorrect value for DRUMS");
|
||||
|
||||
// check typemaps use short for this enum
|
||||
short nonsense = java_enums.POPPYCOCK;
|
||||
short tst1 = java_enums.test1(nonsense);
|
||||
short tst2 = java_enums.test2(nonsense);
|
||||
short poppycock = nonsense.POPPYCOCK;
|
||||
short tst1 = java_enums.test1(poppycock);
|
||||
short tst2 = java_enums.test2(poppycock);
|
||||
|
||||
// Check that we can drop the java_enums keyword as this class implements the java_enumsConstants interface
|
||||
// Check that stuff is an interface and not a class - we can drop the stuff keyword as this class implements the stuff interface
|
||||
switch(number) {
|
||||
case FIDDLE:
|
||||
break;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue