You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardexpand all lines: README.md
+29-21
Original file line number
Diff line number
Diff line change
@@ -144,7 +144,8 @@ This license should be "fire and forget". Just set the price, slap it on uploa
144
144
## Consequences of these goals
145
145
146
146
Let's list out and number the target features for easy reference (TODO: auto-link):
147
-
**Goals:
147
+
148
+
**Goals:**
148
149
1. Source-available
149
150
2. Anyone can contribute to or fork a project
150
151
3. Modifications to the code must be disclosed
@@ -183,9 +184,9 @@ the royalty distribution table would look like this:
183
184
| Contributor D | 20 |
184
185
| Contributor E | 20 |
185
186
186
-
*Total royalty cost: 7%
187
+
*Total royalty cost: 7%*
187
188
188
-
Another contributor adding the same amount of value to the project would just add another row to the table and raise the total royalty by 20% to 8.4% (from $\frac{\text{shares after}}{\text{shares before}} = \frac{20*6}{20*5} = \frac{120}{100}= 1.2 \Rightarrow 1.2 * 7\% = 8.4\%$)
189
+
Another contributor adding the same amount of value to the project would just add another row to the table and raise the total royalty by 20% to 8.4% (from $`\frac{\text{shares after}}{\text{shares before}} = \frac{20*6}{20*5} = \frac{120}{100}= 1.2 \Rightarrow 1.2 * 7\% = 8.4\%`$)
189
190
190
191
| name | shares |
191
192
|:------------------:|:------:|
@@ -196,7 +197,7 @@ Another contributor adding the same amount of value to the project would just ad
196
197
| Contributor E | 20 |
197
198
| Contributor F | 20 |
198
199
199
-
*Total royalty cost 8.4%
200
+
*Total royalty cost 8.4%*
200
201
201
202
While this should leave all contributors happy, as they were each getting $20/100 * 7\% = 1.4\%$ of revenue as royalties before, and $20/120 * 8.4\% = 1.4\%$ of revenue as royalties after, there is clearly an effect on the user of the licensed software, who sees their cost go up 20%.
202
203
@@ -217,7 +218,7 @@ If we start here:
217
218
| Contributor D | 20 |
218
219
| Contributor E | 20 |
219
220
220
-
*Total royalty cost: 7%
221
+
*Total royalty cost: 7%*
221
222
222
223
And add "just" sixty-seven more equal contributors:
223
224
@@ -231,15 +232,16 @@ And add "just" sixty-seven more equal contributors:
Using the project costs more than 100% of revenue, and the end user gets no revenue themselves, even needing to pay more money than the revenue they bring in. This doesn't seem right, as even if the value of the software has gone up by a factor of 14, the end user is still doing valuable work they should be getting money for.
Round to 1329 shares. Note that the fact that this is rounded means all calculations must be done from the number of shares. The final "total royalty cost" is imprecise (6.997901...% rather than 7%).
244
246
245
247
| name | shares |
@@ -252,12 +254,12 @@ Round to 1329 shares. Note that the fact that this is rounded means all calcula
252
254
|||
253
255
| End User | 1329 |
254
256
255
-
*Total royalty cost: ~7%
257
+
*Total royalty cost: ~7%*
256
258
257
259
>[!note]
258
260
>The "End User" name is not replaced with an actual name when this table is placed in a real project. It is a stand-in for "Whoever uses this project under this license".
259
261
260
-
Then when we add a new contributor, the formula for total royalty cost becomes $\frac{\text{sum of contributor shares}}{\text{sum of all shares}} = \frac{20*72}{20*72 + 1329} = \frac{1440}{2769}= {\sim}0.52 = {\sim}52\%$
262
+
Then when we add a new contributor, the formula for total royalty cost becomes $`\frac{\text{sum of contributor shares}}{\text{sum of all shares}} = \frac{20*72}{20*72 + 1329} = \frac{1440}{2769}= {\sim}0.52 = {\sim}52\%`$
261
263
262
264
| name | shares |
263
265
|:---------------:|:------:|
@@ -270,16 +272,19 @@ Then when we add a new contributor, the formula for total royalty cost becomes $
270
272
|||
271
273
| End User | 1328.6 |
272
274
273
-
*Total royalty cost: ~52%
275
+
*Total royalty cost: ~52%*
274
276
275
-
With each contributor individually getting $\frac{\text{contributor shares}}{\text{sum of all shares}} = \frac{20}{2769} = {\sim}0.0072 = {\sim}0.72\%$ of revenue
277
+
With each contributor individually getting $`\frac{\text{contributor shares}}{\text{sum of all shares}} = \frac{20}{2769} = {\sim}0.0072 = {\sim}0.72\%`$ of revenue
276
278
277
279
At this point, you may notice that each contributor's fraction of revenue just went down. This makes sense if you consider the revenue before the contributions and after the contributions as two different values $R_1$ and $R_2$, with $R_2$ being larger due to the value increase of the project allowing the end user to bring in more revenue.
278
280
279
281
Everything is fine if an early contributor is bringing in the same amount of money before and after the later contributions. (Again note that these calculations must be done with the numbers of shares, as the percentage values are approximate)
280
-
$$\frac{\text{contributor's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{contributor's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{20} * 2769}{\cancel{20} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}$$
282
+
283
+
$`\frac{\text{contributor's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{contributor's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{20} * 2769}{\cancel{20} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}`$
284
+
281
285
The same goes for the end user:
282
-
$$\frac{\text{end user's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{end user's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{1329} * 2769}{\cancel{1329} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}$$
286
+
287
+
$`\frac{\text{end user's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{end user's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{1329} * 2769}{\cancel{1329} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}`$
283
288
284
289
If the contributions make the revenue go up by a factor of ~1.94, the math works out.
285
290
@@ -299,26 +304,28 @@ This is good because it allows us to treat every sub-project inclusion as just a
299
304
Now all that's left is the actual mapping of shares from the sub-project to the main project.
300
305
For example, let's say there are two existing contributors to a project, and they want to include a sub-project
301
306
302
-
**Main project:
307
+
**Main project:**
303
308
304
309
| name | shares |
305
310
|:-------------:|:------:|
306
311
| Contributor A | 20 |
307
312
| Contributor B | 20 |
308
313
|||
309
314
| End User | 60 |
310
-
*Total royalty cost: 40%
315
+
316
+
*Total royalty cost: 40%*
311
317
312
318
313
-
**Sub-project:
319
+
**Sub-project:**
314
320
315
321
| name | shares |
316
322
|:-------------:|:------:|
317
323
| Contributor C | 8 |
318
324
| Contributor D | 2 |
319
325
|||
320
326
| End User | 90 |
321
-
*Total royalty cost: 10%
327
+
328
+
*Total royalty cost: 10%*
322
329
323
330
Let's put these in one table for convenience:
324
331
@@ -351,7 +358,8 @@ Before these tables can be combined properly, we need to make the end user share
"This license is the LGPL license, but with the additional condition that you need to pay a percentage of your total annual revenue to the contributors of this project with as defined in the included `royalty_distribution_table.csv` file."
406
414
407
415
408
-
> [!Caution] Disclaimer
416
+
> [!Info] Disclaimer
409
417
> I am not a lawyer.
410
418
411
419
### The specific behavior we want out of the license:
@@ -494,4 +502,4 @@ A. How's that strategy been working out with taxes / global warming / this exact
494
502
495
503
1. Get feedback on this document
496
504
2. Create a rough draft of the license itself
497
-
- As I am not a lawyer, I can only assume that if I write it myself, it will be wrong
505
+
- As I am not a lawyer, I can only assume that if I write it myself, it will be wrong
0 commit comments