Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - joe2011

#1
Gracias.
#2
Gracias por el aporte. Lo completo un poco.

http://www.linuxfromscratch.org/lfs/read.html
http://www.escomposlinux.org/lfs-es/

Un saludo.
#3
GNU/Linux / n-curses - depuración
3 Marzo 2014, 21:33 PM
Buenas noches, amigos
Realizando las prácticas del capítulo 11 de Programación en  Linux con ejemplos de Kurt Wall, el referido a n-curses, me encuentro con el siguiente problema.

Parece ser que para habilitar la depuración es necesario linkar a ncurses_g y habilitar trace(N) en el código. Para probarlo propone el siguiente código:

/* Filename: depurador.c */

#include <curses.h>

int main (void)
{
initscr();

trace(TRACE_CALLS);
printw("Establecer nivel de depuración para TRACE_CALLS");
refresh();
endwin();
return 0;
}



El caso es que no tenía la biblioteca libncurses_g.a y la instalé den debian 7 con
sudo apt-get install libncurses5-dbg

Al ejecutar el comanda de compilación y depuración
gcc depurador.c -o depurador -lncurses_g

La cantidad de errores es enorme, pongo la parte final
/usr/lib/gcc/i486-linux-gnu/4.7/../../../../lib/libncurses_g.a(lib_echo.o): In function `echo':
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:52: undefined reference to `_nc_tracing'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:53: undefined reference to `SP'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:56: undefined reference to `_nc_retrace_int'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:52: undefined reference to `SP'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:52: undefined reference to `_tracef'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:53: undefined reference to `SP'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:54: undefined reference to `_nc_retrace_int'
/usr/lib/gcc/i486-linux-gnu/4.7/../../../../lib/libncurses_g.a(lib_echo.o): In function `noecho':
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:70: undefined reference to `_nc_tracing'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:71: undefined reference to `SP'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:74: undefined reference to `_nc_retrace_int'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:70: undefined reference to `SP'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:70: undefined reference to `_tracef'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:71: undefined reference to `SP'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_echo.c:72: undefined reference to `_nc_retrace_int'
/usr/lib/gcc/i486-linux-gnu/4.7/../../../../lib/libncurses_g.a(lib_erase.o): In function `werase':
/tmp/buildd/ncurses-5.9/ncurses/base/lib_erase.c:54: undefined reference to `_nc_tracing'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_erase.c:54: undefined reference to `_tracef'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_erase.c:91: undefined reference to `_nc_retrace_int'
/tmp/buildd/ncurses-5.9/ncurses/base/lib_erase.c:91: undefined reference to `_nc_retrace_int'
collect2: error: ld returned 1 exit status


Agradecería me dijérais que es lo que puede pasar. ¿Es posible que haya instalado una libreria de depuración que no corresponda con la versión que tenga instalada de ncurses?

Muchas gracias.

#4
Gracias, ya hice previamente la definicion

DB *puntero_db


Pero bueno, ya comenté que encontre la solución en http://docs.oracle.com/cd/E17076_02/html/index.html
y estoy siguiendo ese tutorial junto con el Manual de Kurt Wall.

Por cierto, que me puedes decir respecto a la antigüedad de los libros y la existencia de manuales del estilo más actualizados.

Muchas gracias.
#5
Hola, amigo

Yo estoy siguiendo el siguiente manual
http://es.scribd.com/doc/182307480/Programacion-en-Linux-Kurt-Wall-pdf

Complementado con otro del mismo autor de Programación en Linux, pero ese lo tengo original. Este último complementa el anterior.

Respecto al primero tengo los ejemplos hechos hasta el capítulo 10, menos los 2 primeros capítulos que ya me los sabía (gcc y make) así que si te decides y tienes dudas en esos capítulos ya sabes donde preguntar.

Un saludo.
#6
Gracias por la respuesta tan escueta. Ya me di cuenta de eso pero falla aunque ponga puntero_db.

No obstante siguiendo http://docs.oracle.com/cd/E17076_02/html/index.html

He modificado el código a lo siguiente:
#include <db.h>
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>



int main ( void )
{

DB *dbp;           /* DB structure handle */
u_int32_t flags;   /* database open flags */
int ret;           /* function return value */

/* Initialize the structure. This
* database is not opened in an environment,
* so the environment pointer is NULL. */
ret = db_create(&dbp, NULL, 0);
if (ret != 0) {
/* Error handling goes here */
perror("db_create");
exit(EXIT_FAILURE);
}

/* Database open flags */
flags = DB_CREATE;    /* If the database does not exist,
                       * create it.*/

/* open the database */
ret = dbp->open(dbp,        /* DB structure pointer */
                NULL,       /* Transaction pointer */
                "test.db", /* On-disk file that holds the database. */
                NULL,       /* Optional logical database name */
                DB_BTREE,   /* Database access method */
                flags,      /* Open flags */
                0600);         /* File mode (using defaults) */
if (ret != 0) {
/* Error handling goes here */
perror ("db_open");
exit(EXIT_FAILURE);
}

dbp->close(dbp,0);
return EXIT_SUCCESS;
} /* ----------  end of function main  ---------- */


En fin, gracias por la respuesta.
#7
GNU/Linux / Berkeley BD - Programación Linux
1 Marzo 2014, 13:16 PM
Estimados amigos,

Estoy siguiendo el Manual de Programación en Linux de Kurt Wall y en su capítulo 10 muestra como trabajar con la base de datos de Berkeley. El caso es que el código que pongo a continuación no compila bien. Los fallos de compilación del código adjunto están en db_open y DB->close aunque linke a  
gcc abrir_db2.c -o abrir_db2 -lbd

abrir_db2.c: In function 'main':
abrir_db2.c:37:5: error: expected identifier or '(' before '->' token


Tampoco se cómo buscar por paginas mán de la Berkeley (si las tiene) sobre todo por averiguarr que versión tengo instalada y así intentar buscar algo de documentación para interaccionar desde C con ella. Al menos lo más básico, abrir, cerrar, añadir registros, etc.



#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <fcntl.h>
#include <db.h>

int main (void)
{
DB puntero_db; /* descriptor de base de datos */
int valor_retornado;

valor_retornado = db_open("test.db", DB_BTREE, DB_CREATE, 0600, NULL, NULL, &puntero_db);

if (valor_retornado) {
perror ("db_open");
exit(EXIT_FAILURE);
}

DB->close(puntero_db,0);
exit(EXIT_SUCCESS);

return EXIT_SUCCESS;
}


Respecto a la Berkeley DB encontré esta página:http://docs.oracle.com/cd/E17076_02/html/api_reference/C/frame_main.html pero tampoco funciona el código tomando estas funciones. Y esta otra https://bbs.archlinux.org/viewtopic.php?id=78032 pero tampoco consigo nada, ya digo creo que necesitaría saber que Berkeley tengo instalada.

Me da la sensación que el libro en general es demasiado antiguo porque en capítulos anteriores, por ejemplo en el que habla de archivos, toca el sistema ext-2 y Debian 7, ya monta ext-4. El caso es que me da que en los próximos capítulos a los que estoy deseando llegar donde toca la manipulación de pantalla con ncurses, redes y demás me pueda encontrar con los mismos problemas. Quisiera que me dieras vuestra opinión al respecto y, si existe algún manual más moderno me lo comentéis.

Un saludo.
#8
GNU/Linux / Re: Bloqueos en Linux con fcntl.
30 Septiembre 2013, 23:33 PM
¡Vaya error más tonto! Disculpen las molestias.

He cerrado el descriptor en el módulo Desbloqueo, y ha de cerrarse en el bloque que establece el bloqueo de escritura, posteriormente a un getchar ()

Es decir, borrar la línea 33, e incluir en las líneas 38 y 39

getchar();
close(fd);
#9
GNU/Linux / Bloqueos en Linux con fcntl.
29 Septiembre 2013, 23:29 PM
Buenas noches de nuevo, compañeros del foro

De nuevo me dirijo a vosotros con un problema de programación en linux. Esta vez en relación al bloqueo de descriptores de archivo.

Como he comentado en otra ocasión, estoy siguiendo el libro de Prentice Hall de Kurt Walt Programación en Linux y, aunque lentamente voy progresando, gracias al libro y a vuestra ayuda.

En esta ocasión se trata de ejecutar el programa desde dos ventanas distintas  (./lockit /tmp/foo) y ver como permite a ambos el bloqueo de lectura (del primer byte) pero cuando en una de ellas pasas al bloqueo de escritura (El programa usa getchar() para detener la ejecución) debe decirte que el pid del programa que lo ejecuta en el otro terminal aún lo tiene bloqueado para lectura y no permitírlo. Bien, esto no me ha funcionado, incluso ejecutándolo en un único terminal la salida que obtengo al ejecutar el bloqueo de escritura es:

          bloqueo de escritura ya establecido por -1075043608

cuando debería escribir lo que haya en el campo lock.l_pid, que según la página man de fcntl es lo que debe imprimir.

En fin, si podéis ayudarme os lo agradeceria. Más abajo el código.

Un saludo.


/*
* lockit.c - Establece el bloqueo en un archivo
*/
#include <unistd.h>
#include <sys/file.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>

/* Establece un bloqueo de tipo en el descriptor fd */
void setlock(int fd, int type);

int main ( int argc, char *argv[] )
{
int fd;
/* Abre el archivo */
fd = open(argv[1], O_RDWR | O_CREAT, 0666);
if (fd < 0) {
perror("open");
exit(EXIT_FAILURE);
}

/* Establece un bloqueo de lectura */
setlock(fd, F_RDLCK);
printf("PID %d bloqueado para lectura %s\n", getpid(), argv[1]);
getchar();

/* Desbloqueo */
setlock(fd, F_UNLCK);
printf("PID %d unlocked %s\n", getpid(), argv[1]);
getchar();
close(fd);

/* Establece un bloqueo de escritura */
setlock(fd, F_WRLCK);
printf("PID %d bloqueado para escritura %s\n", getpid(), argv[1]);


return EXIT_SUCCESS;
} /* ----------  end of function main  ---------- */

void setlock(int fd, int type)
{
struct flock lock;
char msg[80];

/* Describe el bloqueo que queremos */
lock.l_whence = SEEK_SET;
lock.l_start = 0;
lock.l_len = 1; /* bloquea un solo bit */

while (1) {
lock.l_type = type;
/* Bloqueo establecido y vuelta al que llama */
if ((fcntl(fd, F_SETLK, &lock)) == 0)
return;

/* Busca por qué no podemos establecer el bloqueo */
fcntl(fd, F_GETLK, &lock);
if(lock.l_type != F_UNLCK) {
switch(lock.l_type) {
case(F_RDLCK):
sprintf(msg, "bloqueo de lectura ya establecido por %d\n", lock.l_pid);
break;
case(F_WRLCK):
sprintf(msg, "bloqueo de escritura ya establecido por %d\n", lock.l_pid);
break;
}
}
puts(msg);
getchar();
}
}
#10
Muchísimas gracias por ayudarme en la resolución del problema. Está claro, no había incluido la llamada a fstat. Lo he incluido y el resultado es el esperado.

Un saludo.

if ((fstat(fd,&buf)) < 0){
    perror("fstat");
    exit(EXIT_FAILURE);
}