¡Esta es una revisión vieja del documento!
Tabla de Contenidos
Programación
IOCTLs
Notas generales de programación
Actualizacion a PHP 5.3.2
split() reemplazarla por explode()
How to fix ‘Function eregi() is deprecated’ in PHP 5.3.0
I used to use eregi for validating email address input that matches to the regular expression.
<?php if(!eregi("^[_\.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z-]+\.)+[a-zA-Z]{2,6}$", $str)) { $msg = 'email is not valid'; } else { $valid = true; } ?>
That would return true if given email address is matches to username@domain.ext pattern. Unfortunately, after upgrading PHP to the earlier version (5.3.0), it wont work properly. This is because eregi is one of several functions that are deprecated in the new version of PHP.
Solution: Use preg_match with the 'i' modifier instead. i means that regular expression is case insensitive. So the code become like this:
<?php if(!preg_match("/^[_\.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z-]+\.)+[a-zA-Z]{2,6}$/i", $str)) { $msg = 'email is not valid'; } else { $valid = true; } ?>
http://takien.com/513/how-to-fix-function-eregi-is-deprecated-in-php-5-3-0.php
Obtener el usuario segun su UID
En este caso queremos obtener el usuario que corresponde al UID 506
#include <stdio.h> #include <pwd.h> #include <sys/types.h> int main() { struct passwd *pw; pw = getpwuid(506); if (pw == NULL) { printf("NULL!\n"); } else { printf("name: %s\n", pw->pw_name); } }
Parsear el contenido de un tag XML con sed
A veces necesitamos extraer el contenido de un tag XML dentro de un script, aca un ejemplo simple
<state can_be_paused="0">running</state>
sed 's/<[^>]*[>]//g'
Salida:
running
Agregar texto al final de una linea que matchea con cierto patrón
Ejemplo en la linea que se refiere al kernel en el archivo menu.lst quiero cambiar la opción de memoria para el dominio 0.
Entonces necesito cambiar de algo asi:
kernel /xen.gz-2.6.18-164.10.1.el5
A algo asi:
kernel /xen.gz-2.6.18-194.8.1.el5 dom0_mem=96
Ejecuto esto:
sed -e 's/kernel.*/& dom0_mem=96/g' menu.lst
Redondear un numero en BASH
echo "tmp=$variable; tmp /= 1;tmp" | bc
Ejecutar asyncronicamente en Perl o como emular un nohup desde adentro
use strict; use POSIX qw/setsid/; my $pid = fork(); die "can't fork: $!" unless defined $pid; exit 0 if $pid; setsid(); open (STDIN, "</dev/null"); open (STDOUT, ">/dev/null"); open (STDERR,">&STDOUT"); exec "comando a ejecutar";
can you get cp to give a progress bar like wget
#!/bin/sh cp_p() { strace -q -ewrite cp -- "${1}" "${2}" 2>&1 \ | awk '{ count += $NF if (count % 10 == 0) { percent = count / total_size * 100 printf "%3d%% [", percent for (i=0;i<=percent;i++) printf "=" printf ">" for (i=percent;i<100;i++) printf " " printf "]\r" } } END { print "" }' total_size=$(stat -c '%s' "${1}") count=0 }
Problema clásicos de programación
Peluquero dormilón
/* Author: dhb@email.it Your comments are welcome. Peluquero dormilón Introducción Una ciudad tiene una peluquería con dos puertas y unas pocas sillas. Los clientes entran por una puerta y salen por la otra. Dado que el negocio es chico, a lo sumo un cliente o el peluquero se pueden mover en al a la vez. El peluquero pasa su vida atendiendo clientes, uno por vez. Cuando no hay ninguno, el peluquero duerme en su silla. Cuando llega un cliente y encuentra que el peluquero está durmiendo, el cliente lo despierta, se sienta en la silla del peluquero y duerme mientras el peluquero le corta el pelo. Si el peluquero está ocupado cuando llega un cliente, el cliente se va a dormir a una de las otras sillas. Despúes de un corte de pelo, el peluquero abre la puerta de salida para el cliente y la cierra cuando el cliente se va. Si hay clientes esperando, el peluquero despierta a uno y espera que el cliente se siente. Sino, se vuelve a dormir hasta que llegue un cliente. Implementación La implementación propuesta esta desarrollada en C usando semáforos. Semáforos: Clientes (customers): número de clientes en espera sin contar el que se esta cortando el pelo Barberos (barber): número de peluqueros (barberos) inactivos. Exmut: exclusión mutua. Condiciones iniciales: customers = 0, barber = 0, exmut = 1 Código */ #include <stdio.h> #include <unistd.h> #include <pthread.h> #define TRUE 1 #define FALSE 0 #define CHAIRS 3 //Sillas Disponibles #define CANT_CUST 5 //Cantidad de Clientes #define T_CUST 0 //Tiempo de llegada de Clientes #define T_CORTE 3 //Tiempo de corte de pelo typedef int semaphore; //Prototipo de funciones void *customer (void *); void *barber (void *); void up (semaphore *); void down (semaphore *); semaphore sem_barber=0, sem_customer=0,sem_mutex=1; int waiting=0; //Main function int main (void) { pthread_t barb_t,cust_t[CANT_CUST]; int i; pthread_create(&barb_t,NULL,barber,NULL); for (i=0;i<CANT_CUST;i++){ sleep(T_CUST); pthread_create(&cust_t[i],NULL,customer,NULL); } pthread_join(barb_t,NULL); return(0); } void *customer (void *n) { printf ("Customer:entrando hay %d esperando\n",waiting); down (&sem_mutex); if (waiting < CHAIRS) { waiting++; up (&sem_customer); up (&sem_mutex); down (&sem_barber); printf ("Customer:Me estan cortando el pelo.\n"); } else { up (&sem_mutex); printf ("Customer:Me fui no hay lugar.\n"); } } void *barber (void *j) { printf ("Barber:Empiezo a trabajar\n"); while (TRUE) { down (&sem_customer); down (&sem_mutex); waiting--; up (&sem_barber); up (&sem_mutex); printf ("Barber:Comienzo el corte de pelo de un cliente quedan %d esperando.\n",waiting); sleep (T_CORTE); printf ("Barber:Termine de cortar el pelo de un cliente quedan %d esperando.\n",waiting); } } void up (semaphore *sem) { *sem+=1; } void down (semaphore *sem) { while (*sem<=0){}; *sem-=1; }