1
0
Fork 0
mirror of https://github.com/kdeldycke/awesome-falsehood.git synced 2024-11-20 11:35:56 -05:00
falsehood/README.md
2016-09-12 11:56:49 +02:00

210 lines
6.8 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Awesome Falsehood [![Awesome](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg)](https://github.com/sindresorhus/awesome)
A curated list of awesome falsehoods programmers believe in.
> The logic of the world is prior to all truth and falsehood.
> - Ludwig Wittgenstein
## Contents
- [Foreword](#foreword)
- [Good Candidates](#good-candidates)
- [*Falsehood* Articles](#falsehood-articles)
- [Libraries](#libraries)
- [Data Structures](#data-structures)
- [Meta](#meta)
- [Build Systems](#build-systems)
- [Dates and Time](#dates-and-time)
- [E-Commerce](#e-commerce)
- [Emails](#emails)
- [Gender](#gender)
- [Geography](#geography)
- [Human Names](#human-names)
- [Networks](#networks)
- [Phone Numbers](#phone-numbers)
- [Prices](#prices)
- [Postal Addresses](#postal-addresses)
- [Versions](#versions)
- [Contributing](#contributing)
- [License](#license)
## Foreword
*Falsehood* articles are a form of commentary on a particular subject, and are
appreciated by the developer community at large for their effectiveness and
density. They're a convenient written form to approach an unfamiliar domain by
dispelling myths, point out common pitfalls, show inconsistencies and
subtleties.
They might looks like to some as a suite of wordy unit-tests covering extensive
edge-cases provided by real-world usage.
## Good Candidates
Here is a non-restrictive list of items which are good candidates for inclusion
in this awesome list.
### *Falsehood* Articles
Articles following the *falsehood* scheme are prime candidates for inclusion in
this awesome list.
These articles starts with the hypothesis that developers have a naive, simple
view of the subject at hand. Then proceed to list a set of candid assumptions
that might be held by such programmers. Each one is intentionally false, and
sometimes illustrated by a counter-example.
A list of falsehood is crafted as a progression that is designed to refine
concepts. Having read the whole list of falsehood, the reader should possess a
global, if not complete, overview of the domain being targeted by the article,
including most, if not all, its pitfalls, edges-cases and inconsistencies.
In the worst case, these articles might provoke an emotional reaction and cause
flipping table. `(╯°□°)╯︵ ┻━┻`
### Libraries
When possible, we provide a list of programming libraries or modules that may
solve, or try to, the complexities and idiosyncrasies pointed by the
*falsehood* articles above.
So we can put back tables in place. `┬─┬ ( ゜-゜ノ)`
### Data Structures
Data models and structures generic enough to cover and addresses most of the
falsehoods are also welcome in this page.
## Meta
- [Awesome Falsehood](https://github.com/kdeldycke/awesome-falsehood) - A
curated list of awesome falsehoods programmers believe in.
- [Falsehoods Programmers
Believe](http://spaceninja.com/2015/12/08/falsehoods-programmers-believe/) - A
brief list of common falsehoods. A great overview and quick introduction into
the world of falsehoods.
## Build Systems
- [Falsehoods About Build
Systems](http://pozorvlak.livejournal.com/174763.html)
## Dates and Time
- [Falsehoods About
Time](http://infiniteundo.com/post/25326999628/falsehoods-programmers-believe-about-time) -
Seminal article on dates and time.
- [More Falsehoods About
Time](http://infiniteundo.com/post/25509354022/more-falsehoods-programmers-believe-about-time) -
Part. 2 of the article above.
- [Falsehoods About Time and Time
Zones](http://www.creativedeletion.com/2015/01/28/falsehoods-programmers-date-time-zones.html) -
Another takes on time-related falsehoods, with an emphasis on time zones.
- [Falsehoods About
Time](https://gist.github.com/thanatos/eee17100476a336a711e) - A critique of
the first article with a very detailed explanation of each falsehood, adding
more context and external resource to the subject.
## E-Commerce
- [Falsehoods About Online
Shopping](http://wiesmann.codiferes.net/wordpress/?p=22201)
## Emails
- [I Knew How to Validate an Email Address Until I Read the
RFC](http://haacked.com/archive/2007/08/21/i-knew-how-to-validate-an-email-address-until-i.aspx/).
## Gender
- [Falsehoods About
Gender](https://gist.github.com/garbados/f82604ea639e0e47bf44)
## Geography
- [Falsehood About
Geography](http://wiesmann.codiferes.net/wordpress/?p=15187).
## Human Names
- [Falsehoods About
Names](https://www.kalzumeus.com/2010/06/17/falsehoods-programmers-believe-about-names/).
- [XKCD #327: Exploits of a
Mom](https://xkcd.com/327/).
- [HL7 v3
RIM](http://www.hl7.org/implement/standards/product_brief.cfm?product_id=186) -
A flexible data model for representing human names.
- [iOS
`NSPersonNameComponentsFormatter`](https://developer.apple.com/library/ios/documentation/Miscellaneous/Reference/NSPersonNameComponentsFormatter_Class/index.html) -
Localized representations of the components of a persons name.
## Networks
- [Falsehoods About
Networks](http://blog.erratasec.com/2012/06/falsehoods-programmers-believe-about.html)
## Phone Numbers
- [`libphonenumber`](https://github.com/googlei18n/libphonenumber) - Google's
common Java, C++ and JavaScript library for parsing, formatting, and validating
international phone numbers. Also available for
[C#](https://github.com/erezak/libphonenumber-csharp),
[Objective-C](https://github.com/iziz/libPhoneNumber-iOS),
[Python](https://github.com/daviddrysdale/python-phonenumbers),
[Ruby](https://github.com/sstephenson/global_phone) and
[PHP](https://github.com/giggsey/libphonenumber-for-php).
## Prices
- [Falsehoods About
Prices](https://gist.github.com/rgs/6509585).
## Postal Addresses
- [Falsehoods About
Addresses](https://www.mjt.me.uk/posts/falsehoods-programmers-believe-about-addresses/).
- [`libaddressinput`](https://github.com/googlei18n/libaddressinput) - Google's
common C++ and Java library for parsing, formatting, and validating
international postal addresses.
- [`addressing`](https://github.com/commerceguys/addressing) - A PHP 5.4+
addressing library, powered by Google's dataset.
- [`postal-address`](https://github.com/scaleway/postal-address) - Python
module to parse, normalize and render postal addresses.
## Versions
- [Falsehoods About
Versions](https://github.com/xenoterracide/falsehoods/blob/master/versions.md)
## Contributing
Your contributions are always welcome! Please take a look at the [contribution
guidelines](CONTRIBUTING.md) first.
## License
[![CC0](http://mirrors.creativecommons.org/presskit/buttons/88x31/svg/cc-zero.svg)](https://creativecommons.org/publicdomain/zero/1.0/)
Content of this repository is licensed under the [Creative Commons CC0
license](https://creativecommons.org/publicdomain/zero/1.0/).
To the extent possible under law, [Kevin Deldycke](http://kevin.deldycke.com)
has waived all copyright and related or neighboring rights to this work.