Skip to content

Instantly share code, notes, and snippets.

@mjpieters
mjpieters / x
Created January 15, 2009 11:25
Urban Dictionary ubiquity search command
(function($) {
makeSearchCommand({
name: "urban-dictionary",
author: {name: "Martijn Pieters", email: "mj@zopatista.com"},
description: "Looks up definition in the Urban Dictionary",
icon: "http://www.urbandictionary.com/favicon.ico",
url:"http://www.urbandictionary.com/define.php?term={QUERY}",
preview: function(pblock, search) {
if (search.text.length < 1) {
$(pblock).html("Definition from the <b>Urban Dictionary</b>");
@mjpieters
mjpieters / gist:2506986
Created April 27, 2012 07:34
plone.app.async decorator template
_decoratedFunctions = {}
class _AsyncSomething(object):
"""Async job decorator
Tracks decorated function via a global mapping instead of storing
the function directly to remain pickleable.
"""
_name = ''
@mjpieters
mjpieters / checkpathlength.py
Created May 18, 2012 12:31
List .torrent files that have pathlengths over a given threshold (defaults to 180 characters).
import bencode
import os
def toolong(torrent, max_, host=None):
decoded = bencode.bdecode(torrent)
if host is not None:
for url in decoded.get('announce-list', [decoded['announce']]):
if host in url: break
else: return False
@mjpieters
mjpieters / mergeiter.py
Created January 22, 2013 16:36
Generator to yield items from a series of sorted iterables in merged order.
import operator
def mergeiter(*iterables):
"""Given a set of sorted iterables, yield the next value in merged order"""
iterables = [iter(it) for it in iterables]
iterables = {i: [next(it), i, it] for i, it in enumerate(iterables)}
while True:
value, i, it = min(iterables.values(), key=operator.itemgetter(0))
yield value
try:
@mjpieters
mjpieters / gist:5345746
Created April 9, 2013 13:37
The GitHub Unicorn

>>> a = [1, 2]
>>> a_multiply = [a] * 5
>>> a_comp = [a for _ in range(5)]
>>> all(i is a for i in a_multiply)
True
>>> all(i is a for i in a_comp)
True
# 2014.02.01 19:20:29 GMT
# Embedded file name: /root/scsl.py
import socket
import threading
import select
import random
import sys
import time
import base64
import subprocess
@mjpieters
mjpieters / peranswer_score.txt
Last active October 10, 2016 15:23
Top Stack Overflow users by tag score
User scores for the top 100 tags sorted on average per-answer score (users with 1000 or more answers only)
NAME TAG SCORE COUNT AVERAGE NORM WEIGHTED
1 CMS javascript 24985 1215 20.56 0.0314 38.1401
2 Eric Lippert c# 44175 2571 17.18 0.0581 149.2803
3 polygenelubricants java 12396 1024 12.11 0.0154 15.7527
4 Mehrdad Afshari c# 11975 1018 11.76 0.0157 16.0231
5 Johannes Schaub - litb c++ 21543 2002 10.76 0.0614 122.9951
6 Dave DeLong objective-c 12198 1254 9.73 0.0555 69.6445
7 Jon Skeet .net 47874 5065 9.45 0.2338 1184.0163
@mjpieters
mjpieters / 4 elements, 1 if
Last active August 29, 2015 14:04
Literal comparisons
$ bin/python test.py 4 1
-------------------------
Configuration:
Number of elements to check against: 4
Number of if statements: 1
-------------------------
Concatenated boolean operators
0.1044412124203518
List
0.06876948488876224
In [1]: from random import randint
In [2]: lines = [randint(0, 42) for _ in range(10000)]
In [3]: %%timeit
...: for _ in lines[::-1]: pass
...:
10000 loops, best of 3: 149 µs per loop
In [4]: %%timeit