Skip to content

Commit

Permalink
Merge branch 'main' of github.com:propensive/adversaria
Browse files Browse the repository at this point in the history
  • Loading branch information
propensive committed Dec 12, 2024
2 parents 36e2886 + 6035e8b commit 1d68421
Show file tree
Hide file tree
Showing 5 changed files with 93 additions and 84 deletions.
88 changes: 88 additions & 0 deletions .github/contributing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
<img src="/doc/images/200x200.png" align="right">

# Contributing to Adversaria

Firstly, thank you for taking an interesting in contributing! Adversaria is an
open-source project, and welcomes contributions in the form of feature code,
bug reports and fixes, tests, feature suggestions and anything else which may
help to make it better software.

Adversaria is one of a large number of
[Soundness](https://github.com/propensive/soundness/) projects, which benefit
from having consistent integrations and automated admin tasks. These will be
developed across all projects simultaneously, and there's a roadmap for
improving them. So we are not currently looking for enhancements in this area,
but you're welcome to enquire.

## Before Starting

It&rsquo;s a good idea to [discuss](https://discord.gg/MBUrkTgMnA) potential
changes with one of the maintainers before starting work. Although efforts are
made to document future development work using the [issue tracker](/issues), it
will not always be up-to-date, and the maintainers may have useful information
to share on plans.

A bad scenario would be for a contributor to spend a lot of time producing a
pull request, only for it to be rejected by the maintainers for being
inconsistent with their plans. A quick conversation before starting work can
save a lot of time.

If a response is not forthcoming in the [Discord
chatroom](https://discord.gg/MBUrkTgMnA), open a [GitHub
issue](https://github.com/propensive/adversaria/issues) or contact the project
maintainer directly _but publicly_. Please __do not__ contact the maintainer
about technical issues privately, as it misses a good opportunity to share
knowledge with a wider audience, unless there is a good reason to do so. Jon
Pretty can usually be contacted [on X](https://x.com/propensive).

All development work&mdash;whether bugfixing or implementing new
features&mdash;should have a corresponding issue before work starts. If you
have commit rights to the `propensive/adversaria` repository, push to a branch named
after the issue number, prefixed with `issue/`, for example, `issue/23`.

## Contribution standards

Pull requests should try to follow the coding style of existing code in the
repository. They are unlikely to be rejected on grounds of formatting, except
in extreme cases. Adversaria does not use automatic code-formatting because it
has proven to produce unreliable and unsatisfactory results (and furthermore,
hand-formatting is not particularly laborious).

Unfortunately an official coding style guide does not yet exist.

Any code that is inconsistently formatted will be tidied up, if necessary, by
the project maintainers, though well-formatted code is appreciated.

## Code reviews

Pull requests should have at least one review before being merged. When opening
a pull request, contributors are welcome to suggest a reviewer. Pull requests
should be left in _draft_ mode until they are believed to be ready for review.

The preferred method of reviewing a pull request is to schedule a video call
with the reviewer and talk through it. It is much faster to share understanding
between the contributor and reviewer this way.

For code contributions, we prefer pull requests with corresponding tests, if
that's appropriate. Changes which break existing tests, however, are likely to
be rejected during review.

## Reporting issues

New issues are welcome, both as bug reports and feature suggestions. More
precision is preferable, and the clearest and most detailed reports will most
likely be addressed sooner, but a short report from a busy developer is still
preferred over a bug we never hear about. We will ask for more detail in triage
if it&rsquo;s needed.

## Conduct

Contributors and other participants in online discussions are expected to be
civil, on-topic and to nurture a pleasant development environment for all
Adversaria&rsquo;s users. Individualism is valued, and nobody should feel
constrained in how they express themselves, as long as they adhere to the
expectations.

Propensive O&Uuml; have some powers to address conduct issues, but that will
start with an informal conversation, and without prejudice.

File renamed without changes.
16 changes: 4 additions & 12 deletions readme.md → .github/readme.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
[<img alt="GitHub Workflow" src="https://img.shields.io/github/actions/workflow/status/propensive/adversaria/main.yml?style=for-the-badge" height="24">](https://github.com/propensive/adversaria/actions)
[<img src="https://img.shields.io/discord/633198088311537684?color=8899f7&label=DISCORD&style=for-the-badge" height="24">](https://discord.gg/7b6mpF6Qcf)
[<img src="https://img.shields.io/discord/633198088311537684?color=8899f7&label=DISCORD&style=for-the-badge" height="24">](https://discord.com/invite/MBUrkTgMnA)
<img src="/doc/images/github.png" valign="middle">

# Adversaria
Expand All @@ -17,17 +17,9 @@ _annotations_ in Scala, by making them available through _typeclass interfaces_.
- no macro code is required to use annotations


## Availability Plan
## Availability

Adversaria has not yet been published. The medium-term plan is to build Adversaria
with [Fury](https://github.com/propensive/fury) and to publish it as a source build on
[Vent](https://github.com/propensive/vent). This will enable ordinary users to write and build
software which depends on Adversaria.

Subsequently, Adversaria will also be made available as a binary in the Maven
Central repository. This will enable users of other build tools to use it.

For the overeager, curious and impatient, see [building](#building).

## Getting Started

Expand Down Expand Up @@ -104,7 +96,7 @@ accessor, such as `_.email`, otherwise the method will not compile.

## Status

Adversaria is classified as __fledgling__. For reference, Scala One projects are
Adversaria is classified as __fledgling__. For reference, Soundness projects are
categorized into one of the following five stability levels:

- _embryonic_: for experimental or demonstrative purposes only, without any guarantees of longevity
Expand Down Expand Up @@ -187,7 +179,7 @@ O&Uuml;](https://propensive.com/).

_Adversaria_ are miscellaneous collections of notes or _annotations_, after which the library is named.

In general, Scala One project names are always chosen with some rationale,
In general, Soundness project names are always chosen with some rationale,
however it is usually frivolous. Each name is chosen for more for its
_uniqueness_ and _intrigue_ than its concision or catchiness, and there is no
bias towards names with positive or "nice" meanings—since many of the libraries
Expand Down
72 changes: 0 additions & 72 deletions contributing.md

This file was deleted.

1 change: 1 addition & 0 deletions doc/lines.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
142

0 comments on commit 1d68421

Please sign in to comment.