Torna indietro   Hardware Upgrade Forum > Software > Programmazione

PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-05-2011, 17:38   #1
Cory
Member
 
L'Avatar di Cory
 
Iscritto dal: Jan 2009
Città: Trento
Messaggi: 81
[C] dubbio syslog()

Ciao a tutti, sto sviluppando un programmino per un esame ed è richiesta la creazione di un file di log in cui il programma salvi i vari input, output, errori eccetera

guardando sul manuale Linux ho visto che le funzioni messe a disposizione dalla libreria syslog.h potrebbero tornarmi molto utili, ma ho la specifica consegna di salvare i log del programma nella cartella /var/log/PROGRAMMA, dove PROGRAMMA è ovviamente il nome della mia applicazione

come faccio a speciicare questa cosa? in rete ho trovato molto poco in proposito, ed il poco che ho trovato parla di andare a modificare il file /etc/syslog.conf: il problema è che il programma non verrà eseguito sulla mia macchina ma su quella del docente per cui non posso editare file del kernel...c'è un modo per fare questa cosa senza toccare file di configurazione?

grazie mille
Cory è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2011, 18:09   #2
darksax
Member
 
Iscritto dal: Jan 2008
Città: Roma
Messaggi: 126
Se non hai la possibilita' di toccare il syslog.conf la vedo dura...
La libreria in questione si appoggia al demone syslogd (che si appoggia al file syslog.conf e quindi... )

Una possibilita' che mi viene in mente, e che puoi indagare, e' mandare l'output su stderr (mi pare di ricordare che si possa fare dalla openlog() ) ed al lancio del programma lo redirigi dove vuoi. E' un'idea ma non so se si puo fare.

cmq farsi una libreria di log interna corrisponde ad una open/write/close totale 10 righe (15 se prevedi una chiamata stile printf() con n parametri variabili in numero e tipo) ed intanto vai avanti con il progetto. poi se hai tempo te la sistemi meglio.
(anche xche' potra' diventare la tua migliore amica nei tuoi futuri sviluppi )

ciao
__________________
La forza dei forti sta nel traversare le traversie con occhio sereno! (PK) ...
I computer sono esattamente come gli esseri umani: fanno qualsiasi cosa tranne che pensare. (John Van Neumann)
Siamo brevi, il mondo è sovraffollato di parole. (Stanisław Jerzy Lec)
darksax è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 09:58   #3
Cory
Member
 
L'Avatar di Cory
 
Iscritto dal: Jan 2009
Città: Trento
Messaggi: 81
la syslog() non la posso usare ai fini del progetto, quindi mi tocca farmi i log da solo grazie dell'aiuto comunque
Cory è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 12:35   #4
Cory
Member
 
L'Avatar di Cory
 
Iscritto dal: Jan 2009
Città: Trento
Messaggi: 81
ne approfitto perchè ho un problema: i miei file di log vanno creati nella cartela /var/log/NOME_PROGRAMMA, quindi ho realizzato una funzione del tipo:

Codice:
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<time.h>
#define LOG_FILE "/var/log/prova/prova_di_log.txt"
#define UTILITY "my_ln"

void write_log();
void error_log();

int main(int argc, char **argv){

        write_log();



}

void write_log(){
  
      FILE *fp;
      time_t ltime=time(NULL);
      
      /*apro file di log, se non esiste lo creo*/
      fp=fopen(LOG_FILE,"a");
      /*scrivo log*/
      fprintf(fp,"%s: %s \tinvocata con i parametri\n",UTILITY,ctime(&ltime));
      /*chiudo file di log*/
      fclose(fp);
      
}

void error_log(){
  
      FILE *fp;
      time_t ltime=time(NULL);
      
      /*apro file di log, se non esiste lo creo*/
      fp=fopen(LOG_FILE,"a");
      /*scrivo log*/
      fprintf(fp,"%s: %s \tERROR \n",UTILITY,ctime(&ltime));
      /*chiudo file di log*/
      fclose(fp);
  
  
}
solo che nella cartella /var/log :

1. non c'è la cartella NOME_PROGRAMMA
2. non c'è il file di log

immagino che questo accada perchè ho sufficienti permessi per aggiungere entry in quella cartella, o sbaglio? qualcuno sa come posso fare? PS: il codice sopra è il prototipo della libreria che poi gestirà i file di log, non fa sostanzialmente nulla,,
Cory è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 12:49   #5
Cory
Member
 
L'Avatar di Cory
 
Iscritto dal: Jan 2009
Città: Trento
Messaggi: 81
tra l'altro il codice compila senza errori, se lo eseguo da segmentation fault..ma se cambio il valore di LOG_FILE (ad esempio, /home/user/Documenti/file.txt) tutto funziona perfettamente...
Cory è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 14:43   #6
darksax
Member
 
Iscritto dal: Jan 2008
Città: Roma
Messaggi: 126
L'errore di segmentation fault lo becchi perche' non testi il ritorno della fopen().
In caso di errore della fopen() il descrittore ritornato vale NULL.
Non controllandolo, poi al primo utilizzo (nella fwrite()) fai il botto.
quindi aggiungi sotto la open un test ed agisci di conseguenza.

Per i diritti sulla directory controlla se esiste la directory prova sotto /var/log e se ha i permessi giusti (ls-l e chmod). Okkio che fopen crea solo i file non le directory
__________________
La forza dei forti sta nel traversare le traversie con occhio sereno! (PK) ...
I computer sono esattamente come gli esseri umani: fanno qualsiasi cosa tranne che pensare. (John Van Neumann)
Siamo brevi, il mondo è sovraffollato di parole. (Stanisław Jerzy Lec)
darksax è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 15:11   #7
Cory
Member
 
L'Avatar di Cory
 
Iscritto dal: Jan 2009
Città: Trento
Messaggi: 81
grazie della risposta!
in caso come faccio a creare una directory o file a cui possono accedere tutti?
Cory è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 16:02   #8
darksax
Member
 
Iscritto dal: Jan 2008
Città: Roma
Messaggi: 126
mkdir() per creare la directory
access() per controllare la sua esistenza

i diritti assegnati alla directory creata corrispondono a quelli assegnati nell'environment del utente che esegue il programma (ti auguro che il prof sia magnanimo

PS okkio al test di errno x la gestione degli errori

cmq se ti puo' essere utile, qui trovi un buon reference sulla clib con relativi sample
http://www.delorie.com/gnu/docs/glibc/libc_282.html

ciao
__________________
La forza dei forti sta nel traversare le traversie con occhio sereno! (PK) ...
I computer sono esattamente come gli esseri umani: fanno qualsiasi cosa tranne che pensare. (John Van Neumann)
Siamo brevi, il mondo è sovraffollato di parole. (Stanisław Jerzy Lec)
darksax è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Scivolone ASRock: annuncia il Ryzen 9 99...
DLSS 5: NVIDIA spiega il funzionamento, ...
PlayStation come NVIDIA DLSS: Sony punta...
OnePlus Nord 6 sta arrivando e avr&agrav...
CPU desktop: Intel dice addio ai socket ...
Google sta testando un'app di Gemini per...
NVIDIA GeForce RTX 5070 Laptop: in arriv...
Il Tribunale di Roma ha annullato la mul...
AppleCare One potrebbe arrivare presto i...
Amazon ci riproverà: l'azienda st...
Apple e Samsung dominano la classifica d...
Un game designer di 9 anni, due fogli a ...
Il weekend Amazon parte col botto: gross...
Amazfit Active 2 scende a 69,99€: i migl...
Smart TV No IVA su Amazon: QLED, Mini-LE...
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:52.


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