Rodrigo Borrego Bernabé - Software Developer



SQLite3::exec(): database is locked error

Category : Programación, Symfony · No Comments · by Ene 31st, 2012

Si comenzando a utilizar Symfony2 trabajáis en una mezcla de Windows y Linux que unís mediante Samba, quizás os hayáis encontrado con el siguiente error nada más comenzar:

Warning: SQLite3::exec(): database is locked

Realmente no podemos arreglarlo, puesto que la gestión de permisos de Samba no le gusta a SQLite, pero podemos evitarlo (‘workaround’, que dirían) cambiando el directorio donde se crean ciertos ficheros. Abrimos el archivo ‘app/config/config.yml’ y escribimos la siguiente configuración:

parameters:
  kernel.cache_dir: '/tmp/sf-test'

Fuente: http://www.kitpages.fr/fr/cms/21/symfony2-sqlite3-et-samba

UPDATE: Parece que con la versión 2.0.12 esto ya no funciona y debes incluir en app/AppKernel.php

public function getCacheDir()
 {
 //return $this->rootDir . '/my_cache/' . $this->environment;
 return '/tmp/sf2'.$this->environment;
 }

Buscar en Gmail por múltiples etiquetas

Category : breves · No Comments · by Sep 1st, 2011

A menudo lo necesito y siempre se me olvida cómo hacerlo y lo que se puede y no se puede hacer. Así que aquí lo resumo

Todas las etiquetas (AND):

l:personal l:deporte

Que se puede combinar con la búsqueda normal:

l:personal l:deporte sábado

buscaría los mensajes con ‘sabado’ y las etiquetas ‘personal’ y ‘deporte’

Alguna de las etiquetas (OR)

l:personal OR l:deporte

Cambiar el orden de los listados de sfDoctrineRoute

Category : Programación, Symfony · No Comments · by Ago 17th, 2011

En el controlador (actions.class.php) tenemos un método para el listado de elementos:

  public function executeIndex(sfWebRequest $request)
  {
    $this->items= $this->getRoute()->getObjects();
  }

Si queremos modificar el comportamiento, por ejemplo el orden en el que se muestran esos listados debemos modificar el routing.yml

item:
  class: sfDoctrineRouteCollection
  options:
    [...]
    model_methods:
      list:            getListOrdered

Y en itemTable.class.php añadir el siguiente método (por ejemplo para ordenar por el año)

    public static function getListOrdered()
    {
        return ItemTable::getInstance()->createQuery('e')->orderBy('year DESC')->execute();
    }

Ahorra dinero, o no lo pierdas, sabiendo matemáticas básicas

Category : Uncategorized · No Comments · by Jun 17th, 2011

Me parece increíble. Pero me acabo de encontrar con un error básico de cálculo. Y corregir a la persona que lo cometió me ha permitido ahorrarme más de 150€ (aparte de ganarme una mirada asesina, pero ese es otro tema).

Lo diré claro  INCREMENTAR UNA CANTIDAD EN DOS PORCENTAJES NO ES LO MISMO QUE INCREMENTAR LA SUMA DE LOS PORCENTAJES.

Es decir, no es lo mismo incrementar el IVA (18%) y luego aplicar un descuento (25%) que incrementar (o decrementar en este caso) la suma (-7% = 18% – 25%).

MAL HECHO/ERROR/NO

  1. Cantidad inicial: 100€ (bien redonda).
  2. Le quitamos el 7%: 100€ – 7€
  3. Total: 93€

BIEN

  1. Cantidad inicial: 100€
  2. Le añadimos el IVA: 100€ + 18€ = 118€
  3. Al resultado le aplicamos el 20% de descuento: 118€ – 29,5€ = 88,5€
  4. Total: 88,5€

En definitiva, con estos datos hacerlo bien nos ha permitido ahorrar 4,5€. ¿No te parece mucho? Prueba a rehacer las cuentas para un coche (23.000€ por ejemplo). Ya te lo digo yo: 1.035€

¡Ay! ¡Qué a gusto me he quedado!

Redimensionado de background que simula columnas

Category : breves, HTML/CSS, Programación · No Comments · by Jun 10th, 2011

Este artículo es muy interesante para redimensionar automáticamente imágenes, videos,  etc.

http://www.alistapart.com/articles/fluid-images/

Y tiene una segunda parte tan interesante o más acerca de «layout de dos columnas de la misma altura y redimensionable (líquido)». ¿Sabes de qué hablo? Si lo has sufrido fijo que sí.

Artículo útil sobre CSS layouts

Category : HTML/CSS, Programación · No Comments · by May 31st, 2011

He encontrado un artículo interesante sobre layouts en CSS y bordes para dos columnas. No he probado lo que aquí cuentan, pero tendré que echarle un vistazo…
http://www.smashingmagazine.com/2010/11/08/equal-height-columns-using-borders-and-negative-margins-with-css/

Invocando url_for desde el modelo

Category : Programación, Symfony · No Comments · by Abr 5th, 2011

El modo ‘feo’ (AKA The Ugly Way), dado que rompe el paradigma MVC:

sfContext::getInstance()->getConfiguration()->loadHelpers(array('Url'));
$url = url_for('mi_url', true); // El segundo parámetro (absolute) depende del destino de la variable $url

El modo ‘elegante’:

$url = sfContext::getInstance()->getController()->genUrl('mi_url', true);

o en una acción:

$this->getController()->genUrl('string');

Reemplazar texto con imágenes vía CSS

Category : HTML/CSS, Programación · No Comments · by Mar 22nd, 2011

Motivación

  1. Quiero una imagen en mi botón/enlace/elemento de menú/loquesea
  2. Quiero que los que no vean las imágenes (navegadores modo texto, bots, lectores de pantalla, etc.) tengan un texto equivalente
  3. Quiero que los demás no vean ese texto

HTML:

<div class="miclase">Mi texto alternativo</div>

CSS:

.miclase {
 text-indent: -100em;
 overflow: hidden;
 background: url(miimagen.png) no-repeat;
 height: 100px;
 width: 100px;
 }

Japón

Category : Uncategorized · No Comments · by Mar 15th, 2011

Una parte de mí siente vergüenza cuando sigo con mi vida, preocupado por menudencias. Una parte de mí siente vergüenza al agobiarme por tonterías cuando miles de personas lo han perdido todo barrido por el agua.

Mi apoyo a toda la gente que tratará de seguir adelante, de crearlo todo de nuevo desde cero. Un abrazo, virtual, pero sentido.

Escribir mensajes de log desde el modelo que funcionan en las tareas CLI de Symfony

Category : Programación, Symfony · No Comments · by Mar 5th, 2011

El problema de echo es que aparece por pantalla de la web y no queremos que eso ocurra en producción.
El problema del sfLogger es que se accede a través del contexto y no lo tenemos en las tareas de línea de comandos (task in CLI) de Symfony.

Entonces, ¿Cómo escribir un mensaje de log desde el modelo que funcione en ambas situaciones?


ProjectConfiguration::getActive()
->getEventDispatcher()
->notify(new sfEvent(NULL, 'application.log', array('message' => "Mi mensaje",
'priority' => sfLogger::INFO)));