Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-06-2014, 14: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, 05: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, 08: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, 08: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, 08: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, 09: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, 10: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, 10: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, 10: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, 11: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, 11: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, 13: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, 08: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


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Ecovacs presenta la gamma 2026: paviment...
Efficienza energetica fino a 2.000 volte...
Lenovo 360: il programma di canale dell'...
Appena 10.000 qubit per rompere la critt...
Analisi dei transistor durante il funzio...
Attacco informatico a Booking.com: espos...
A quattro mesi dal divieto dei social ne...
NVIDIA GeForce RTX 5060 e 5060 Ti: in ar...
Rebellions, Arm e SK Telecom, nuova alle...
Modernizzazione delle app: Red Hat OpenS...
Nel mirino di Google c'è il back ...
PRAGMATA in bundle con GeForce RTX 5000:...
Le novità MOVA per il 2026: robot e impi...
Windows, stop all'attivazione telefonica...
ASUS porta la serie TUF nel formato Mini...
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: 00:46.


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