02
Thu, Jan
0 New Articles

Barcoding with DDS

Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

Brief: Writing barcoding applications used to be a job for only the most skilled programmers. Enhancements in printer technology, advanced function printing and DDS keyword support bring this capability within everyone's reach.

Creating a barcode application on the AS/400 should be as simple as writing a report or running a Query. But until the introduction of advanced function printing and the Intelligent Printer Data Stream (IPDS) printers, things were not so easy. (See "Barcode Printing on the AS/400," MC, January 1994.)

There are basically two ways to create barcode applications quickly. One way is to use a special DDS keyword in an externally defined printer file to be used in an application. The other way is to use IBM's Advanced Function Printing Utilities/400. Both methods use advanced function printing to print text and images on a printer.

The path you choose depends upon a number of factors: the availability of tools, the strategic value of the application, the maintenance profile and standards of the applications your shop creates, how urgently you need the application and-finally-your own desire to dig into the technical requirements.

You might decide to write an RPG program that takes advantage of DDS keywords developed specifically for advanced function printing and-in particular- barcode printing. For the majority of AS/400 programmers, DDS represents the most straightforward means of providing barcode capabilities: the complete power of IPDS printers and advanced function printing can be readily integrated into existing applications, and the learning curve is slight.

The other choice is to use Advanced Function Printing Utilities/400's Print Format Definition, which offers you a fast means of creating a simple application: the learning curve is very easy but this method may not fit into your environment.

The best methodology depends upon your environment and your application needs. This article shows you the technique of using an RPG program and an externally defined printer file. The Advanced Function Printing Utilities/400 technique will be covered in an upcoming article.

Requirements

You must have an IPDS printer available to you for this sample program. IPDS is the key that makes barcode applications easy to create on the AS/400.

The following IBM printers have IPDS capabilities:

o IBM 38XX series printers which include 3812 defined as AFP(*YES), 3816, 3820, 3825, 3827, 3831 and 3835.

o IBM 4XXX series printers which include 4028, 4224, 4230 and 4234.

If you're using any of these printers, you should verify that it will support the particular barcodes you need to print. For instance, my shop's IBM 3812 printer does not support POSTNET or Code 128 barcodes. The system won't inform you of the limitations of the printer to which you're sending your output. You need to obtain some printer specifications to learn what your particular machine supports. Printers attached through PC Support cannot print barcodes using advanced function printing even though the printer itself may be capable. However, some printers attached through PC Support can print barcodes using other methods. (Look for an article on this topic in an upcoming issue.)

The Sample Application

Our sample application is very simple: we'll create a report which prints a vendor master name and address list. Instead of printing the vendor number field in the usual numeric representation, we'll print it as a Code 3-of-9 barcode. A sample label is shown in 1.

Our sample application is very simple: we'll create a report which prints a vendor master name and address list. Instead of printing the vendor number field in the usual numeric representation, we'll print it as a Code 3-of-9 barcode. A sample label is shown in Figure 1.

A preliminary step to creating the report is to create a vendor master file- the DDS is shown in 2. The RPG program (3) to print our report is very simple; all the barcode- specific coding is defined in the DDS for the printer file (4). We simply open the file, read a record and write out the print file record.

A preliminary step to creating the report is to create a vendor master file- the DDS is shown in Figure 2. The RPG program (Figure 3) to print our report is very simple; all the barcode- specific coding is defined in the DDS for the printer file (Figure 4). We simply open the file, read a record and write out the print file record.

The DDS in this example utilizes the built-in row and column orientation to position the barcode. However, if we were working with an application requiring exceptionally small tolerances for the placement of the barcode (such as POSTNET applications on letters or labels), we could place the code at specific locations using the POSITION keyword instead. (POSITION allows you to identify the exact location of a barcode, image or graphic in increments of inches or centimeters.)

There are some specific requirements for barcode output. For example, the database field for vendor number (VNDNBR) is defined as a numeric field, but the VNDNBA field in our printer file must be alphabetic. The reason for this requirement is that if a barcode type allows alphabetic characterization, the DDS field referencing the barcode keyword must match those characteristics. Code 3-of-9, used in our example, allows alphabetic characterization.

Secondary parameters of the BARCODE keyword must also be specified to obtain the desired results. The format for the BARCODE keyword is shown in 5. We need only a few parameters for our sample application, but we'll review all the available options.

Secondary parameters of the BARCODE keyword must also be specified to obtain the desired results. The format for the BARCODE keyword is shown in Figure 5. We need only a few parameters for our sample application, but we'll review all the available options.

In our sample application, we're specifying a Code 3-of-9 barcode, with a height of two lines. No human-readable representation of the code will appear on the printout. And we'll use a check-digit of hex 02 to help us verify the reading of the barcode by our scanners. Refer to 4 for the DDS which defines these specifications.

In our sample application, we're specifying a Code 3-of-9 barcode, with a height of two lines. No human-readable representation of the code will appear on the printout. And we'll use a check-digit of hex 02 to help us verify the reading of the barcode by our scanners. Refer to Figure 4 for the DDS which defines these specifications.

The first two parameters specify the barcode type and the height. The DDS BARCODE keyword supports 16 different barcode types (see 6).

The first two parameters specify the barcode type and the height. The DDS BARCODE keyword supports 16 different barcode types (see Figure 6).

The HEIGHT parameter represents the number of lines which you want the barcode to consume. In our example, we specified a height of two lines.

The next parameter is optional and defines the orientation of the barcode- horizontal (*HRZ) or vertical (*VRT).

The *NOHRI parameter prevents the human-readable interpretation of the code from printing. The default value of *HRI causes the interpretation to be printed along the bottom of the barcode and *HRITOP prints it along the top.

When printing a Code 3-of-9 barcode, you can specify *AST or *NOAST as an optional parameter. *AST only affects the human-readable interpretation (if one is requested), not the barcode itself. Specifying *AST forces a single asterisk to print on either side of the human-readable interpretation. However, these asterisks are not translated into the barcode. The default of *NOAST suppresses the printing of these asterisks. In either case, the barcode itself looks the same.

The check-digit (hex 02) parameter identifies the check-digit type, which can be any one-character hexadecimal value other than FF. Check-digit scanning-if supported by your barcode reader-places an extra digit within the barcode as a means of validating a barcode. In such a validation scheme, the characters of the barcode are internally summed by the reader and compared to the check digit. If they match, the barcode is considered valid. Otherwise, the barcode is rejected automatically by the reader.

*WIDTH specifies the width (in inches) of the narrow bars of the barcode. The valid values are .007 through .208.

*RATIO specifies the ratio of wide bars to the narrow bars. The valid values are 2.00 through 3.00. For example, a value of 2.00 specifies that the wide bars should be twice the size of the narrow bars.

Advanced Function Printing Makes It Easy

Whichever means you use to create your barcode application-either through DDS or Advanced Function Printing Utilities/400-advanced function printing provides you with adequate tools and a good maintenance profile. No longer are you required to translate printer control codes into hexadecimal encapsulations. IPDS printers and advanced function printing provide you with an architecture which will support your applications without laborious translation. While you are still required to research the capabilities of the IPDS printer you're using, you don't have to "get down and dirty" to get the application to work.

Best of all, as your printers change-through upgrades or turnover-your barcode application will remain viable. And if your shop develops a need to print a different type of barcode, the changes to your application will be slight. Overall, the DDS keywords and IPDS printers offer us a good method to meet the printing demands of our users.

T.M. Stockwell is an associate technical editor for Midrange Computing.

REFERENCE Data Description Specification Reference (SC41-9620, CD-ROM QBKA7402).


Barcoding with DDS

Figure 2 The XTS001PF Physical File

 *============================================================ * To compile: * * CRTPF FILE(XXX/XTS001PF) SRCFILE(XXX/QDDSSRC) * *============================================================ *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+.. A R VNDMST A VNDNBR 5P 0 A NAME 25A A ADDR1 25A A CITY 15A A STATE 2A A ZIPCD 5P 0 A VNDSTS 76A *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+.. 
Barcoding with DDS

Figure 3 The XTS001RG RPG Program

 *============================================================ * To compile: * * CRTRPGPGM PGM(XXX/XTS001RG) SRCFILE(XXX/QRPGSRC) * *============================================================ *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+.. FXTS001PFIF E DISK FXTS001P1O E PRINTER C READ XTS001PF 99 C *IN99 DOWEQ*OFF C MOVE VNDNBR VNDNBA C WRITELABEL C READ XTS001PF 99 C ENDDO C MOVE *ON *INLR *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+.. 
Barcoding with DDS

Figure 4 The XTS001P1 Printer File

 *============================================================ * To compile: * * CRTPRTF FILE(XXX/XTS001P1) SRCFILE(XXX/QDDSSRC) + * DEVTYPE(*AFPDS) * *============================================================ *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+.. A R LABEL A VNDNBA 5A 1 1BARCODE(CODE3OF9 2 *NOHRI - A *AST X'02') A NAME 25A 5 1 A ADDR1 25A 6 1 A CITY 15A 7 1 A STATE 2A 7 17 A ZIPCD 5 0 8 1 
Barcoding with DDS

Figure 5 The Format of the BARCODE Keyword

 BARCODE(bar-code-id [height] [[*HRZ || *VRT [*HRI || *HRITOP || *NOHR [*AST || *NOAST [check-digit] [*WIDTH value] [*RATIO value]]) 
Barcoding with DDS

Figure 6 DDS Supported Barcodes

 Barcode ID Data Type Field Length MSI signed numeric 1 - 31 UPCA signed numeric 11 UPCE signed numeric 10 UPC2 signed numeric 2 UPC5 signed numeric 5 EAN8 signed numeric 7 EAN13 signed numeric 12 EAN2 signed numeric 2 EAN5 signed numeric 5 CODEABAR character 1 - 50 CODE128 character 1 - 50 CODE3OF9 character 1 - 50 INTERL2OF5 signed numeric 1 - 31 INDUST2OF5 signed numeric 1 - 31 MATRIX2OF5 signed numeric 1 - 31 POSTNET signed numeric 1 - 31 
BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$

Book Reviews

Resource Center

  • SB Profound WC 5536 Have you been wondering about Node.js? Our free Node.js Webinar Series takes you from total beginner to creating a fully-functional IBM i Node.js business application. You can find Part 1 here. In Part 2 of our free Node.js Webinar Series, Brian May teaches you the different tooling options available for writing code, debugging, and using Git for version control. Brian will briefly discuss the different tools available, and demonstrate his preferred setup for Node development on IBM i or any platform. Attend this webinar to learn:

  • SB Profound WP 5539More than ever, there is a demand for IT to deliver innovation. Your IBM i has been an essential part of your business operations for years. However, your organization may struggle to maintain the current system and implement new projects. The thousands of customers we've worked with and surveyed state that expectations regarding the digital footprint and vision of the company are not aligned with the current IT environment.

  • SB HelpSystems ROBOT Generic IBM announced the E1080 servers using the latest Power10 processor in September 2021. The most powerful processor from IBM to date, Power10 is designed to handle the demands of doing business in today’s high-tech atmosphere, including running cloud applications, supporting big data, and managing AI workloads. But what does Power10 mean for your data center? In this recorded webinar, IBMers Dan Sundt and Dylan Boday join IBM Power Champion Tom Huntington for a discussion on why Power10 technology is the right strategic investment if you run IBM i, AIX, or Linux. In this action-packed hour, Tom will share trends from the IBM i and AIX user communities while Dan and Dylan dive into the tech specs for key hardware, including:

  • Magic MarkTRY the one package that solves all your document design and printing challenges on all your platforms. Produce bar code labels, electronic forms, ad hoc reports, and RFID tags – without programming! MarkMagic is the only document design and print solution that combines report writing, WYSIWYG label and forms design, and conditional printing in one integrated product. Make sure your data survives when catastrophe hits. Request your trial now!  Request Now.

  • SB HelpSystems ROBOT GenericForms of ransomware has been around for over 30 years, and with more and more organizations suffering attacks each year, it continues to endure. What has made ransomware such a durable threat and what is the best way to combat it? In order to prevent ransomware, organizations must first understand how it works.

  • SB HelpSystems ROBOT GenericIT security is a top priority for businesses around the world, but most IBM i pros don’t know where to begin—and most cybersecurity experts don’t know IBM i. In this session, Robin Tatam explores the business impact of lax IBM i security, the top vulnerabilities putting IBM i at risk, and the steps you can take to protect your organization. If you’re looking to avoid unexpected downtime or corrupted data, you don’t want to miss this session.

  • SB HelpSystems ROBOT GenericCan you trust all of your users all of the time? A typical end user receives 16 malicious emails each month, but only 17 percent of these phishing campaigns are reported to IT. Once an attack is underway, most organizations won’t discover the breach until six months later. A staggering amount of damage can occur in that time. Despite these risks, 93 percent of organizations are leaving their IBM i systems vulnerable to cybercrime. In this on-demand webinar, IBM i security experts Robin Tatam and Sandi Moore will reveal:

  • FORTRA Disaster protection is vital to every business. Yet, it often consists of patched together procedures that are prone to error. From automatic backups to data encryption to media management, Robot automates the routine (yet often complex) tasks of iSeries backup and recovery, saving you time and money and making the process safer and more reliable. Automate your backups with the Robot Backup and Recovery Solution. Key features include:

  • FORTRAManaging messages on your IBM i can be more than a full-time job if you have to do it manually. Messages need a response and resources must be monitored—often over multiple systems and across platforms. How can you be sure you won’t miss important system events? Automate your message center with the Robot Message Management Solution. Key features include:

  • FORTRAThe thought of printing, distributing, and storing iSeries reports manually may reduce you to tears. Paper and labor costs associated with report generation can spiral out of control. Mountains of paper threaten to swamp your files. Robot automates report bursting, distribution, bundling, and archiving, and offers secure, selective online report viewing. Manage your reports with the Robot Report Management Solution. Key features include:

  • FORTRAFor over 30 years, Robot has been a leader in systems management for IBM i. With batch job creation and scheduling at its core, the Robot Job Scheduling Solution reduces the opportunity for human error and helps you maintain service levels, automating even the biggest, most complex runbooks. Manage your job schedule with the Robot Job Scheduling Solution. Key features include:

  • LANSA Business users want new applications now. Market and regulatory pressures require faster application updates and delivery into production. Your IBM i developers may be approaching retirement, and you see no sure way to fill their positions with experienced developers. In addition, you may be caught between maintaining your existing applications and the uncertainty of moving to something new.

  • LANSAWhen it comes to creating your business applications, there are hundreds of coding platforms and programming languages to choose from. These options range from very complex traditional programming languages to Low-Code platforms where sometimes no traditional coding experience is needed. Download our whitepaper, The Power of Writing Code in a Low-Code Solution, and:

  • LANSASupply Chain is becoming increasingly complex and unpredictable. From raw materials for manufacturing to food supply chains, the journey from source to production to delivery to consumers is marred with inefficiencies, manual processes, shortages, recalls, counterfeits, and scandals. In this webinar, we discuss how:

  • The MC Resource Centers bring you the widest selection of white papers, trial software, and on-demand webcasts for you to choose from. >> Review the list of White Papers, Trial Software or On-Demand Webcast at the MC Press Resource Center. >> Add the items to yru Cart and complet he checkout process and submit

  • Profound Logic Have you been wondering about Node.js? Our free Node.js Webinar Series takes you from total beginner to creating a fully-functional IBM i Node.js business application.

  • SB Profound WC 5536Join us for this hour-long webcast that will explore:

  • Fortra IT managers hoping to find new IBM i talent are discovering that the pool of experienced RPG programmers and operators or administrators with intimate knowledge of the operating system and the applications that run on it is small. This begs the question: How will you manage the platform that supports such a big part of your business? This guide offers strategies and software suggestions to help you plan IT staffing and resources and smooth the transition after your AS/400 talent retires. Read on to learn: