Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Al Museo Alfa Romeo di Arese, Nutanix ha riunito clienti, partner ed esperti per .Next On Tour Italia e per mostrare come l’infrastruttura hybrid multicloud possa diventare il fondamento dell’innovazione, con una piattaforma capace di unificare applicazioni tradizionali, moderne architetture cloud-native e nuovi scenari basati sull’intelligenza artificiale
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti
Il Lenovo LOQ 15i Gen 10 (15IRX10) offre prestazioni convincenti grazie al Core i7-13650HX e alla RTX 5060 Laptop a 100W, mantenendo un prezzo competitivo tra 1100 e 1300 euro. Costruzione solida, buon display e ampia espandibilità lo rendono una scelta equilibrata per chi cerca un notebook gaming accessibile ma moderno.
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Abbiamo giocato a lungo a Battlefield 6, abbiamo provato tutte le modalità multiplayer, Redsec, e le numerose personalizzazioni. In sintesi, ci siamo concentrati su ogni aspetto del titolo per comprendere al meglio uno degli FPS più ambiziosi della storia dei videogiochi e, dopo quasi due mesi, abbiamo tirato le somme. In questo articolo, condividiamo con voi tutto ciò che è Battlefield 6, un gioco che, a nostro avviso, rappresenta esattamente ciò che questo genere attendeva da tempo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-04-2011, 10:27   #1
Duchamp
Member
 
L'Avatar di Duchamp
 
Iscritto dal: Apr 2010
Messaggi: 67
[C][linux] shared libraries facoltative a runtime

Buongiorno a tutti; sto testando un po' la questione Linux e sono arrivato a capire quanto segue: se nel mio programma faccio uso di una certa libreria linkata in modo dinamico e poi passo questo programma ad un amico, lui dovrà naturalmente possedere la libreria per poter avviare il software.

A me però piacerebbe fare un passo indietro e valutare la presenza della libreria a runtime: il programma parte a prescindere, se la libreria esiste uso le funzionalità che offre, altrimenti disabilito le feature che la riguardano.

Secondo voi questo è possibile o bisogna per forza compilare da zero? Oppure creare due binari del programma, uno con le funzionalità della lib e uno senza?
Oppure distribuire, insieme ai binari, le librerie più esotiche che potrebbero non essere installate di default?

Vi ringrazio in anticipo per qualsiasi delucidazione vogliate darmi
Duchamp è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 11:19   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12889
Se non ricordo male c'è la funzione dlopen() che fa al caso tuo, dagli un'occhiata.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 13:30   #3
Duchamp
Member
 
L'Avatar di Duchamp
 
Iscritto dal: Apr 2010
Messaggi: 67
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Se non ricordo male c'è la funzione dlopen() che fa al caso tuo, dagli un'occhiata.

Ciao WarDuck, non conoscevo dlopen() ma ho già inutito qualche problema - correggimi se sbaglio: dovrei usare il suo handle interno per "chiamare" le funzioni presenti nella libreria e questo richiederebbe un grosso lavoro di riscrittura. Ancora peggio se la lib in questione è inclusa a sua volta da altre lib di "terze parti" su cui non ho controllo (oppure sì, ma ritoccando migliaia di linee di codice).

Però ci stiamo avvicinando! Non sarebbe carino indicare quali librerie usare? Magari non quelle in /usr/lib ma in una cartella che fornisco insieme al software? So che floola si comporta proprio così: fornisce insieme al binario una folder chiamata "floola libs". Insomma, come delle dll! Come si può ottenere tutto ciò?


EDIT: naturalmente questa sarebbe una soluzione un po' brute force: fornisco io, sin da subito, tutte le librerie necessarie

Ultima modifica di Duchamp : 21-04-2011 alle 13:35.
Duchamp è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 15:56   #4
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Distribuire eseguibili binari in linux e' un calvario perche' non hai mai la garanzia che una persona abbia le librerie che servono.
e se ce le ha probabilmente sono di una versione differente
e se e' la stessa versione probabilmente sono state compilate con flag differenti.

Consiglio mio: se puoi compila staticamente le librerie, molto meno sbattimento.
Se la licenza crea problemi (e.g. e' LGPL) collega dinamicamente, distribuisci le librerie che ti servono e gioca di LD_LIBRARY_PATH
__________________
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 22-04-2011, 11:05   #5
Duchamp
Member
 
L'Avatar di Duchamp
 
Iscritto dal: Apr 2010
Messaggi: 67
Quote:
Originariamente inviato da marco.r Guarda i messaggi
Distribuire eseguibili binari in linux e' un calvario perche' non hai mai la garanzia che una persona abbia le librerie che servono.
e se ce le ha probabilmente sono di una versione differente
e se e' la stessa versione probabilmente sono state compilate con flag differenti.

Consiglio mio: se puoi compila staticamente le librerie, molto meno sbattimento.
Se la licenza crea problemi (e.g. e' LGPL) collega dinamicamente, distribuisci le librerie che ti servono e gioca di LD_LIBRARY_PATH

Sono in piena via crucis con sta storia delle librerie
E ovviamente il 50% è in LGPL... la tua soluzione di settare LD_LIBRARY_PATH mi sembra molto realistica. Se fosse qualcosa di definibile in fase di compilazione sarebbe meraviglioso, evitando di angosciare il mio utente con script e file di sistema. E' possibile?
Duchamp è offline   Rispondi citando il messaggio o parte di esso
Old 22-04-2011, 11:20   #6
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da Duchamp Guarda i messaggi
Sono in piena via crucis con sta storia delle librerie
E ovviamente il 50% è in LGPL... la tua soluzione di settare LD_LIBRARY_PATH mi sembra molto realistica. Se fosse qualcosa di definibile in fase di compilazione sarebbe meraviglioso, evitando di angosciare il mio utente con script e file di sistema. E' possibile?
Uhm, forse si' ma non ti conviene
Ti conviene piuttosto creare uno script che faccia le poche operazioni necessarie e lanci l'eseguibile vero e proprio.
Se nomini lo script col nome del programma e il tuo programma come "programma.bin" ad esempio, il tuo amico neanche si accorgera' che sta lanciando uno script e non il programma vero e proprio.
Per inciso, e' quello che fanno molti programmi commerciali sotto linux, e diversi programmi open source.

giusto per dare una idea, sulla mia macchina di lavoro:
Codice:
# file /usr/bin/* | grep script | wc -l
595

# file /usr/bin/* | grep executable  | wc -l
1769
Un quarto dei binari della mia distribuzione sono in realta' script di qualche tipo.
__________________
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 22-04-2011, 11:42   #7
Duchamp
Member
 
L'Avatar di Duchamp
 
Iscritto dal: Apr 2010
Messaggi: 67
Davvero interessante questa dritta, non avevo proprio considerato lo script che avvia il programma vero e proprio. Adesso mi studio la soluzione, nel frattempo ti ringrazio per il supporto!
Duchamp è offline   Rispondi citando il messaggio o parte di esso
Old 22-04-2011, 11:51   #8
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Un esempio tratto da google-chrome
Codice:
#!/bin/bash
#
# Copyright (c) 2010 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

# Let the wrapped binary know that it has been run through the wrapper.
export CHROME_WRAPPER="`readlink -f "$0"`"

HERE="`dirname "$CHROME_WRAPPER"`"

# We include some xdg utilities next to the binary, and we want to prefer them
# over the system versions because we know they work correctly for us. But if
# our path already exists, we leave it where it is, to allow overriding this.
# (Once distributions have picked up the updated xdg-mime, we can go back to
# appending $HERE rather than prepending.)
case ":$PATH:" in
  *:$HERE:*)
    # $PATH already contains $HERE, leave it where it is.
    ;;
  *)
    # Prepend $HERE to $PATH.
    export PATH="$HERE:$PATH"
    ;;
esac

# Always use our versions of ffmpeg libs.
# This also makes RPMs find the compatibly-named NSS3/NSPR symlinks.
if [[ -n "$LD_LIBRARY_PATH" ]]; then
  LD_LIBRARY_PATH="$HERE:$HERE/lib:$LD_LIBRARY_PATH"
else
  LD_LIBRARY_PATH="$HERE:$HERE/lib"
fi
export LD_LIBRARY_PATH

export CHROME_VERSION_EXTRA="stable"

# We don't want bug-buddy intercepting our crashes. http://crbug.com/24120
export GNOME_DISABLE_CRASH_DIALOG=SET_BY_GOOGLE_CHROME

exec -a "$0" "$HERE/chrome" "$@"
Guarda in particolare la sezione relativa a LD_LIBRARY_PATh
__________________
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
 Rispondi


Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud Nutanix: innovazione, semplicità e IA al ...
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il n...
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
TV LG QNED84 2025: prezzi a picco su tut...
Saldi Pixel 2025: Pixel 9a, Pixel 10, Pi...
Apple Watch in super sconto su Amazon: S...
Indiana Jones e l'Antico Cerchio: in arr...
Motorola MA1, non è mai costato s...
Lara Croft è pronta a tornare: ai...
Windows 10 riceve KB5071546: aggiornamen...
Realme conferma l'arrivo della gamma 16 ...
Il 2026 sarà l'anno di svolta per...
I computer quantistici di Pasqal sbarcan...
Windows 11, in distribuzione l'ultimo ag...
Solo 1.000 pezzi: debutta il Nothing Pho...
Call center truffaldini si fingevano tec...
Le case auto sono sicure: l'UE sposter&a...
Sindacati degli sviluppatori di videogio...
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: 14:47.


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