This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
fold' :: (b->a->b) -> b -> [a] -> b | |
fold' f b [] = b | |
fold' f b (h:t) = fold' f (f b h) t | |
map' :: (a->b) -> [a] -> [b] | |
map' f lst = fold' (\b a -> b ++ [f a]) [] lst | |
map'' :: (a->b) -> [a] -> [b] | |
map'' f [] = [] | |
map'' f (h:t) = f h : map'' f t |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
chunks :: Int -> [a] -> [[a]] | |
chunks _ [] = [] | |
chunks n xs = (fst c) : chunks n (snd c) | |
where c = splitAt n xs | |
chunks' :: Int -> [a] -> [[a]] | |
chunks' n = unfoldr (\b -> if null b then Nothing else Just (splitAt n b)) | |
chunks'' :: Int -> [a] -> [[a]] | |
chunks'' n = takeWhile (not.null) . unfoldr (Just . splitAt n) |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
wordsWhen :: (Char -> Bool) -> String -> [String] | |
wordsWhen p s = case dropWhile p s of | |
"" -> [] | |
s' -> w : wordsWhen p s'' | |
where (w, s'') = break p s' |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
splitStr :: Eq a => [a] -> [a] -> [[a]] | |
splitStr sub str = split' sub str [] [] | |
where | |
split' _ [] subacc acc = reverse (reverse subacc:acc) | |
split' sub str subacc acc | |
| sub `isPrefixOf` str = split' sub (drop (length sub) str) [] (reverse subacc:acc) | |
| otherwise = split' sub (tail str) (head str:subacc) acc |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// MongoClient -- callbacks | |
var assert = require('assert') | |
var MongoClient = require('mongodb').MongoClient | |
MongoClient.connect('mongodb://localhost:27017/test', function(err,db) { | |
assert.equal(null,err) | |
console.log('connected') | |
db.collection('test').find().toArray(function(err,res) { | |
assert.equal(null,err) | |
console.log(res) | |
}) |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
function random_pwd | |
for i in (seq 5) | |
cat /dev/urandom | env LC_CTYPE=C tr -dc 'a-zA-Z0-9' | fold -w 18 | head -n 1 | tr -d '\n' | fold -w 3 | tr '\n' '-' | |
echo '' | |
end | |
end |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
def unfoldr[A, B](seed: B)(func: B => Option[(A, B)]): Stream[A] = | |
func(seed) match { | |
case Some((a, b)) => a #:: unfoldr(b)(func) | |
case None => Stream.empty | |
} | |
/* | |
* Infinite sequence: | |
* val s = unfoldr (0) (b => Some(b,b+1)) | |
* Fibonacci sequence: |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
$ grep -R "::kStageType" * | |
src/mongo/db/exec/and_hash.cpp:const char* AndHashStage::kStageType = "AND_HASH"; | |
src/mongo/db/exec/and_sorted.cpp:const char* AndSortedStage::kStageType = "AND_SORTED"; | |
src/mongo/db/exec/cached_plan.cpp:const char* CachedPlanStage::kStageType = "CACHED_PLAN"; | |
src/mongo/db/exec/collection_scan.cpp:const char* CollectionScan::kStageType = "COLLSCAN"; | |
src/mongo/db/exec/count.cpp:const char* CountStage::kStageType = "COUNT"; | |
src/mongo/db/exec/count_scan.cpp:const char* CountScan::kStageType = "COUNT_SCAN"; | |
src/mongo/db/exec/delete.cpp:const char* DeleteStage::kStageType = "DELETE"; | |
src/mongo/db/exec/distinct_scan.cpp:const char* DistinctScan::kStageType = "DISTINCT_SCAN"; | |
src/mongo/db/exec/ensure_sorted.cpp:const char* EnsureSortedStage::kStageType = "ENSURE_SORTED"; |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
-- Calculates distances between two points (a,b) and (x,y) on a great circle with radius r | |
-- Coordinates are in the form of (longitude,latitude) | |
-- | |
-- Example: calculate distance between points (0,0) and (1,1) on earth: | |
-- ghci> geodist 6378.1 0 0 1 1 | |
-- 157.42462387232553 | |
-- | |
-- Result should be identical to MongoDB's $geoNear | |
-- | |
-- Formula was taken from http://andrew.hedges.name/experiments/haversine/ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var mongoBinary = { | |
save : function(url, collection, filename) { | |
var fs = require('fs') | |
var Binary = require('mongodb').Binary | |
var MongoClient = require('mongodb').MongoClient | |
var assert = require('assert') | |
var doc = { |
OlderNewer