[Ace-users] [tao-users] Broken ACE_DEBUG messages when using TAO compiled with ACE_USES_WCHAR

Johnny Willemsen jwillemsen at remedy.nl
Wed Nov 7 04:18:14 CST 2007


Hi,

Thanks for using the PRF form. The combination of TAO with ACE_USES_WCHAR is
not stable, it is experimental and not tested at all. If you have patches to
improve this support, please store them in bugzilla. We are looking for a
sponsor to complete the support for TAO with ACE_USES_WCHAR enabled.

Regards,

Johnny Willemsen
Remedy IT
Postbus 101
2650 AC  Berkel en Rodenrijs
The Netherlands
www.theaceorb.nl / www.remedy.nl  

*** Integrated compile and test statistics see
http://scoreboard.theaceorb.nl ***
*** Commercial service and support for ACE/TAO/CIAO             ***
*** See http://www.theaceorb.nl/en/support.html                 ***

 

"Karl-Heinz" <wind at itq.de> wrote in message
news:<1194427773.144244.228070 at k79g2000hse.googlegroups.com>...

    ACE VERSION: 5.5.8

    HOST MACHINE and OPERATING SYSTEM:
        PC, Windows XP, VC8

    TARGET MACHINE and OPERATING SYSTEM, if different from HOST:
    COMPILER NAME AND VERSION (AND PATCHLEVEL):

    THE $ACE_ROOT/ace/config.h FILE: config-win32.h, ACE_USES_WCHAR,
    _USE_32BIT_TIME_T 1

    THE $ACE_ROOT/include/makeinclude/platform_macros.GNU FILE:

    CONTENTS OF $ACE_ROOT/bin/MakeProjectCreator/config/
default.features
    (used by MPC when you generate your own makefiles): MFC=0

    AREA/CLASS/EXAMPLE AFFECTED:
    TAO/IIOP_Connector, TAO/IIOP_Connection_Handler, ACE_INET_Addr

    DOES THE PROBLEM AFFECT:
        COMPILATION? no
        LINKING? no
        EXECUTION? no
        OTHER (please specify)? unreadable trace output

    SYNOPSIS:
    ACE_DEBUG messages contain unreadable information (e.g.
hostaddress)

    DESCRIPTION:
    When compiling TAO with ACE_USES_WCHAR some ACE_DEBUG messages
contain
    unreadable information:

    TAO (3488|4020) Loaded default protocol <??????>
    TAO (3488|4020) created new ORB <>
    TAO (3488|4020) - Transport_Cache_Manager::fill_set_i,
current_size = 0, cache_maximum = 512
    TAO (3488|4020) - IIOP_Connector::begin_connection, to
<127.0.0.1:12345> which should block
    TAO (3488|4020) - IIOP_Connection_Handler::open, The local addr is
<????1?8??????????:1309>
    TAO (3488|4020) - IIOP_Connection_Handler::open, IIOP connection
to peer <127.0.0.1:12345> on 36940
    TAO (3488|4020) - IIOP_Connector::make_connection, new connected
connection to <127.0.0.1:12345> on Transport[36940]

    Explanation: sometimes a character pointer (const char*) is passed
to the
    ACE_DEBUG macro which expects const wchar_t*.


    REPEAT BY:
    Compiler using ACE_USES_WCHAR, TAO_debug_level=10, run ORB, watch
output

    SAMPLE FIX/WORKAROUND:
    1. ACE_INET_Addr should support ACE_TEXT instead of const char
    2. Use ACE_INET_Addr::addr_to_string to convert string before
passing it to ACE_DEBUG


Hi,
I get broken debug messages in my output window when running TAO (see
above). The problem arises when
TAO is compiled with option ACE_USES_WCHAR. Is it possible that
ACE_DEBUG crashes my system when
searching for the wchar-string end (00 00)... I fear that this could
lead to unpredictable access violations.
Best regards
Karl-Heinz Wind

----------



More information about the Ace-users mailing list