lineTranslateDialog (TAPI) (Compact 2013)

3/26/2014

This function displays an application-modal dialog box that enables the user to change the current location, adjust location and calling card parameters, and see the effect on a phone number about to be dialed.

Syntax

LONG lineTranslateDialog(
  HLINEAPP hLineApp, 
  DWORD dwDeviceID, 
  DWORD dwAPIVersion, 
  HWND hwndOwner, 
  LPCWSTR lpszAddressIn
);

Parameters

  • hLineApp
    [in] Application handle returned by the lineInitialize function. If you set hLineApp to NULL, this function fails and returns LINERR_INVALAPPHANDLE.
  • dwDeviceID
    [in] Device identifier for the line device upon which the call is intended to be dialed, so that variations in dialing procedures on different lines can be applied to the translation process.
  • dwAPIVersion
    [in] Highest version of TAPI supported by the application (not necessarily the value negotiated by the lineNegotiateAPIVersion function on the line device indicated by dwDeviceID).
  • hwndOwner
    [in] Handle to a window to which the dialog box is to be attached. Can be a NULL value to indicate that any window created during the function should have no owner window.
  • lpszAddressIn
    [in] Pointer to a null-terminated string that contains a phone number that is used, in the lower portion of the dialog box, to show the effect of the user's changes on the location parameters. The number must be in canonical format; if noncanonical, the phone number portion of the dialog box is not displayed. This pointer can be left NULL, in which case the phone number portion of the dialog box is not displayed. If the lpszAddressIn parameter contains a subaddress or name field, or additional addresses separated from the first address by ASCII CR and LF characters, only the first address is used in the dialog box.

Return Value

Zero indicates success. A negative error number indicates that an error occurred. The following table shows the return values for this function.

Value

Description

LINEERR_BADDEVICEID

The device id is incorrect.

LINEERR_INCOMPATIBLEAPIVERSION

The API version in incompatible.

LINEERR_INIFILECORRUPT

The INI file is corrupt.

LINEERR_INUSE

The dialog box is already displayed by another application

LINEERR_INVALADDRESS

The address provided is invalid.

LINEERR_INVALAPPHANDLE

The application handle is invalid.

LINEERR_INVALPARAM

The parameter is invalid.

LINEERR_INVALPOINTER

The pointer is invalid.

LINEERR_NODRIVER

The driver could not be found.

LINEERR_NOMEM

Not enough memory is available.

LINEERR_OPERATIONFAILED

The operation failed.

Remarks

LINEERR_INUSE is returned if the dialog box is already displayed by another application (cannot be open more than once). In these versions, TAPI brings the existing dialog box to the front, and the error indicates that any particulars related to the address passed in by the current application have not been handled, because that address was not processed by the function.

The application must call lineGetTranslateCaps after this function to obtain any changes the user made to the telephony address translation parameters, and call the lineTranslateAddress function to obtain a dialable string based on the user's new selections.

If any function related to address translation (for example, lineGetTranslateCaps or lineTranslateAddress) returns LINEERR_INIFILECORRUPT, the application should call lineTranslateDialog. The lineTranslateDialog function detects the errors and corrects them, and reports the action taken to the user. LINEERR_INIFILECORRUPT is returned the first time any of these functions are used after installation of Windows Embedded Compact, because the parameters are uninitialized (lineTranslateDialog takes care of initializing them, using the user-specified default country/region to select the default country/region code).

Requirements

Header

tapi.h

Library

TAPI32.dll

See Also

Reference

TAPI Line Device Functions
lineGetTranslateCaps
lineInitialize
lineNegotiateAPIVersion
lineTranslateAddress