Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
?
Solved

JasperFillManager fails to create output

Posted on 2015-02-24
6
Medium Priority
?
28 Views
Last Modified: 2016-07-19
I'm trying to upgrade from Jasper Reports 5.5.1 to 6.0 but I can't get any output.  I'm running a standalone java application using compiled jrxml files.

I'm pretty sure it's a library I'm missing but I've gone through the documentation and I have all of the required libraries, so I'm not sure how to troubleshoot this further.

Also the program (at least in netbeans) runs through code in an unexpected fashion that I also can't figure out.

First here are the libraries that are included in the project.
List of librariesHere is the sample code where it fails.
    public static JasperPrint fillReport(String filename, JRParDataSource jrds,
            HashMap<String, Object> parameters) throws JRException {

     JasperPrint jasperPrint = null;
     jasperPrint = JasperFillManager.fillReport(filename, parameters,
                        jrds);
       return jasperPrint;
    }

Open in new window

The program runs the fillReport line but never hits the return jasperPrint line.

Here is the calling routine

    public static void saveJasperPrint(String jasperPath, String jasperFilename,
            String filename, HashMap<String, Object> parameters, JRParDataSource jrds)
            throws JRException {
        jasperPath = FileEx.makePathname(jasperPath, jasperFilename, true);
        jasperPath += ".jasper";

        // create jasperPrint
        JasperPrint jasperPrint = null;
        jasperPrint = fillReport(jasperPath, jrds, parameters);
        // save report
        saveReport(jasperPrint, new File(filename));
    }

Open in new window


After calling fillReport it never returns to run saveReport

And finally the top level caller.
try {   //other code in here
    setProgress(0);
    for (nDone=0; nDone< nTotal; nDone++) {  
             try {
                    // Add current user id to filename to prevent getting
                    // mixed up with someone else's report.
                        ReportFileIO.saveJasperPrint(criteria.getReportType().filename,
                            criteria.getFilename() + "." + user, parameters, jrds);
                } catch (JRException e) {
                    errors.add(BusinessConstants.dataCentreName + ": Unable to create jasperPrint for " +
                            criteria.getFilename());
                    break;
                }
            }
       }
        catch (Exception e) {
            errors.add(e.getMessage() + "\n" + Trace.printTrace(e));
        } finally {
            setProgress(100);
            return errors.isEmpty() ? null : errors;
        }

Open in new window


The call to saveJasperPrint happens and the return goes directly to the finally statement without being caught in any of the exception handlers.  

So I'm not sure how to resolve this problem.
0
Comment
Question by:geekdad1
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 2
6 Comments
 
LVL 16

Expert Comment

by:krakatoa
ID: 40628971
The program runs the fillReport line but never hits the return jasperPrint line.

How do you know that?
0
 
LVL 1

Author Comment

by:geekdad1
ID: 40629249
Running in debug mode under netbeans 7.0  I reach the breakpoint at  fillReport but single stepping from that statement goes right to the finally statement in the top level calling program.
0
 
LVL 16

Expert Comment

by:krakatoa
ID: 40629368
Well from what I see of the API for this, the JasperFillManager.fillReport() methods with 3 args seem to take the Map params as the last argument - maybe you want to check this, iianm. But I could be wrong as I don't do Jasper.
0
Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

 
LVL 1

Author Comment

by:geekdad1
ID: 40629518
This is a working application (at least it was until I tried to upgrade jasper), so I'm quite sure the arguments to the function are fine.
0
 
LVL 1

Accepted Solution

by:
geekdad1 earned 0 total points
ID: 41711411
Closing this as it's too old.
0
 
LVL 1

Author Closing Comment

by:geekdad1
ID: 41718751
Moved on to other problems.  No longer an issue
0

Featured Post

How to Use the Help Bell

Need to boost the visibility of your question for solutions? Use the Experts Exchange Help Bell to confirm priority levels and contact subject-matter experts for question attention.  Check out this how-to article for more information.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Java Flight Recorder and Java Mission Control together create a complete tool chain to continuously collect low level and detailed runtime information enabling after-the-fact incident analysis. Java Flight Recorder is a profiling and event collectio…
Introduction This article is the first of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article explains our test automation goals. Then rationale is given for the tools we use to a…
Viewers learn about the “for” loop and how it works in Java. By comparing it to the while loop learned before, viewers can make the transition easily. You will learn about the formatting of the for loop as we write a program that prints even numbers…
Viewers learn how to read error messages and identify possible mistakes that could cause hours of frustration. Coding is as much about debugging your code as it is about writing it. Define Error Message: Line Numbers: Type of Error: Break Down…
Suggested Courses

610 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question