177 lines
9.1 KiB
Markdown
177 lines
9.1 KiB
Markdown
# **[pronoun.is](https://pronoun.is) is a website for personal pronoun usage examples**
|
|
|
|
<!-- markdown-toc start - Don't edit this section. Run M-x markdown-toc-refresh-toc -->
|
|
**Table of Contents**
|
|
|
|
- [**[pronoun.is](https://pronoun.is) is a website for personal pronoun usage examples**](#pronounishttpspronounis-is-a-website-for-personal-pronoun-usage-examples)
|
|
- [For users](#for-users)
|
|
- [For developers](#for-developers)
|
|
- [The database](#the-database)
|
|
- [The code](#the-code)
|
|
- [Tests](#tests)
|
|
- [Running the app in a dev environment](#running-the-app-in-a-dev-environment)
|
|
- [The git repo](#the-git-repo)
|
|
- [Philosophy on pronoun inclusion](#philosophy-on-pronoun-inclusion)
|
|
- [FAQ](#faq)
|
|
- [Can we translate pronoun.is into another language?](#can-we-translate-pronounis-into-another-language)
|
|
- [Can we change the example sentences?](#can-we-change-the-example-sentences)
|
|
- [Can we add pronunciation guides?](#can-we-add-pronunciation-guides)
|
|
- [Can we add pluralization support (i.e. themself vs themselves)](#can-we-add-pluralization-support-ie-themself-vs-themselves)
|
|
- [License](#license)
|
|
|
|
<!-- markdown-toc end -->
|
|
|
|
|
|
## For users
|
|
|
|
You can use any pronouns you like simply by filling them into the
|
|
url path. For example, https://pronoun.is/ze/zir/zir/zirs/zirself
|
|
|
|
That's pretty unwieldy! Fortunately you can also give it only the
|
|
first pronoun or two: https://pronoun.is/she/her or https://pronoun.is/they
|
|
|
|
Automatically filling in the rest from only one or two forms only
|
|
works for pronouns in the [database][pronoun-database]. If the
|
|
pronouns you or a friend uses aren't supported, please let us know and
|
|
we'll add them. Alternatively you could add them yourself and submit a
|
|
pull request (see the next section for details)
|
|
|
|
## For developers
|
|
|
|
### The database
|
|
|
|
The pronouns "database" is a tab-delimited file located in [resources/pronouns.tab][pronoun-database] with fields and example values as follows:
|
|
|
|
subject|object|possessive-determiner|possessive-pronoun|reflexive
|
|
-------|------|---------------------|------------------|---------
|
|
they | them | their | theirs | themselves
|
|
|
|
The top 6 pronouns are displayed on the front page. Please don't edit these
|
|
without talking to me, they've been hand-curated based on usage frequency.
|
|
Below the top 6, the remaining pronouns are sorted in alphabetical order by
|
|
subject and then in roughly frequency order for sets that have the same subject
|
|
pronoun. If you're adding a set that shares the same object pronoun as other
|
|
set(s) already in the database, please insert it immediately below those ones.
|
|
|
|
If you edit the database with a text editor, make sure your editor inputs real
|
|
tab characters in that file (a thing your editor might normally be configured
|
|
not to do!) In Emacs, you can input real tabs by doing Ctrl+q <tab>.
|
|
In Vi you can use Ctrl+v <tab>.
|
|
|
|
[pronoun-database]: resources/pronouns.tab
|
|
|
|
### The code
|
|
|
|
The top-level logic for running the server lives in [`pronouns.web`](src/pronouns/web.clj)
|
|
|
|
Page rendering markup is in [`pronouns.pages`](src/pronouns/pages.clj), it uses
|
|
[hiccup](https://github.com/weavejester/hiccup) for rendering HTML from Clojure
|
|
datastructures.
|
|
|
|
[`pronouns.config`](src/pronouns/config.clj) is currently used only for loading
|
|
the [pronouns database][pronoun-database]
|
|
|
|
The unfortunately-named [`pronouns.util`](src/pronouns/util.clj) includes both
|
|
actual utility functions used elsewhere in the code, but also what you might
|
|
think of as "controllers" if you're used to the MVC model of web design - code
|
|
that does the computations necessary for the `pages` (analogous to "views")
|
|
to render themselves. We should probably break up `util` into (at least) two
|
|
namespaces and be a little more deliberate about where everything currently
|
|
in that namespace should live!
|
|
|
|
### Tests
|
|
|
|
Run the suite with `lein test`
|
|
|
|
Test coverage is not great but getting better. Please run the tests and
|
|
confirm that everything passes before merging changes, and please include
|
|
tests with any new logic you introduce in a PR!
|
|
|
|
Goals for the future include setting up automated CI to run the tests for
|
|
us on every PR branch
|
|
|
|
### Running the app in a dev environment
|
|
|
|
First, install [leiningen](https://leiningen.org/). Then you can launch the app
|
|
on your own computer by running the following command:
|
|
|
|
```
|
|
$ lein ring server
|
|
```
|
|
|
|
This will launch a server running the app and open your default web browser to
|
|
the index page. The server will automatically reload files as you edit them -
|
|
with the unfortunate exception of `pronouns.tab`, which is loaded as a resource
|
|
and requires an app restart to reload.
|
|
|
|
### The git repo
|
|
|
|
For most of this project's history we had separate `master` and `develop`
|
|
branches but that's proven to be more trouble than it's worth. Going
|
|
forward we'll be doing all development in feature branches off of `master`,
|
|
and PRs should be issued against `master`.
|
|
|
|
Please follow [this guide](https://chris.beams.io/posts/git-commit/)
|
|
for writing good commit messages :)
|
|
|
|
## Philosophy on pronoun inclusion
|
|
|
|
Pronoun.is aims foremost and exclusively to be a useful resource for people to communicate the personal pronoun they use for themselves.
|
|
|
|
It is possible to use these example sentences to demonstrate the usage of words that are not personal pronouns, or even cleverly insert an [entire story](https://pronoun.is/she/or%20they,%20those%20ships%20who%20were%20docked%20and%20still%20equipped%20with%20ancillaries,%20arranged%20to%20share%20the%20duty%20of%20monitoring%20our%20guest%20as%20it%20fit%20into%20their%20routines;%20that%20was%20the%20agreement,%20despite%20it%20being%20less%20convenient%20for%20me%20to%20participate%20at%20all,%20on%20the%20grounds%20that%20certain%20visitors%20might%20prefer%20a%20constant%20individual%20companion%20to%20what%20might%20seem,%20depending%20on%20their%20past%20experiences,%20to%20be%20undue%20attention%20from%20every%20soldier%20they%20passed.%20As%20usual,%20then,%20I%20took%20the%20first%20shift/the%20one%20possession%20of%20hers%20that%20Station%20Security%20hadn't%20confiscated,%20a/knowingly%20left%20with%20her.%20What%20a%20Presger%20frisbee%20might%20do%20or%20even%20look%20like%20I%20couldn't%20say.%20She%20hadn't%20seemed%20the%20sort%20to%20have%20alien%20technology,%20but,%20then%20again,%20neither%20had%20I/another%20unremarkable%20stranger,%20quite%20a%20ways%20down%20the%20concourse,%20who%20caught%20it%20with%20a%20degree%20of%20coordination%20that%20most%20would%20have%20overlooked.%20It%20did%20not%20escape%20my%20notice,%20however.%20"Cousin,"%20I%20said,%20enough%20to%20convey%20-%20unless%20our%20visitor%20were%20quite%20ignorant,%20but,%20of%20course,%20at%20this%20point%20I%20was%20certain%20that%20she%20couldn't%20be%20-%20both%20that%20I%20knew%20what%20she%20was%20not%20and%20that%20I%20was%20giving%20her%20the%20benefit%20of%20the%20doubt%20as%20to%20what,%20or%20who,%20she%20was)! However, as a policy we will not include such entries in the database.
|
|
|
|
|
|
## FAQ
|
|
|
|
### Can we translate pronoun.is into another language?
|
|
|
|
I'd love to see pronoun.is-like apps exist in the world for other languages.
|
|
I'll answer any questions you need answered if you decide to fork the code to
|
|
create a similar site for a different language, and I'll also entertain the
|
|
idea of patching the pronoun.is codebase to support rending pages in different
|
|
languages as long as it doesn't make the code substantially more complicated.
|
|
|
|
Even if we add I18N support to the code, other language versions of the site
|
|
should have their own domains names (ideally with clever TLD puns like
|
|
pronoun.is has for english!)
|
|
|
|
(This was discussed in issues #13, #14, and #66)
|
|
|
|
### Can we change the example sentences?
|
|
|
|
Probably not, sorry, I really like these ones! Maybe in the future we can add
|
|
multiple different example sentence sets, though.
|
|
|
|
### Can we add pronunciation guides?
|
|
|
|
The short answer is, this is very hard! I'd love to have them if someone can
|
|
come up with a design for how to do this that'd work (including the logistics
|
|
of hosting media files and stuff).
|
|
|
|
(This was discussed in issues #43 and #80)
|
|
|
|
### Can we add pluralization support (i.e. themself vs themselves)
|
|
|
|
All of the ways I can think of to do this are pretty ugly (both visually
|
|
and in the code) so I'm pretty reluctant to do it. That's not an absolute no,
|
|
but any proposed solution would need to keep the pronouns database simple
|
|
enough that non-programmers can edit it and keep the URLs short, pretty, and
|
|
readable to humans as a sentence if you take all the punctuation out.
|
|
|
|
## License
|
|
Copyright © 2014-2018 Morgan Astra <m@morganastra.me>
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>
|
|
|