Routines - Reports
Reporting in HansaWorld Enterprise is non-destructive, i.e. you can make and print a report as many times as you wish. Some accounting programs are designed in such a way as to allow journal printing only directly in connection with the data entry. HansaWorld Enterprise does not have this limitation.
When you click the [Reports] button in the Master Control panel or use the Ctrl-R (Windows and Linux) or ⌘-R (Mac OS X) keyboard shortcut, a window is opened, containing a list of the available reports. The contents of this window will vary with the selected module: the illustration below shows the reports in the Nominal Ledger module:

Choose a report by clicking an item in the list once. If you need to set the page size, number of copies and other printer options for the report, choose 'Page Setup' from the File menu. You can also use this function to choose the printer on which the report is to be printed. These settings will be used whenever you print the particular report until you choose 'Page Setup' once again.
Once you have done this, double-click the report name in the list. A specification window will open, where you can choose the information that you want to be shown in the report. For example, when producing a Balance Sheet, you can use its specification window (illustrated below) to choose the period that is to be covered by the report.

While the specification window is open, you can choose the destination of the printout by selecting one of the Media options at the bottom of the window. These are the available options:
- Screen
 
- If you print to screen (the default setting), the report will be shown in a new window (described  here). You can subsequently send the report to a printer by clicking the Printer icon in the Button Bar of this window or by selecting 'Print' from the File menu.
 
- Printer 
 
- Use this option to send the report directly to a printer.
 
- File 
 
- Choose this option to export the contents of any report to a tab-delimited text file on your hard disk. You can then open this file in Excel, for further calculations etc or in Word or a page make-up program, for incorporation in publicity material or published reports.
 
- Clipboard
 
- This option will place the contents of a report in your computer's clipboard, from where you can paste it into another application.
 
- Fax
 
- You cannot use this option with reports.
 
- Excel
 
- This option opens the Excel application and creates a new workbook containing the report.
 
- The following example shows a Customer Statistics report opened in Excel, after which a chart has been added:
  
 
- Html as attachment
 
- This option will place a file containing report in your Personal Desktop. You may need to close and re-open the Master Control panel to see the report there.
 
- You can only use this option in a multi-user system, where it can be useful when you need to produce a long report. You can print a report using this option, log off and leave the server to produce the report overnight, and the report will be waiting for you in your Personal Desktop the next day. 
 
- To open the report, highlight it in your Personal Desktop and choose 'Open Record' from the Master Control panel's Operations menu. The report will be shown in a new window in your browser.
 
- Pdf
 
- Choose this option to print a report as a PDF file on your hard disk.
If your database is in restricted mode, you will only be able to print a report using the Screen option.
There are also two check boxes at the bottom of each report specification window:
- Print Dialog
 
- If you want a print dialogue to appear when you send the report to a printer, check this box. You might do this if you want to print several copies of a report.
 
- Ignore Timeout Limit
 
- Please refer to the 'Parallel Reporting' section at the bottom of this page for details of this option.
Once you have entered the reporting criteria and have chosen a print destination, click [Run] to produce the report.
Defining Reports
For some reports in the Nominal Ledger module, you can redefine the contents and layout of the report. To do this, use the Report Settings setting in the Nominal Ledger.
Parallel Reporting
In multi-user systems, the server will give a higher priority to working with records (searching, opening, saving), and a lower priority to reporting. Despite this prioritisation, if some users in your system will frequently produce reports, the other users may find that performance suffers. You can use the Parallel Reporting options to attempt to optimise the performance for all users. The Single Thread option can be used with any server, while the Multi Thread option will allow you to take advantage of multiple cores and processors. These options can be found on the 'Performance' card of the Optional Features setting in the System module.

- Off
 
- The server will calculate a single report at a time, so reports will be produced in the order in which they were requested. Reflecting the higher priority given to working with records, the calculation of each report will be paused periodically to allow records to be read and saved.
 
- Single Thread
 
- The server can calculate a number of reports simultaneously. It does this by working on a particular report for a few moments, then working on a second report for a few moments, then on a third, before returning to the first. This will give a benefit when there is a long report queue that includes both short and heavy reports, as the short reports will be produced more quickly. The server will be able to start working on them more quickly, without always needing to wait until the earlier reports in the queue have been produced. This benefit by its very nature will be much reduced when there is a short report queue or no queue at all.
 
- By default, the server can work on up to five reports at once, but you can change this using the Report Slots field underneath the Parallel Reports options. The number of Report Slots can be between one and 80.
 
- If the users in your system will frequently produce many reports, you may find it beneficial to increase the number of Report Slots. If reports will be produced infrequently, you might consider reducing the number. Depending on the complexity of the reports in the queue, increasing the number may mean each individual report will be produced more slowly, so you may need to experiment to find the optimum setting for the typical report queue in your system.  
 
- Multi Thread
 
- The server will dedicate separate threads to reports. Each thread will be able to produce a separate report, allowing several reports to be produced simultaneously. When a report is requested, it will be placed in an overall report queue, to be assigned to the first thread that becomes available.
 By default, there can be up to five separate report threads. Again, you can change this using the Report Slots field. A good guideline is to set the number of Report Slots to twice the number of processor cores in the server. 
 
 Usually, you should only consider using this option if you have a multiple-core or multiple-processor server. 
 You will need to restart the server after changing the Parallel Reports options.
By default, the server will spend up to 300 seconds calculating each report. You can change this report time-out limit by entering a number of seconds in the Seconds a Report is allowed to Run before Timing out field in the Timed Operations setting in the Technics module. If a report takes longer than the report time-out limit, the following will happen, depending on the Parallel Reporting option:
- Off
 
- There is no report time-out limit if Parallel Reporting is Off, so every report will always be produced in its entirety.
 
- Single Thread
 
- The report calculation will be halted, and the incomplete report will be printed.
 
- Multi Thread
 
- The report calculation will be halted, and the incomplete report will not be printed.
When you produce a report, if you believe it will take longer than the time-out limit and you want it to be produced in its entirety, use the Ignore Timeout Limit option at the bottom of every report specification window.
If you are using the single- or multi-thread options, you can monitor the reports that the server is working on. To do this, produce a Report Status report from the User Settings module. As well as showing you the calculation times for each report being produced, this report also gives you the chance to cancel a particular report. To do this, click the [Cancel] text button next to the report name. If you are using the single-thread option, the incomplete report will be printed. You cannot use the Report Status report if Parallel Reporting is off. In this case, the Report Status will be placed in the report queue behind the other reports, which will be completed before calculation of the Report Status report begins. When it is produced, it will therefore be empty.
Massive Cache
Another way to improve reporting speed is to increase the size of the cache used by the HansaWorld Enterprise application. By default, this is 3.2 Mb. By increasing the size of this cache, you will improve the speed of operation because data that is in the cache can be accessed much more quickly than data on disk. Data in the cache is data that has already been used during the work session. In particular, the speed of importing will improve if you increase the cache size and, in many installations, the speed of reporting and processing records will improve as well. 
The optimum size of the cache will vary, depending on the server type, RAM size and operating system, and can only be established through experimentation. A good guideline, especially for Windows servers and for servers with smaller RAM sizes, is never to assign more than 40% of the machine's RAM size to the cache. If the cache is too large, the memory available for other tasks may not be enough. If the machine then runs out of memory, it will start using its hard disk as extra memory. This will cause it to slow down significantly and may also increase instability. If the server is a 32-bit machine, the maximum cache size is between 1 and 3.5 Gb, depending on machine and operating system. If the server is a 64-bit machine with a 64-bit capable operating system (Mac OS X or Linux) and a large amount of RAM and if you are using the 64-bit version of HansaWorld Enterprise, then the 40% guideline becomes less important. For example, if the server has 12 Gb RAM, you could assign up to 10 Gb to the cache.
You can increase the cache size using one of two methods:
- You can start the application on the server using the --db-cache parameter. For example:
 - ./HansaWorld --db-cache=1G
 starts the server application and sets the cache to 1 GB. You can set the cache size using K, M (not Mb) or G (not Gb). Make sure the parameter does not contain any spaces.
 The --db-cache parameter sets the cache size for the particular work session only. After quitting and restarting the server, the cache size will revert to the default.
 
 
- To set the cache size permanently, follow these steps:
 - In the Configuration setting in the System module, choose to use the Massive Cache feature using the option on the 'Technical' card:
  
 
- Enter the cache size in the Database Cache Size field on the 'Performance' card of the Optional Features setting. The cache size should be a number of kilobytes.
  
 
- Restart the server.
 
Individual Reports
Please click the links for details about the individual reports in the following modules: