Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
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: 12939
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


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Reddit punterà sull'AI per miglio...
Samsung ha obiettivi molto ambiziosi per...
I produttori non faranno sconti sulle me...
Ubisoft potrebbe cedere pezzi se il pian...
Qualcomm potrebbe utilizzare una tecnolo...
Starfield per Nintendo Switch 2 potrebbe...
Un MacBook Pro a -300€, i MacBook Air M4...
Amazon abbassa i prezzi sugli iPhone: sc...
Amazon, ancora sconti sugli smartphone A...
iPhone Air 2 'riciclerà' alcuni c...
Offerta Amazon da non perdere: lo speake...
Nioh 3 debutta alla grande su Steam: pri...
Al centro della Via Lattea ci potrebbe e...
Elon Musk ora guarda alla Luna: SpaceX p...
La Cina ha lanciato nuovamente lo spazio...
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: 23:02.


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