Skip to content

Instantly share code, notes, and snippets.

@Suor
Suor / mutating_querysets.py
Created March 16, 2011 07:27
Django: mutating querysets
# THIS VERSION IS OUTDATED
# see .inplace(), .cloning(), ._clone() and .clone() methods of QuerySetMixin
# in https://github.com/Suor/django-cacheops/blob/master/cacheops/query.py
from django.conf import settings
from django.db.models import Model, Manager
MUTATING_QUERYSETS = getattr(settings, 'MUTATING_QUERYSETS', False)
class QuerySetMixin(object):
def __init__(self, *args, **kwargs):
@Suor
Suor / gist:876324
Created March 18, 2011 15:59
QuerySet which returns namedtuples
from itertools import imap
from collections import namedtuple
from django.db.models.query import QuerySet, ValuesQuerySet
class NamedTuplesQuerySet(ValuesQuerySet):
def iterator(self):
# Purge any extra columns that haven't been explicitly asked for
extra_names = self.query.extra_select.keys()
@Suor
Suor / jinjalink_loader.py
Created May 14, 2011 12:08
Jinja2 template loader for django
@Suor
Suor / monkey.py
Created May 16, 2011 16:07
Efficient pickling of django models
from django.db.models import Model
from itertools import izip
def attnames(cls, _cache={}):
try:
return _cache[cls]
except KeyError:
_cache[cls] = [f.attname for f in cls._meta.fields]
return _cache[cls]
@Suor
Suor / INSTALL.markdown
Created November 7, 2011 08:41
open_file_at_cursor sublime command
cd ~/.config/sublime-text-2/Packages/User/
curl -O https://raw.github.com/gist/1344471/open_file_at_cursor.py

Open keyboard bindings file, and add a line to it

[
    ...
 { "keys": ["alt+o"], "command": "open_file_at_cursor" } // this one
@Suor
Suor / update-sublime.pl
Created February 4, 2012 03:01
Sublime Text 2 updater for Linux
#!/usr/bin/perl
use v5.10;
use strict;
use warnings FATAL => 'all';
use Mojo::UserAgent;
my $latest_url = Mojo::UserAgent->new->get('http://www.sublimetext.com/2')
@Suor
Suor / gist:2049656
Created March 16, 2012 11:22
Redis rate limiting
FUNCTION LIMIT_API_CALL(ip)
ts = CURRENT_UNIX_TIME()
_, current, _ = MULTI
SETNX(ip, ts * 10)
INCR(ip, 1)
EXPIRE(ip, 1)
EXEC
IF current - ts * 10 > 10 THEN
ERROR "too many requests per second"
ELSE
@Suor
Suor / README.md
Created June 7, 2012 07:33
Примеры использования AOP

Задача: нужно при активации услуги продлять жизнь объявления. Как не писать одинаковый код в каждом обработчике активации? Примеры возможного аспектно-ориентированного кода на разных языках. Код на перле рабочий с библиотекой Aspect, на остальных языках просто возможные варианты.

Первый вариант использует простые обёртки - перед вызовом AdvertService.activate() навешивает обёртку на метод .save() отдельного объявления, которая уже его продляет. Второй вариант комбинирует два среза: вызов AbstractAdvert.save() и нахождение в потоке управления AdvertService.activate(), и накладывает обработчик на комбинированный срез.

Интересно как недостаточный синтаксис и семантика разных языков делают подобные операции неуклюжими.

P.S. Другой вариант - использование событий, но он более многословный.

@Suor
Suor / cmdline_opts.pl
Created July 11, 2012 10:00
Parse command line options with kind of pattern matching
given (\@ARGV) {
when ([]) {
make_all();
}
when ([qr/first|second|third/]) {
make_source(@ARGV);
}
when ([qr/first|second|third/, qr/\d\d\d\d-\d\d-\d\d/]) {
make_source_day(@ARGV);
}
@Suor
Suor / model_command.py
Created September 7, 2012 06:15
django ModelCommand
import re
from django.core.management.base import LabelCommand, CommandError
from django.db.models.loading import get_model
class ModelCommand(LabelCommand):
args = 'model+'
def handle_label(self, label, **options):
if not re.search(r'^\w+\.\w+$', label):