Skip to content

Frequently Made Suggestions

Kevin Granade edited this page Feb 3, 2021 · 31 revisions

This is a list of frequently made suggestions, and the current stance on how viable they are. Broad categories are “This is already implemented”, “Someone is working on it now”, “This will go in as soon as someone implements it”, “This doesn’t fit the main game, but would be fine for a mod that ships with the game”, “We might add support for it to the code, but we won’t/can’t distribute it with the game”, “This isn’t reasonable to implement”, and “We’re not adding support for this to the code even for a mod”.

Table of Contents

Project Management

We should vote on this: Nope
The project isn’t a democracy, no number of "me too"s or votes is going to change something we’ve decided on.
The method for users to influence development is via debate. This is intentional, not due to laziness.
Debate sidesteps all the nasty problems around deciding who gets to vote and enforcing that everyone gets the right amount of voting power etc. and validates that people actually know what they’re asking for.
A good reason to make a change has more impact than any number of votes. A lot of the issues in this thread are good examples of this
The project is run by Kevin Granade (“owns” the project, final say on features), a small group of core developers who review and merge changes, and a much larger group of contributors who make pull requests on GitHub. There are also translators who are effectively independent and a handful of people with moderation rights on the forums and Discord. Mod authors who host their own mods are also independent.
While we (the core contributors) ask for feedback and discuss issues on the forums pretty regularly, we aren’t asking for a vote or community consensus, just feedback and discussion.
Places where votes and popular support are important are which parts of the game are in most need of bugfixes or new features, sometimes a dev (Kevin included) finds themselves between projects and is just looking for something to improve, that’s when making it clear what needs improvement the most can make things happen.
Steam Greenlight, other app stores: not opposed, but we aren’t doing it or endorsing it either.
Many of the core developers, Kevin included, are actively hostile to Steam, mostly due to their encouragement of DRM.
Even with that aside, it’s just a ton of work for not that much benefit from the project’s point of view. If someone wants to integrate with some packaging system, even whatever Steam uses, they can feel free to PR it, but we're not aware of any devs being interested in anything except packaging the game for linux repositories.
You should add a: Yes, in general, if someone is willing to do the work
This game is open-source, welcomes contributors, and is highly customizable. Aside from certain items on the list below, most suggestions for additions are going to get approved, either in the vanilla game, or in a mod. The tricky part is finding a contributor to add the item.
The FMS list is here because some ideas have complicated reasons why they're not going to be accepted, or why they'll be accepted but not anytime soon. For most other ideas, they'll get accepted as soon as someone puts forth a contribution of sufficient quality and there's no need to put anything on this list.

Game Features

Performance

Improving Performance via Multithreading: Not just no, but hell no.
several key developers (including Kevin) already have horror stories about debugging threadlock races that have a 3+ hour run time to reproduce for their day jobs and are extremely insistent that they do not want to take on that kind of debugging for their free time hobby. So adding multithreading is a non-starter, because it will substantially shrink the pool of talented developers who will contribute code changes.
multithreading massively increases the overhead of maintaining the game. that's an ongoing overhead that just never goes away, it worms its way into every part of the system. for example, if anything but thread #1 wants to touch a data structure, that data structure must now be threading-safe and/or protected by locks
also, we use mingw for windows builds, it turns out mingw does not have working POSIX locking primitives. (if you do multithreaded on mingw, you abandon linux portability and use windows locking primitives). This is another huge maintenance burden.
problem #3 is that multithreading doesn't get you performance improvements as fast as almost anyone thinks it will. to break that down, threading is relatively good for throughput, but it's hard to use it to improve latency. as it turns out, user-facing programs almost never care about throughput, they only care about latency, so that kind of sucks. so for example, one of the expensive things we do is calculating FoV, it turns out it's what's called embarrassingly paralleizable, if a little tricky. i.e. you can break it up into 8 almost entirely independent jobs. The catch is, that task is actually dominated by cache misses instead of computation, and multithreading makes that worse, because you have to ship the input and output data aound to the various CPUs. so splitting that task up is relatively easy, but I'm not at all certain that doing so would make it any faster.
we had some mystery regressions and some not-so-mystery regressions since 0.E, subsequent improvements have clawed all that performance back and more. so we're in pretty good shape now
which brings me to the "soft" problems with multithreading. say we do get good multithreaded optimizations and performance increases linearly with cores (so much lolnope, performance almost always increases with diminishing returns). I develop on two systems, one has 8 functional cores and the other has 12 functional cores. In the perfect multithreading case, there's a 50% performance difference between the two systems, so a code change with performance that is barely tolerable on the 12 core system is untenable on the 8 core system.
keeping dda single threaded helps keep me (and the other developers) honest, because it narrows the gap between the best and worst systems available. it also narrows the gap within the userbase, including extreme cases where people are still on single or dual core CPUs
finally there's the opportunity cost issue. for the effort of multithreading key parts of the game, we can put a hell of a lot of investment into more generally applicable optimization. there's a hell of a lot of cache coherency and algorithmic optimization we have planned that we haven't gotten around to yet. Optimizing the code would result in some sophisticated and finely tuned code we have to maintain, but we don't have to worry about the rest of the code being hard to maintain
that's the worst thing about multithreading IMO, as soon as you have multiple threads, you have to start worrying about thread safety throughout your code
We should be able to turn off z-levels: No.
Z-levels became a mandatory feature in 0.E experimental in order to support ground vehicles moving up and down ramps. Having z-levels be optional was a large maintenance burden on the developers, and turning off z-levels breaks vehicle ramps.
There has been an extensive optimization effort in the fall of 2020 to bring back performance, and it's been mostly successful. Current experimentals should run faster with z-levels on than 0.E runs with z-levels off.

Multiplayer

This has come up many times https://discourse.cataclysmdda.org/search?q=multiplayer, and it simply can not be added to DDA.
The game loop of DDA includes a large number of activities that pass a large amount of time with no or minimal player input.
Some have proposed requiring coop mode, but that doesn't change the fact that there are huge number of scenarios where a player gets stuck with nothing to do for an extended amount of time.
This isn't just the obvious things like crafting and sleeping, but simply moving around tactically and examining the inventory and examining surroundings and menu interaction are not streamlined for short turn times. This has implications for every part of the game, and I am not interested in making those adjustments.
The synchronization issues go much deeper than you seem to think they do, and resolving them would require overhauling most of the core game code.
I'm not interested in dealing with the security issues inherent in multiplayer network support.

Rogue Like

‘Fixing’ savescumming (in either direction): no.
People periodically point out places where savescumming breaks some part of the game, and likewise people point out “savescumming features” they want in the game. The answer to both is no.
If you encounter a bug while savescumming, you need to reproduce it without the savescumming.
Savescumming is not a normal part of the game, and there is no intention of ever adding features that facilitate it, like auto-backup of saves, tracking multiple saves, or the like.

Player abilities

Psychic powers: mod only
Not happening, it simply doesn’t fit the theme of the game.
However, we’d be happy to have support for it in the code so that a mod can have psychic powers.
Magic powers: mod only
Not happening, it simply doesn’t fit the theme of the game.
However, the Magiclysm mod is distributed with the game and is very extensible in JSON to support other systems of magic.
Poop and related bodily functions: NO
No, just no, not even in a mod.
Hygiene facilities may become an issue with larger faction bases, and there may be some kind of optional furniture to allow collecting urine and manure for use in crafting and farming.
Bathing/accumulating scent: mostly no
Every way we look at it, this seems like it would mostly be a pain to deal with for the player and not fun if it simply accumulated over time.
One approach that might work would be specific monster attacks that make your scent stronger that you’d have to deal with somehow.
Craftable Automatic Weapons: mostly no
We limit crafting for the most part (exception, see cars) to things a single survivor with limited tools can create, and every reasonable plan for automatic action guns I’ve seen has required rather extensive tooling that’s not available to the survivor (metal folding/rolling machines, presses, drill presses).
The absolute closest thing to an automatic weapon I’ve been able to come up with that would be reasonable to craft is an old-school Gatling gun, and a motor for same to up the rounds per minute.
At some point in the future we might build up tooling to the point where automatic weapons manufacture becomes feasible, at that point we can revisit this.
For further discussion on the subject, see https://github.com/CleverRaven/Cataclysm-DDA/issues/10787
Addendum, the Luty-pattern SMG, which should be craftable in dda: https://github.com/CleverRaven/Cataclysm-DDA/issues/22688
Disassemble guns into components for repair or reassembly into new guns: mod only
This is not an issue with how things could or should work and more of an issue with extremely poor return on investment.
Enumerating all the parts of every gun would be a huge amount of data overhead, the code overhead isn't actually that high.
The situation where you have enough guns that you'd have a stock of swappable parts that you could make a really good gun out of, but don't just have a good gun would be vanishingly rare.
We don't have and aren't interested in having any scenarios where guns wear out in ways that you need a stock of replacement parts.
If you want to make a game that's about collecting parts and swapping them around, you streamline the parts and exaggerate the benefits of :The few cases where you can do something meaningful like a calibre swap or a full auto conversion can be handled in a more targeted way with gun mods.
An extraordinarily dedicated modder could hack some of this kind of thing in with crafting recipes and gunmods, if they wanted to work with us on that process we could consider limited code support to help out.
“Enhancing” or “modding” melee weapons: ok for a mod
People frequently suggest that we add a system where melee weapons can have mods attached to them like guns can. There are two problems with this. First no one has seen a sensical suggestion of what these mods would be outside of fantasy type things. Second, the mod system for guns is TERRIBLE and shouldn't be duplicated. Someone would have to come up with something much better before it would get added.
The damage melee weapons cause is a complex combination of dynamic leverage as they are swung, weight distribution, and the interaction of the striking surface(s) with the target, and that doesn’t even get into the complexities of maneuvering past a targets defenses without opening your own guard.
Recover liquids from the ground: No interest/wouldn’t work well
This keeps being suggested, but it’s just not reasonable to recover spilled liquids from the ground and then get any kind of use out of them, since in general they’d be so adulterated by whatever would get mixed in with them that they wouldn’t be fit for any purpose.
Recovering specific liquids with specific properties might be acceptable, if there is some ultra-valuable liquid that gets spilled and had some special method of recovery and filtering.
Dual-wielding weapons: Not practical
"dual wielding" as in holding a pistol in each hand and firing both simultaneously is NOT going to be effective. It will hopefully be added, but when it does it will be ludicrously ineffective because of penalties. :The rationale for why this is so have been well-outlined already at https://discourse.cataclysmdda.org/t/dual-wield/1268 and there's no need or desire for further discussion. This will probably be represented in a very high rate of accumulation of recoil if you try to do this, most likely paired with an accuracy penalty.
Likewise, wielding and attacking with two melee weapons isn’t going to have any benefit over wielding a single melee weapon in both hands, either you’re going to be able to attack faster and deal more damage with the same weapon, or you’d be able to use a larger, more damaging weapon at the same speed and much more damage per strike. Attacking with one weapon and defending with another has a completely different set of trade-offs, and might be overall beneficial, especially if one of the items is very good at defending, like a shield.
“holding something in your off-hand” is something that will be supported
If you’re holding something in your off hand and a gun (even a small pistol) in your primary hand, you’ll have a penalty assessed due to lack of stability. Probably based on the weight/volume of the carried item, so e.g. a small flashlight or a small melee weapon might have a minimal penalty, but another pistol is relatively heavy and might cause you problems.
Along with adding support for holding items in the off-hand, we’ll get stricter about tracking how many free hands you have to perform actions, and automatically perform the actions needed E.g. if you want to light a stick of dynamite and throw it while you are wielding a gun, the actual actions performed will be:
'a’ctivate dynamite ->
put up gun, take out dynamite, take out lighter, light dynamite, put up lighter
(you end up holding dynamite (lit) in your primary hand)
't’hrow dynamite ->
throw dynamite, draw gun
You may notice this sort of thing will “waste” some time by performing unnecessary actions sometimes, for example maybe you want to light and throw several sticks of dynamite in a row, in that case you’ll want to holster the gun first to avoid triggering the item swapping stuff.
On the other hand, this buffs pistols relative to rifles or shotguns, as it’s much faster to holster/draw a pistol (especially if you have a holster)
Even for simple stuff, like opening a door, if you have both hands occupied, it will put up an item, open the door, take out the item again.
When this happens (which will be a while, it’s pretty invasive and complicated), we will be VERY careful to not cause disruptions to doing things simply, with the extra actions just costing in-game time. If you’re in a hurry though and need to make every second count, it will be better to think ahead about a sequence of actions and try to minimize this sort of overhead.
Playing as a robot/playing as an intelligent dog: Planned, no release set
Some people want to play as a robot, or an android, or a brain in a jar piloting a robotic body, or as a dog. The developers want to allow people to do all of that. Unfortunately, there's a lot of changes that need to be made to get from the current state of the code to that highly desirable end-point. Some changes have already been made, but there's nothing really visible yet.
Bring back ICBM launch: Mod only
There used to be a partially implemented feature where you could break into an ICBM silo and hack the computer systems, then launch a missile at some target on the overmap. The results were incredibly underwhelming and didn't remotely represent the damage a many-kt warhead would cause, and was a frequent source of bugs, so it was removed.
It's not a valid idea to bring it back for a number of reasons. One, the very large scale map destruction it would require would be a lot of work to implement, for incredibly low tangible benefit. Two, the feasibility of a survivor breaking into a nuclear silo and successfully launching a missile is negligible, the most likely situation is that the silo would have been put into some kind of lockdown or even destroyed once the staff deemed it infeasible to continue standing by, rendering a launch literally impossible, but even if that didn't happen, navigating the security mechanisms and failsafes the launch system would be expected to have is so difficult as to be effectively impossible. Three, the impact of an ICBM launch is the wrong scale for the game, if the desired feature is "destroy an area 150m across from a distance", which is what the previous feature amounted to, there are numerous options for achieving that without the ludicrous and impossible overkill embodied in a nuclear strike. For example, an artillery or even mortar barrage has the capability of leveling a 100m or even larger area, and is a million times more feasible to acquire than a nuclear launch.

Electrical power transmission

This covers several sub-suggestions that do or do not work for various reasons.

Bring back a municipal power grid: not feasible to implement
This isn’t feasible for several reasons. First, the assumption is that the grid is wrecked. After a disaster of this scale, it frequently takes dedicated teams of technicians working overtime days to weeks of work to restore the grid to working function, and that’s with near-unlimited resources, no additional disasters happening, and specific restoration plans in place. For a survivor it would be simply impossible, and even for teams of survivors it would take a prohibitive amount of time to do, and it would be much easier to simply cobble together a rough point-to-point power transmission system.
Second, this would be extremely difficult to support in the game engine because once you surpass a certain scale you need to keep every connected electrical device loaded and periodically processed in order to keep track of power usage. The only way I could see this working is if you ran through a series of missions to reclaim a town, and as part of the missions some power generation plant was assembled, and the town was wired up for it. At that point we could hand-wave the power usage tracking because the faction would be running the plant, not the player.
Short-range power transmission (scale of a single building): Partially implemented
Currently you can hook up multiple vehicles with jumper cables so they can transmit power, and this even works if some of the vehicles aren’t in the immediate area.
The plan is to extend this by building “appliances” that you can hook into this grid, but you interact with them using the construction and menus brought up with 'e’xamine instead of going through the vehicle menus. The main thing holding this kind of thing back is generators, which for game balance should make lots of noise and attract monsters, but monsters aren’t very good at dealing with this yet (see hordes).
In addition to "appliances", there may also be "facilities". Again, under the hood, facilities are going to be related to vehicles (admittedly, stationary vehicles) but are going to be built via the construction menu and interacted with as collections of terrain and furniture. Facilities will hopefully allow for medium sized, powered buildings.

User interface

Nestable container model for inventory: Will go in as soon an there’s a good implementation/someone is working on it.
KorGgenT implemented this in spring 2020 and although there are still some teething issues, it's working fairly well and will be a headline feature for the 0.F release.
This is a really old and good one, the problem being the most straightforward implementation of it where you manually manage all those containers is a terrible interface. (see DF adventure mode) For this to go in, it must default to the inventory system doing all the work for the player, and the player only specifies what goes where occasionally.

Monsters

Separate limbs for monsters: not useful
The suggestion is usually along the lines of, “add limbs to monsters so they can be crippled”. The problem with this approach is you can add crippling attacks much more easily by just applying a crippling effect to the monster, there’s no need to track per-limb HP for monsters to make it happen. Also, a limb system for monsters would be much more complicated than the one for players, since monsters have a more variable number of limbs, so we couldn’t even just use the code from the player-based system.
Targeted attacks on monster body parts: not useful
A similar suggestion is to allow the player to target specific monster body parts in order to achieve specific effects such as stunning with headshots or slowing by hitting the legs. A much simpler system is to have the player declare the effect they want rather than something indirect like targeting a limb, then we can be more flexible about how the attack plays out based on the combination of player abilities, weapon used, and monster type.
For a better outline on what we DO want to do, see https://github.com/CleverRaven/Cataclysm-DDA/issues/1565
Using zombie parts: mod only, mostly no
From a game balance perspective zombies are very abundant and should only be used under limited lore-friendly circumstances in consumables, trivial early items or with lasting risks and drawbacks.
Conversations with monsters and other things: yes, planned for 0.G
There is an extensive and sophisticated system for talking with NPCs, but you can't have a conversation with your genetically modified, super-intelligent dog, nor with your intelligent sword from Magiclysm, nor with your car.
Work is being done to enable all these conversations. It's not hard work at this point, it's just tedious bits that need to get done.
Multi-tile monsters: desired but difficult
There are substantial technical challenges to a monster that exists on more than 1 tile at the same time, mostly dealing with pathfinding. As people come up with solutions to these challenges, multi-tile monsters will become more likely.
Some multi-tile monsters, such as giant snakes, have fewer technical challenges and might arrive sooner.

Vehicle additions

Caterpillar tracks/tank treads: As soon as someone gets around to it.
The way treads would work is they’d be very tough and have a very large amount of traction, along with a somewhat incidental property of needing to take up several squares. Also if any section of a track were destroyed, it would render the entire unit non-working, and probably keep your vehicle from moving at all.
Things that need to be implemented before treads proper are:
  • Traction system, where there’s a trade-off between amount of traction and amount of friction, so higher traction means you have more grip, especially on loose surfaces like mud or sand, but you have higher friction, so it reduces your top speed and fuel efficiency. This is mostly implemented.
  • A way to handle installing and destroying multi-tile components in vehicles. This is partially implemented.
Walker legs: mod only, if someone can figure out how to make it work
This doesn’t really fit in the game, vehicle sized robotics balancing and walking around is too far fantasy scifi for the game.
Someone is going to have come up with physics formula to convert engine power to motive speed for walker legs before this can be implemented. Vehicles are probably going to have multiple z-levels for most walker leg designs.
I should be able to run my APC on solar panels
A modern solar/electric car that can even approach continuous locomotion is massively under weight compared to a standard car, and even then tends to only be tested in highway conditions where stops and starts are nonexistent. Even if we crank up the efficiency of cells to their theoretical maximum (by roughly 5x, which would be a reasonable thing to do with “quantum cells” from labs), we’re possibly reaching enough power to operate a small car at a reasonable duty cycle, but its not remotely reasonable to run a heavy utility vehicle from solar, much less an armored vehicle.
There should be helicopter flight simulators in military bases so we can learn to fly helicopters: No but yes
With the introduction of helicopters, people are upset that they can't learn to fly them but have to start the game with the appropriate trait. I've done research on the early aircraft pioneers, and teaching yourself to fly involves crashing, a lot, and hopefully non-fatally.
As a work-around for that, people have proposed that military bases have flight simulators. This is kind of reasonable, in that room-sized flight simulators with haptic feedback are a thing in the real world, but it's not happening because those things require a level of power and maintenance infrastructure that just isn't present after the Cataclysm, plus they have cryptic user interfaces that mean some random survivor can't just walk up to them and start the "Flight Training 101" simulation.
What would be more reasonable and possible would be finding a high end personal computer with a flight controller rig and a high end flight simulator like MS Flight Simulator 8. I've known a dozen or more private pilots in my life, and every one of them had a system like this so they could practice flying even when they couldn't afford to take their private plane up. A high end PC is certainly something that your average survivor can set up, and you can run them off a scavenged gasoline engine set up as a small electrical generator. So this is definitely a solution, as soon as someone gets around to writing it.
We should be able to modify helicopters and other aircraft: Qualified yes
Small modifications of aircraft would be fine, but significant changes (adding frames, changing the engine, etc) basically mean that you have a new aircraft design and you need to run some test flights to make sure that your new design is airworthy.
For this to happen, we need code to detect significant changes in aircraft, code to simulate the chance that your new design isn't airworthy, and code to make you fall out of the sky during your test flights. None of that is hard, but the current vehicles maintainer has other tasks to work on and no one else is offering to step up to the plate.
We should be able to make airplanes/autogyros/hot air balloons/blimps/submarines: Yes
All of these have been suggested. All of them would be possible if someone wrote a bunch of code to enable them.
Vehicles should be able to span multiple z-levels: planned for 0.G
Vehicles can already span multiple z-levels in the experimentals leading to 0.F, with a ground vehicle moving along a ramp from z0 to z+1 being an example. What they can't do is have two vehicle frames with the same (x,y) co-ordinates but different z co-ordinates. This will hopefully get fixed for 0.G (it's a huge amount of work inside the vehicle code), and people will be able to build double-decker bus deathmobiles.

Gun Behavior

Hit multiple targets with a shotgun: Kind of yes, but really no.
For some examples of 12-gague 00-shot patterns, take a look at http://www.theboxotruth.com/the-box-o-truth-20-buckshot-patterns/ 26
tl;dr at 45 yards, which is outside the maximum effective range of the round in the first place (I’ve seen anywhere from 25 yards to 35 yards claimed), the spread was between 27 and 33 inches. Even at this extreme range, the spread is still less than one in-game square, so you’re effectively never going to hit two targets standing side-by-side. What might happen is you get some kind of “graze” one one target, and the shot that didn’t hit the target will continue and possibly hit another target behind it.

Environment

Bring back acid melting items: Grossly unrealistic
There’s no level of acid strength where it makes sense for it to dissolve large volumes of items on the ground, but isn’t invariably fatal on contact with a survivor. If someone has some actual facts about how acids work when in contact with large volumes of various substances, including flesh, that contradict my understanding of this, we can talk, but referring to the previous state of the game or other games isn’t going to get you anywhere.
The previous mechanic where it was sort of dangerous to the survivor but massively damaging to items was a game-ism, and it’s most likely not coming back. The popularity point of view seems to be a wash as well, because there seem to be at least as many people strongly in support of removing item-melting as there are who want it back.
Bring back acid rain: Partially
The old implementation of acid rain had a massive world consistency flaw, given the lethality of acid rain when exposed to it, and its frequency, nearly every animal on the planet should be dead after about a month. This includes most of the invasive creatures, because it would kill them too. There are two options for mitigating this issue. One is to make it incapacitating instead of lethal, in which case animals would be harmed by it, but not killed, so in general populations would be unaffected. The other is to make it a highly localized or rare phenomenon, and kill any creatures (and probably plants) in the area when it occurs, whether the player is there or not. Again, if it’s rare populations would recover over time and be mostly unaffected. With the second event though, you’d get cool trails of death scattered around in your game world.

Failed Rationalizations

These aren’t suggestions, but arguments that comes up in support of suggestions or alterations to the game. They come up constantly so I’m putting a note about them here.

“Seeing as we have nanobots and power armors…”, “We have teleportation, so it’s not unreasonable to have…”: :Irrelevant
If you make this argument, you will not only not make the intended point, since the argument is nonsensical, but you will also damage your credibility with me personally, and I suspect with the other contributors as well. I am absolutely sick of reading this, and I am even more sick of responding to it, so I’ll just refer to this post from now on.
The supposed lack of “consistency” between super-science elements of the game and mundane elements of the game is intended. The setting of the world is current-day New England (America if you don’t recognize the region name), with isolated science fiction elements, such as super-science items that generally appear in “secret research labs”* or deployed with military units. The existence of super-science items does not imply that every aspect of daily life is imbued with elements of fantastical science.
* Yes we do a fairly bad job of labs feeling like “secret research facilities”, but bear with us and/or make suggestions about making them feel more like that, that is the intent.
"Player can craft a X, so they should also be able to craft a Y"
This kind of argument is invalid for several reasons.
Just because there’s a contradiction i.e. “cordless drills and gunsmithing tools are equally hard to make, but we can only make cordless drills” doesn’t imply that the correct action is allowing crafting of gunsmithing tools, it’s equally likely that craftable cordless drills were a mistake.
This argument generally has a tenuous or non-existent relationship between the items in question. Frequently it’s an assertion that X is “complicated” and Y is either “simple” or “also complicated”, this is not sufficient for craftability of X to imply craftability of Y.
Hoisted from a topic where it came up again: https://discourse.cataclysmdda.org/t/i-cant-see-the-difference-between-firearm-and-gunsmith-repair-kits
Clone this wiki locally