Blog

Member Methods for Java Streams in BoxLang

Maria Jose Herrera August 26, 2024

Spread the word

Maria Jose Herrera

August 26, 2024

Spread the word


Share your thoughts

Streamline Your Data Handling with New BoxLang Stream Collectors

BoxLang's all about enhancing your coding experience by making data manipulation smooth and intuitive. We've recently introduced some powerful new features that extend our support for Java Streams, giving you more flexibility and control over collecting and processing data.

Review Original Post

What’s New?

We’ve added a set of handy stream collectors that bridge the gap between Java Streams and BoxLang's native data types. Here’s a quick rundown of what’s available:

  1. Collect to a BoxLang Array with .toBXArray() . Transform a stream of objects into a native BoxLang array. This method is akin to .toList() in Java, but returns a BoxLang array instead of a Java List.

    import java.util.stream.IntStream;
    
    // Create a stream of integers and convert it to a BoxLang array
    result = IntStream.range(1, 6).toBXArray(); // [1, 2, 3, 4, 5]
    
  2. Convert Map Entries to a BoxLang Struct with .toBXStruct() Use this method to collect a stream of Map entries into a BoxLang struct. It’s perfect for when you want to filter and structure your data efficiently.

    foods = {
      'apples': 'healthy',
      'bananas': 'healthy',
      'pizza': 'junk',
      'tacos': 'junk'
    };
    
    result = foods.entrySet().stream()
      .filter(e -> e.getValue() == 'healthy')
      .toBXStruct();
    
  3. Add Data to an Existing Query with .toBXQuery() This collector allows you to populate an existing query object with data from a stream, making it easy to integrate Java Streams with BoxLang queries.

    // Create an empty query and populate it with data
    qry = queryNew("name,title", "varchar,varchar");
    
    [
      { name: "Brad", title: "Developer" },
      { name: "Luis", title: "CEO" },
      { name: "Jorge", title: "PM" }
    ].stream().toBXQuery(qry);
    
  4. Create a Delimited List with .toBXList() Convert a stream of strings into a delimited list, offering a straightforward way to join data with custom delimiters.

    domain = ["www", "google", "com"].stream().toBXList(".");
    

Why Streams?

Streams offer more than just familiar methods like map()forEach(), and findFirst(). They represent a flexible pipeline for data processing that can handle potentially infinite data sources efficiently. Unlike arrays or structs, streams can handle operations in parallel, providing powerful ways to process large datasets.

Here’s a quick example of using a stream to find the first number in the Fibonacci sequence greater than 1000—all in BoxLang:

import java.util.stream.Stream;

Stream.iterate([0, 1], f -> [f[1], f[0] + f[1]])
  .map(f -> f[1])
  .dropWhile(n -> n < 1000)
  .findFirst()
  .get(); // 1597

Ready to Dive In?

We hope these new stream collectors make your data handling in BoxLang more versatile and powerful. For more details and examples, check out the feature ticket:

Review Original Post

Add Your Comment

Recent Entries

12 Days of BoxLang - Day 4: TestBox

12 Days of BoxLang - Day 4: TestBox

Today we’re celebrating one of the most exciting new additions to the BoxLang ecosystem:

the TestBox BoxLang CLI Runner — a fast, native way to run your TestBox tests directly through the BoxLang Runtime. ⚡

No server required. No CommandBox needed. Just pure, ultra-fast BoxLang-powered testing from the command lineon Windows, Mac, and Linux.

If you’re building modern applications with BoxLang — web apps, CLIs, serverless functions, Android apps, or OS-level utilities — this new feature gives you a unified, flexible testing workflow you can run anywhere.

Victor Campos
Victor Campos
December 13, 2025
12 days of BoxLang - Day 3: SocketBox!

12 days of BoxLang - Day 3: SocketBox!

As BoxLang continues evolving into a modern, high-performance, JVM-based runtime, real-time communication becomes essential for the applications we all want to build: dashboards, collaboration tools, notifications, live feeds, multiplayer features, and more.

That’s where SocketBox steps in — the WebSocket upgrade listener built to work seamlessly with CommandBox and the BoxLang MiniServer. ⚡

Today, for Day 3, we’re highlighting how SocketBox supercharges BoxLang development by giving you fast, flexible, and framework-agnostic WebSocket capabilities.

Maria Jose Herrera
Maria Jose Herrera
December 12, 2025
12 Days of BoxLang - Day 2: CommandBox

12 Days of BoxLang - Day 2: CommandBox

BoxLang + CommandBox: The Enterprise Engine Behind Your Deployments

For Day 2 of our 12 Days of Christmas series, we’re diving into one of the most powerful parts of the BoxLang ecosystem: CommandBox the defacto enterprise servlet deployment platform for BoxLang.

If BoxLang is the language powering your applications, CommandBox is the engine room behind it all. ⚙️

Victor Campos
Victor Campos
December 11, 2025