Blog

Auto-casting Java Functional Interfaces to BoxLang Functions

Maria Jose Herrera August 21, 2024

Spread the word

Maria Jose Herrera

August 21, 2024

Spread the word


Share your thoughts

Simplify Java Integration with Auto-Casting Functional Interfaces

We’ve got an exciting new feature to share that’s all about bridging the gap between Java and BoxLang, making your code even more versatile and dynamic.

Review Original Post

Bringing Java and BoxLang Closer: Auto-Casting Functional Interfaces

We’re thrilled to introduce auto-casting for Java functional interfaces to BoxLang functions. What does that mean? Simply put, you can now take a functional interface from Java and seamlessly use it as a BoxLang function. This makes it easier to integrate Java’s robust functional programming capabilities directly into your BoxLang code.

You might recall that we previously allowed BoxLang functions to be used in Java. This new feature flips the script, enabling you to bring Java functions into BoxLang. It's all about enhancing interoperability and making both languages work together smoothly.

BoxLang Ticket

Why It Matters?

Java developers, you’ll find this especially handy. Imagine you’re working with Java and want to infuse some dynamic, functional programming into your app, similar to how Kotlin or Groovy might be used. This feature allows BoxLang to integrate seamlessly with Java, making it a powerful addition to your toolkit.

Try BoxLang

Getting Started: Examples in Action

Let’s dive into some examples to see this feature in action:

  1. Using Java’s Predicate Interface

    Java’s Predicate interface is perfect for filtering. Here’s how you can use it in BoxLang:

    // Import Java classes directly into BoxLang
    import java.util.function.Predicate;
    
    // Cast Java Predicate to BoxLang function
    isBrad = Predicate.isEqual( "brad" ) castas "function:Predicate"
    
    isBrad( "brad" ) // true
    isBrad( "luis" ) // false
    [ "brad", "luis", "jon" ].filter( isBrad ) // [ "brad" ]
    
    
  2. Sorting with Java’s Comparator

    The Collections.reverseOrder() method from the JDK provides a Comparator instance. Here’s how you can use it for sorting in BoxLang:

    import java.util.Collections;
    
    // Use Java Comparator directly for sorting
    [ 1, 7, 3, 99, 0 ].sort( Collections.reverseOrder() ) // [ 99, 7, 3, 1, 0 ]
    
    
  3. Integrating BoxLang with Java via JSR-223

    Java developers can pass Java lambdas into BoxLang like so:

    // Java code
    Bindings bindings = JSREngine.createBindings();
    bindings.put( "isEven", ( Predicate<Integer> ) ( n ) -> n % 2 == 0 );
    
    Object result = JSREngine.eval(
      """
        // BoxLang code using Java lambda
        [1,2,3,4,5,6,7,8,9,10].filter( isEven )
      """, bindings );
    // result contains [ 2, 4, 6, 8, 10 ]
    
    

The Power of Integration

This feature allows for easy integration between BoxLang and Java, making it simpler to leverage the best of both worlds. Whether you're working with Java functional interfaces or need to use them dynamically within BoxLang, this update is designed to enhance your coding experience and productivity.

For more details, check out the full ticket 

if you missed the original feature announcement

Happy coding!

Try BoxLang

Add Your Comment

Recent Entries

MatchBox and WebAssembly: Running BoxLang in the Browser and at the Edge

MatchBox and WebAssembly: Running BoxLang in the Browser and at the Edge

The MatchBox open beta is live at https://boxlang.ortusbooks.com/boxlang-framework/matchbox, and it brings something genuinely new to the BoxLang ecosystem: a path into WebAssembly.

That means BoxLang code can now move into browser applications, static-site deployments, edge runtimes, and WASI-style containers - without requiring a JVM. The feature is still beta, but the core direction is already useful: write BoxLang, compile it with MatchBox, and ship the generated WASM artifact to wherever a small portable runtime makes sense.

Jacob Beers
Jacob Beers
June 04, 2026