Linker Error "unresolved external symbol" für Konsolenanwendung unter Embedded Visual C++ Ver. 4.2



  • Hallo Red-Baron,

    die Help-Seite von EVC sagt aus, dass "character based applications" mit der Linker Option /Subsystem:CONSOLE ausgeführt werden können; würde bedeuten, dass eine Konsolenanwendung geht.

    Könntest Du in Deiner PPC Version prüfen, ob ebenfalls diese Linker Option möglich ist ? Dann wäre ich auf dem Holzpfad.

    Ich versuche, ein Beispiel aus dem ASA UltraLite Tutorial nachzuvollziehen, welche folgenden Text für das main Programm angibt:

    int main() {
    DatabaseManager * dm;
    Connection * conn;
    Sqlca.Initialize();
    dm = ULInitDatabaseManager( Sqlca );
    conn = open_conn(dm, Sqlca);
    conn->Release();
    dm->Shutdown( Sqlca );
    Sqlca.Finalize();
    return 0;
    }
    

    Weil main und nicht winMain angegeben ist, gehe ich davon aus, dass eine Konsolenanwendung eingerichtet werden muss.

    Ich habe mich schon mehrmals an den Sybase Support gewandt, jedoch noch keine Antworten auf meine Fragen bekommen.

    ElectricProg



  • moin meister ...

    kann jetzt leider nicht, aber WINCE hat _NUR_ UniCode-Funktionen implementiert
    der Compiler wird Dir deshalb strlen compilieren aber in der std ist nur lstrlen definiert in tchar.h enthalten.

    zu main habe ich folgendes gefunden.

    Microsoft Specific —>

    In the Unicode programming model, you can define a wide-character version of the main function. Use wmain instead of main if you want to write portable code that adheres to the Unicode programming model.

    You declare formal parameters to wmain using a similar format to main. You can then pass wide-character arguments and, optionally, a wide-character environment pointer to the program. The argv and envp parameters to wmain are of type wchar_t*. For example:


    If your program uses a main function, the multibyte-character environment is created by the run-time library at program startup. A wide-character copy of the environment is created only when needed (for example, by a call to the _wgetenv or _wputenv functions). On the first call to _wputenv, or on the first call to _wgetenv if an MBCS environment already exists, a corresponding wide-character string environment is created and is then pointed to by the _wenviron global variable, which is a wide-character version of the _environ global variable. At this point, two copies of the environment (MBCS and Unicode) exist simultaneously and are maintained by the operating system throughout the life of the program.

    Similarly, if your program uses a wmain function, a wide-character environment is created at program startup and is pointed to by the _wenviron global variable. An MBCS (ASCII) environment is created on the first call to _putenv or getenv, and is pointed to by the _environ global variable.

    For more information on the MBCS environment, see Internationalization in the Run-Time Library Reference.

    END Microsoft Specific

    Hoffe das Hilft ...

    mfg
    RB



  • Hallo RB,

    Unicode habe ich schon berücksichtigt.
    Die anderen Anpassungen hatten leider keinen Erfolg.

    Ist die Analyse des EVC 4.2 generierten makefiles eine gute Idee ?

    ElectricProg



  • moin meister ...

    das Problem ist, ich kann nicht mal ein ConsolenProjekt anlegen ...
    Nur App und Lib und COM ...

    Geht der Code denn in ner normalen GUIApp zu verwenden ?

    Jedenfalls wird die falsche StartLib eingebunden, die Linker Option steht bei mir auch in der Doku ... aber auf meinem realen Gerät gibt es definitiv keine
    Console.

    Kann aber auch sein, das ich es nur eine Startlib gibt mit WinMain.

    mfg
    RB



  • Ich kann ebenfalls nur folgende Anwendungen im EVC 4.2 anlegen:

    - WCE APP
    - WCE ATL
    - WCE DLL
    - WCE MFC
    - WCE STATIC LIB

    Ich habe deshalb meine Anwendung als WCE APP deklariert. In dieser Umgebung läuft der Compiler durch, jedoch nicht der Linker.

    mfG

    ElectricProg



  • moin meister ...

    Eine WCE APP hat ja ne WinMain ... dieser Fehler müßte doch schon mal
    weg sein ...

    oder selbst wenn Du eine WCE APP mit dem Wizard erstellst kommt der LinkerError (?), dann weiß ich auch nicht weiter.

    mfg
    RB



  • Ich werde wohl aufgeben, dies zum Laufen zu bringen.

    ElectricProg



  • moin meister ...

    Wenn Du wenigstens es hinbekommst, eine einefache HelloWorld WIN32API Anwendung
    für PPC zu erstellen, würde ich mal versuchen den Code dort Schrittweise einzubauen.

    Vergiß doch mal die Console, was willst Du damit ?

    Was für eine Datenbank willst Du denn anzapfen ? Ich habe ne MySQL DB verwendet
    und setze dieses kostenlose Tool ein:
    http://www.kalpadrum.com/dalp/

    klappt wunderbar 🙂

    Oder wenn Du schon 3 Tage probiert hast, kannst Du auch nochmal einen Tag probieren das hier als UNICODE zu übersetzen, für WIN32 wirds jedenfalls
    unterstützt:

    http://www.sqlapi.com/

    mfg



  • Hallo Red Baron,

    - eine einfache HelloWorld WIN32API Anwendung für PPC zu erstellen ist kein Problem

    - ich habe vor, auf PocketPC unter Win CE Anwendungen zu entwickeln, welche die Verkabelungen von Luftfahrzeugen darstellen sollen; Später soll dann über eine kabellose Verbindung das Schematic auf eine monokulares Display entsprechend der Auswahl auf dem Pocket PC geschaltet werden.

    - die Verkabelungsdaten sollen zentral in einer Datenbank gehalten werden und dezentral auf diverse PocketPC über Internet portiert werden

    - als mögliche Lösungen preferiere ich derzeit:

    1. MS SQL Server zentral + CE SQL Server dezentral + Schnittstelle c++
    2. Sybase SQL Server zentral + CE UltraLite SQL Server dezentral + Schnittstelle c++ (mein Favorit aufgrund Preis/Leistungsverhältnis)

    Das Konsolenbeispiel liegt einem Sybase Ultralite Tutorial bei mit den lapidaren Worten: "nehmen Sie beliebigen C++ Compiler"

    MySQL als kommerzielle Variante in obiger Konfiguration habe ich noch nicht prüfen können.

    Ich suche aufgrund des Projektumfanges Enthusiasten, die mitmachen wollen.

    Wäre dies etwas für Dich ?

    ElectricProg



  • moin meister ...

    langsam:

    1. MS SQL Server zentral + CE SQL Server dezentral + Schnittstelle c++
    2. Sybase SQL Server zentral + CE UltraLite SQL Server dezentral + Schnittstelle c++ (mein Favorit aufgrund Preis/Leistungsverhältnis)

    hört sich kommerziell an 😞 (egal)

    Ich programmiere seit einiger Zeit für PPC aber nur API, mit MFC kenne ich mich
    nicht so recht aus.

    Da ich keine Testumgebung für obige SQL Server habe ist das schon mal schlecht,
    ich bin Privatmann 🙂

    DALP ist nur für nicht kommerzielle Projekte zugelassen, dürfte also rausfallen.

    Der Sinn einer solchen Anwendung ist mir nicht ganz klar, aber wenns Leute gibt die sowas brauchen ... bitte.

    Also wenn es ein paar kleinere Module Anfangs wären würde mich das schon mal
    interessieren, ich habe ebend bisher nur alleine, nie in Teams an einem Programm gearbeitet. Kann mich schlecht selbst einschätzen 😞

    mfg
    RB



  • Guten Morgen, Red-Baron,

    meine Gedanke ist ebenfalls, API zu nutzen.
    Testumgebungen für Sybase sind kostenfrei downloadbar bei Sybase.
    Sinn der Anwendung ist es, Informationen über die Verkabelungen direkt dort zu erhalten, wo sie benötigt werden. Derzeit existieren Schränke voll Papier, welche darauf warten, effektiv in elektronische Form umgesetzt zu werden.

    ich denke, wir sollten bei Interesse die weitere Diskussion per E-mail weiterführen, da der weitere Inhalt nicht in das Forum gehört.

    MfG

    ElectricProg



  • moin meister ...

    Also aus reinem Interesse müßte ich mir von Sybase den Server besorgen,
    mal von Arbeit aus mit DSL 🙂 - "hier Russland nur Modem" *gebrochen gesprochen* mit MochaPPP über SerialLink ne Netzwerkverbindung herstellen zum mobilen Gerät WinCE 3.0 bzw. PPC2000, was neueres habe ich net, egal.

    Jo und dann ...

    Also geht es "nur" darum "monokulares Display" (?) praktisch "Schaltpläne"
    darzustellen (in Gesamt- und Detailansicht ? ) ...

    Dazu fällt mir nur ein, es gab in meiner Ausbildung "Techniker Kommunikationstechnik/Datenverarbeitung" ein Programm, komme jetzt nicht mehr auf den Namen, wo über ein Script Schaltungen "programmiert" werden konnten und
    danach alle möglichen Simulationen durchgeführt werden konnten.

    Jedenfalls müßten die Pläne ja dann mal so vorliegen (oder ähnlich) ... ist parsen angesagt ?

    Unter der Bedingung, daß :
    - es kein Datum gibt bis wann sowas fertig zu sein hat
    - kommerzielle Nutzung erst Dritten in Aussicht gestellt wird nach Fertigstellung

    heißt also Entwicklung OHNE jegliche Androhung von Streß, rücke ich mal meine
    Mehltüte raus.

    martin.bauer.dd@web.de

    Ich habe einen gültigen Arbeitsvertrag, bei dem 40 Stunden/Woche gefordert
    werden, da bleiben also noch zwei freie Tage a 24h 🙂
    Ich denke Du verstehst ...

    mfg
    RB


Anmelden zum Antworten