Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Con la prima rete 5G Standalone attiva in Italia, WINDTRE compie un passo decisivo verso un modello di connettività intelligente che abilita scenari avanzati per imprese e pubbliche amministrazioni, trasformando la rete da infrastruttura a piattaforma per servizi a valore aggiunto
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro punta a diventare uno dei riferimenti assoluti nel segmento dei camera phone di fascia alta. Con un teleobiettivo Hasselblad da 200 MP, una batteria al silicio-carbonio da 7500 mAh e un display da 6,78 pollici con cornici ultra ridotte, il nuovo flagship non teme confronti con la concorrenza, e non solo nel comparto fotografico mobile. La dotazione tecnica include il processore MediaTek Dimensity 9500, certificazione IP69 e un sistema di ricarica rapida a 80W
DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-06-2014, 15:50   #1
Donbabbeo
Senior Member
 
L'Avatar di Donbabbeo
 
Iscritto dal: Jul 2006
Messaggi: 8152
[C C++]Dipendenze eseguibile che variano in base ad un'istruzione e l'atoi maledetta

Mi sto occupando del refactoring di un vecchissimo progetto legacy ed in questi giorni sto verificando le dipendenze che si porta dietro.

Armato di DependencyWalker e di uno degli innumerevoli eseguibili che compongono il progetto (uno stramaledetto gestionale scritto in un linguaggio C misto C++, pieno di incongruenze, multiple istruzioni sulla stessa riga, zero commenti, la peggior convenzione per i nomi mai concepita ed indentazioni completamente casuali), salta fuori che all'incirca dal 2009 in avanti è così:

Non sarebbe un grosso problema se non fosse per il fatto che prima del 2009 la situazione era questa:

E con mia immensa gioia devo accollarmi il compito di tornare alla vecchia situazione mantenendo però le modifiche fatte al codice nel frattempo.
Mi sono sorbito tutto il codice e confrontandolo con la vecchia versione file per file (non hanno mai usato alcuna forma di Version Control, mannaggia loro) ed ho rintracciato il problema.

Si tratta di una funzione in una libreria del progetto che al netto di tutta la fuffa inutile si può, con mio grande stupore, tradurre in:

Codice:
chain(str, pps)
	char *pps;
    char *str;
{
    int pp = 0;

	pp = atoi(pps);
	
	// ic sunt leones.
In pratica l'errore è generato dall'atoi.
Ma ancora più incredibile è che se io commento il rigo o al posto dell'atoi metto l'assegnazione diretta di un valore numerico tipo 0, 1 o 3, la libreria che contiene tale funzione compila bene, ma l'eseguibile a cui viene linkata la .lib restituisce i seguenti errori in compilazione:

Quote:
nafxcw.lib(wincore.obj) : error LNK2001: unresolved external symbol __imp__InitCommonControls@0
nafxcw.lib(wincore.obj) : error LNK2001: unresolved external symbol __imp__DragAcceptFiles@8
nafxcw.lib(appcore.obj) : error LNK2001: unresolved external symbol _ClosePrinter@4
nafxcw.lib(appcore.obj) : error LNK2001: unresolved external symbol _DocumentPropertiesA@24
nafxcw.lib(appcore.obj) : error LNK2001: unresolved external symbol _OpenPrinterA@12
nafxcw.lib(filecore.obj) : error LNK2001: unresolved external symbol __imp__SHGetFileInfoA@20
nafxcw.lib(filecore.obj) : error LNK2001: unresolved external symbol _GetFileTitleA@12
Tutto ciò rasenta il ridicolo se al contrario assegno un valore come 2, 4 o qualsiasi altro numero: in tal caso la libreria compila bene, compila bene l'eseguibile e mi ritrovo esattamente con le sole 4 dipendenze che sto agognando.

Non so più a che santo appellarmi, qualcuno sa indirizzarmi verso una soluzione?
__________________
"Quiquid Latine Dictum Sit, Altum Sonatur" 😐
Donbabbeo è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 06:56   #2
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Suggerimento 1: tieni duro! Ce la farai!
Suggerimento 2: rifiutati di credere ai fantasmi. Rifiutati di credere che sia l'atoi() a generare quel problema di link (anche perche' potresti riscriverla in 1 minuto, ma immagino che il problema di link resti).

Considera i due problemi separatamente. Anche se in apparenza sembrano correlati, fai finta che la correlazione non esista.

Capisco che per motivi di sintesi hai dovuto fare dei tagli ed il procedimento che hai seguito e' perfettamente logico.
Tuttavia quando succedono queste cose e' molto probabile che si sia perso qualcosa dietro strada, magari qualcosa a cui non hai dato peso.
Prova a pensare ad una seconda strada, perfettamente logica come la prima, che possa portarti ad isolare il problema, oppure fai il contrario: cerca di provocare il problema!


Domanda: hai parti di codice generato automaticamente? Ho avuto un problema simile con il codice di un cliente. Sono diventato matto prima di capire che c'erano dei fogli Excel che contenevano delle macro, e quelle macro generavano del codice a seconda dei valori inseriti nel foglio elettronico. Se queste cose non ti vengono dette, non le troverai mai!!

Buona fortuna
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 09:17   #3
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Non so se possa tornare utile, ma visto che ci siamo, puoi indicare quale compilatore/ide e sistema operativo stai utilizzando?
Gli errori che ricevi possono dipendere da 2 possibili cause:
1) nel processo di link non sono incluse le librerie che contengono tali funzioni;
2) nei sorgenti del tuo progetto non sono inclusi gli header relativi a tali librerie, o gli header inclusi sono relativi ad una versione diversa delle librerie effettivamente utilizzate in fase di link.
Prova a cercare gli errori su google, dovresti trovare sia le librerie che gli header da aggiungere.
Il fatto che mettendo un valore piuttosto che un altro il problema sparisca è abbastanza strano, le considerazioni di sottovento sono valide, comunque ti consiglierei di controllare il makefile cercando eventuali istruzioni che non siano compilazione/linking.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 09:34   #4
Donbabbeo
Senior Member
 
L'Avatar di Donbabbeo
 
Iscritto dal: Jul 2006
Messaggi: 8152
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Suggerimento 1: tieni duro! Ce la farai!
Suggerimento 2: rifiutati di credere ai fantasmi. Rifiutati di credere che sia l'atoi() a generare quel problema di link (anche perche' potresti riscriverla in 1 minuto, ma immagino che il problema di link resti).
Grazie per l'incoraggiamento

Ovviamente sono consapevole che l'atoi non ha colpe, la prima cosa che ho fatto è stata creare una funzione ad hoc per rimpiazzarla (sia un atoi fatto in casa che una funzione stupida che ritorni direttamente un intero) e l'errore permane.

Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Non so se possa tornare utile, ma visto che ci siamo, puoi indicare quale compilatore/ide e sistema operativo stai utilizzando?
Gli errori che ricevi possono dipendere da 2 possibili cause:
1) nel processo di link non sono incluse le librerie che contengono tali funzioni;
2) nei sorgenti del tuo progetto non sono inclusi gli header relativi a tali librerie, o gli header inclusi sono relativi ad una versione diversa delle librerie effettivamente utilizzate in fase di link.
Prova a cercare gli errori su google, dovresti trovare sia le librerie che gli header da aggiungere.
Il fatto che mettendo un valore piuttosto che un altro il problema sparisca è abbastanza strano, le considerazioni di sottovento sono valide, comunque ti consiglierei di controllare il makefile cercando eventuali istruzioni che non siano compilazione/linking.
Sto usando Visual Studio C++ 6.0 su Windows XP in macchina virtuale (purtroppo è un programma legacy e non gira su altre versioni di VC++ )

Capisco che la causa principale sembra essere un problema di linking, ciò che trovo assurdo è che basta commentare la chiamata alla funzione chain o cambiare l'istruzione con l'atoi per far compilare senza problemi...

Speriamo di riuscire a svelare l'arcano
__________________
"Quiquid Latine Dictum Sit, Altum Sonatur" 😐
Donbabbeo è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 09:44   #5
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Ah-ehm: vogliate perdonare la mia ignoranza, ma il seguente codice:
Codice:
chain(str, pps)
	char *pps;
    char *str;
{
non ha qualcosa di ambiguo?
Premetto che non ho mai programmato in C sotto Visual Studio, però il codice sopra riportato mi sembra che si discosti parecchio dal C standard:
1) manca il tipo di dato restituito dalla funzione (sarà void? Ci vuole comunque);
2) le variabili locali sono state dichiarate prima dalla parentesi graffa?!
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 10:52   #6
van9
Member
 
Iscritto dal: Nov 2012
Messaggi: 126
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Ah-ehm: vogliate perdonare la mia ignoranza, ma il seguente codice:
Codice:
chain(str, pps)
	char *pps;
    char *str;
{
non ha qualcosa di ambiguo?
Premetto che non ho mai programmato in C sotto Visual Studio, però il codice sopra riportato mi sembra che si discosti parecchio dal C standard:
1) manca il tipo di dato restituito dalla funzione (sarà void? Ci vuole comunque);
2) le variabili locali sono state dichiarate prima dalla parentesi graffa?!
E' C pre-ANSI. Di default si ritornava un int e quello era il modo corretto di dichiarare i parametri formali (fuori dal corpo della function).
van9 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 11:03   #7
Donbabbeo
Senior Member
 
L'Avatar di Donbabbeo
 
Iscritto dal: Jul 2006
Messaggi: 8152
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Ah-ehm: vogliate perdonare la mia ignoranza, ma il seguente codice:
Codice:
chain(str, pps)
	char *pps;
    char *str;
{
non ha qualcosa di ambiguo?
Premetto che non ho mai programmato in C sotto Visual Studio, però il codice sopra riportato mi sembra che si discosti parecchio dal C standard:
1) manca il tipo di dato restituito dalla funzione (sarà void? Ci vuole comunque);
2) le variabili locali sono state dichiarate prima dalla parentesi graffa?!
Si tratta di un vecchissimo codice legacy che usa ancora la notazione old-style per le dichiarazioni dei parametri e non la notazione a prototipo diventata lo standard de facto.
Aggiungo inoltre che il progetto è praticamente privo di files di intestazione, ogni funzione aggiunta viene automaticamente riconosciuta in tutto il codice (buttando fuori decine di warning, sarà per questo che li tengono disattivati? )

Non parlarmene, non faccio che combattere con gli altri per far adottare uno stile di programmazione sano invece di sto schifo di boiate. Fortuna che il 90% del tempo programmo applicazioni standalone di contorno a questo minestrone di codice.
__________________
"Quiquid Latine Dictum Sit, Altum Sonatur" 😐
Donbabbeo è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 11:23   #8
vbextreme
Member
 
L'Avatar di vbextreme
 
Iscritto dal: Dec 2013
Messaggi: 90
posta esattamente tutta la funzione incrimitata e la sua chiamata.
con tre righe e senza sfera di cristallo è impossibile aiutarti.
__________________
Easy framework per il linguaggio C.
vbextreme hack your life
vbextreme è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 11:26   #9
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
E forse è proprio questo l'errore. Quando il compilatore non trova una chiamata ad una funzione non definita (né prototipata) genera un warning e crea automaticamente un prototipo sulla base dei parametri utilizzati nella chiamata stessa. Tale prototipo potrebbe non essere accurato e quindi potrebbe non coincidere con la reale definizione della funzione, e pertanto in fase di link la funzione potrebbe non essere trovata: il nome effettivo della funzione infatti viene costruito concatenando al nome definito dall'utente la stringa "@n", dove n se non ricordo male è la lunghezza in byte dei parametri passati (da cui i messaggi es. __imp__DragAcceptFiles@8).
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2014, 12:53   #10
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
E forse è proprio questo l'errore. Quando il compilatore non trova una chiamata ad una funzione non definita (né prototipata) genera un warning e crea automaticamente un prototipo sulla base dei parametri utilizzati nella chiamata stessa. Tale prototipo potrebbe non essere accurato e quindi potrebbe non coincidere con la reale definizione della funzione, e pertanto in fase di link la funzione potrebbe non essere trovata: il nome effettivo della funzione infatti viene costruito concatenando al nome definito dall'utente la stringa "@n", dove n se non ricordo male è la lunghezza in byte dei parametri passati (da cui i messaggi es. __imp__DragAcceptFiles@8).
Sembra probabile anche a me.
Ipotesi di quel che succede

* le funzioni che non riesce a linkare sono state utilizzate senza includere le intestazioni della libreria di sistema.

* il compilatore usa una dichiarazione un po' diversa e si aspetta che tu gliele implementi

* aggiungendo atoi, per caso includi le librerie che ti servono e per culo vanno bene (puo' succedere se cambia solo il tipo di ritorno o non usi alcuni argomenti)

Il mio suggerimento e' di cercare dove vengono usate le funzioni che non vengono trovate e verificare se sono stati aggiunti gli include di sistema
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 27-06-2014, 12:51   #11
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Iscritto!
Questo problema vince a mani basse il premio "code horror" del semestre
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 27-06-2014, 14:07   #12
Donbabbeo
Senior Member
 
L'Avatar di Donbabbeo
 
Iscritto dal: Jul 2006
Messaggi: 8152
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Iscritto!
Questo problema vince a mani basse il premio "code horror" del semestre


Per il momento mi sono arreso, è una vita che spingo per fare un refactoring come dio comanda ma qui si continua a mettere pezze su pezze... Mi stupisco che dopo 30 anni ancora funziona più o meno bene...
__________________
"Quiquid Latine Dictum Sit, Altum Sonatur" 😐
Donbabbeo è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2014, 09:20   #13
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Quote:
Originariamente inviato da Donbabbeo Guarda i messaggi


Per il momento mi sono arreso, è una vita che spingo per fare un refactoring come dio comanda ma qui si continua a mettere pezze su pezze... Mi stupisco che dopo 30 anni ancora funziona più o meno bene...
Ricorda, come dice "Lello": <<<chi parte sa da che cosa fugge, ma non sa che cosa cerca!>>
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi Wind Tre 'accende' il 5G Standalone in Italia: s...
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh OPPO Find X9 Pro: il camera phone con teleobiett...
DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
Scope elettriche al minimo storico su Am...
Blue Jay e Project Eluna: robotica e AI ...
Scede a 949€ il Samsung Galaxy S25 Ultra...
Blue Yeti Nano in super offerta su Amazo...
Netflix sta preparando un'offerta per Wa...
Prezzo impossibile, è sceso ancor...
Torna il migliore dei mini PC economici:...
USA, via libera all'uso di plutonio mili...
Tutte le tappe verso l'euro digitale sec...
Nikon Comedy Wildlife 2025: le immagini ...
Il telescopio spaziale James Webb ha cat...
Tesla Roadster? Il re di ChatGPT chiede ...
Pier Giorgio Furcas raddoppia: Vice Dire...
Novità PagoPA: con Klarna:pagamen...
Per il 2026 la Cina eseguirà una ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 10:39.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v