The article below may help.

Manuel


----- Plagiarized Text Follows:  ---------->

Print Word Documents from an AS/400

by Herman Van der Staey
Article Information
Article ID: 6311

Pub: iSeries NEWS

Dept: Tech Corner

Date: July 01, 1999

You can use the AS/400's RUNRMTCMD command to print PC documents from your
AS/400. I wrote a Visual Basic (VB) 6.0 program, PRINTDOC.EXE, that prints
documents from a PC application, such as Microsoft Word or Excel, running on
a PC with Client Access for Windows 95/NT (V3R1M2 or higher) associated with
the program (Figure A). PRINTDOC.EXE accepts one parameter - the name of the
document you want to print.

For example, if PRINTDOC.EXE is in C:\PROG and Word document MYWORD.DOC is
in C:\DATA, you'd execute RUNRMTCMD as follows:


RUNRMTCMD CMD('C:\PROG\PRINTDOC.EXE +
               C:\DATA\MYWORD.DOC') +
          RMTLOCNAME('xxx.xxx.xxx.xxx'  *IP)+
          RMTUSER(pc user ID)               +
          RMTPWD('password')

(xxx.xxx.xxx.xxx is the IP address or host name of the target PC, pc user ID
is the user ID for the target PC, and password is the target PC user's
password). Because Windows NT passwords are case sensitive, you should place
single quotes around the password to preserve the case.

If you wanted to print an Excel worksheet, you'd specify a file with an .XLS
instead of a .DOC extension. Note that you must start the Client Access
Incoming Remote Command NT service or daemon program (on non-NT systems) on
the target PC to use RUNRMTCMD. (For more information about RUNRMTCMD and
the Incoming Remote Command service/daemon, see the IBM Redbook Inside
AS/400 Client Access, SG24-4748.)

PRINTDOC.EXE uses the Windows ShellExecute API to open or print the
Microsoft application file (.DOC or .XLS) without requiring the user to
specify the name of the application associated with the file. Note that
although PRINTDOC.EXE works with .DOC and .XLS files, it doesn't work for
all file types. For more information about the ShellExecute API, see
Microsoft Knowledge Base article Q170918 at http://support.micro
soft.com/support/kb/articles/q170/9/18.asp.

You can download a self-extracting zip file containing all the files needed
to install PRINTDOC.EXE from http://www.news400.com. After you decompress
the file, you can easily install PRINTDOC.EXE, including all needed dynamic
link library (DLL) files, using a SETUP.EXE program that you create with VB
6.0's Deployment Wizard.

Tip provided by Herman Van der Staey, systems engineer at Delcredere -
Ducroire, the Belgian Export Credit Agency, in Brussels, Belgium. Contact
him at h_vanderstaey@ondd.be.



Figure 1
------------


Attribute VB_Name = "Module1"
' PRINTDOC.EXE          version 1.03   1999/05/12
' ------------
'
' This program starts the application associated with
' a given document extension and prints the document
' in the background
'
' PRINTDOC.EXE accepts one parameter: the name of the document
' you want to print.
'
' Errors are written to the file ERRLOG.TXT


Option Explicit

Private Declare Function ShellExecute Lib "shell32.dll" Alias _
"ShellExecuteA" (ByVal hwnd As Long, ByVal lpszOp As _
String, ByVal lpszFile As String, ByVal lpszParams As String, _
ByVal lpszDir As String, ByVal FsShowCmd As Long) As Long

Private Declare Function GetDesktopWindow Lib "user32" () As Long

Const SW_SHOWNORMAL = 1

Const SE_ERR_FNF = 2&
Const SE_ERR_PNF = 3&
Const SE_ERR_ACCESSDENIED = 5&
Const SE_ERR_OOM = 8&
Const SE_ERR_DLLNOTFOUND = 32&
Const SE_ERR_SHARE = 26&
Const SE_ERR_ASSOCINCOMPLETE = 27&
Const SE_ERR_DDETIMEOUT = 28&
Const SE_ERR_DDEFAIL = 29&
Const SE_ERR_DDEBUSY = 30&
Const SE_ERR_NOASSOC = 31&
Const ERROR_BAD_FORMAT = 11&

Function prtDoc(DocName As String) As Long
    Dim Scr_hDC As Long
    Scr_hDC = GetDesktopWindow()
    prtDoc = ShellExecute(Scr_hDC, "print", DocName, _
    "", App.Path, SW_SHOWNORMAL)
End Function

Sub Main()

Dim r As Long, msg, logfile, logtext As String
Dim FileNumber As Integer

       r = prtDoc(Command$)

       If r <= 32 Then
          'There was an error
          Select Case r
             Case SE_ERR_FNF
               msg = "File not found"
             Case SE_ERR_PNF
               msg = "Path not found"
             Case SE_ERR_ACCESSDENIED
               msg = "Access denied"
             Case SE_ERR_OOM
               msg = "Out of memory"
             Case SE_ERR_DLLNOTFOUND
               msg = "DLL not found"
             Case SE_ERR_SHARE
               msg = "A sharing violation occurred"
             Case SE_ERR_ASSOCINCOMPLETE
               msg = "Incomplete or invalid file association"
             Case SE_ERR_DDETIMEOUT
               msg = "DDE Time out"
             Case SE_ERR_DDEFAIL
               msg = "DDE transaction failed"
             Case SE_ERR_DDEBUSY
               msg = "DDE busy"
             Case SE_ERR_NOASSOC
               msg = "No association for file extension"
             Case ERROR_BAD_FORMAT
               msg = "Invalid EXE file or error in EXE image"
             Case Else
               msg = "Unknown error"
          End Select

          ' Log the error message in file ERRLOG.TXT

          FileNumber = FreeFile     ' get unused file number
          logfile = App.Path + "\ERRLOG.TXT"
          Open logfile For Append Access Write As #FileNumber
          Print #FileNumber, Format(Now, "yyyy/mm/dd  hh:mm:ss"); _
                Spc(3); msg; Spc(3); Command$
          Close #FileNumber

       End If

End Sub


-----Original Message-----
From: Taylor, Mark W [mailto:MarkWTaylor@eaton.com]
Sent: Tuesday, September 10, 2002 2:44 PM
To: 'mapics-l@midrange.com'
Subject: Re: User Exit after Packing Slip?


As far as the Word document, I can't help you.
But I have some information for you on the User Exit at Pack List time.
The User Exit name is UMBSHP3R
If you look at the documentation for that user exit it will say that it
receives 4 parameters: Company Number, Header Type, Order Number, and
Shipment Number.... But it doesn't (as I had to learn the hard way)
The parms only contain the Company Number, and the Shipment Number. You have
to chain out to the Shipment file MBDDRES8 with the Company Number and
Shipment number to get to the Order Number.
Hopfully this will save you some trouble once you figure out the issue with
the Word document.

Mark Taylor
_______________________________________________
This is the MAPICS ERP System Discussion (MAPICS-L) mailing list
To post a message email: MAPICS-L@midrange.com
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/cgi-bin/listinfo/mapics-l
or email: MAPICS-L-request@midrange.com
Before posting, please take a moment to review the archives
at http://archive.midrange.com/mapics-l.


As an Amazon Associate we earn from qualifying purchases.

This thread ...


Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.