Davy Jones
- 37 Posts
- 49 Comments
Davy Jones@lemmy.dbzer0.comOPto Asklemmy@lemmy.ml•What’s something you own that has truly paid for itself?411·3 days agoMy bike is the only thing I can say for certain has paid for itself. If I had paid $1 for each trip I’ve taken on it, I would have spent far more than it cost me.
Davy Jones@lemmy.dbzer0.comOPto Ask Lemmy@lemmy.world•What are your thoughts on how social media impacts our society and interpersonal connections?2·4 days agoI don’t really think social media actually makes people more social in real life and federated platforms are pretty much the same. I also remember reading once that many tech execs don’t let their kids use social media or phones.
Also here’s a few interesting related things I’ve seen:
Davy Jones@lemmy.dbzer0.comOPto Lemmy@lemmy.ml•Piefed finally fixes Lemmy’s ugly post URLsEnglish3·5 days agoBoth URL types are available but I don’t know what the default one will be or if it’s already in effect.
Davy Jones@lemmy.dbzer0.comOPto Ask Lemmy@lemmy.world•Would you recommend Lemmy to others, and if so, what kind of content or communities make it worth it?322·6 days agoI wouldn’t recommend Lemmy to anyone I know. Lemmy feels like a meme aggregator more than a forum or a link aggregator. It probably has it’s own niche of people who like what they can find in it but the people I know seem interested in other things, like local news and sports.
Atheism 1.45K users / month, Religion 9 users / month, religion isn’t gonna fly on Lemmy. You may be as christian as you like but how many times have you been able to talk religion here. And the same goes for any topics that goes against the current group think.
I still use Reddit for niche and polarizing topics. Lemmy feels like groupthink to me, especially about politics — it’s always “Ukraine good, Russia bad” and “Palestine good, Israel bad.” I like hearing both sides, but divergent opinions get smothered here. Imagine an average Christian joining the Fediverse: they’d have to leave many of their beliefs at the door and adapt to the herd, or risk being unwelcome, having posts downvoted to oblivion, and being told to leave. It’s already happened to me a few times with opinions that aren’t welcomed here. It’s a far cry from what Lemmy’s decentralization promised.
Davy Jones@lemmy.dbzer0.comOPto No Stupid Questions@lemmy.world•Is there a way to listen to only the radio topics I actually care about?1·7 days agoI wish that was an option but mainstream media is the only way to get locally relevant news as far as I know.
Davy Jones@lemmy.dbzer0.comOPto No Stupid Questions@lemmy.world•How can I find a post I saw about a local alternative to Perplexity?0·7 days agoAnd with instances blocking each other it may be in an instance I can’t see from this one.
Davy Jones@lemmy.dbzer0.comOPto No Stupid Questions@lemmy.world•How can I find a post I saw about a local alternative to Perplexity?0·7 days agoRight now I can see the posts I have already interacted with, for a moment I thought it would be that.
Davy Jones@lemmy.dbzer0.comOPto No Stupid Questions@lemmy.world•How can I find a post I saw about a local alternative to Perplexity?0·7 days agoNah, it didn’t say anything about perplexity it just felt like that to me. It uses Ollama and some of the LLM services from companies but I saw it on an image, and I don’t remember what the title was.
Davy Jones@lemmy.dbzer0.comOPto No Stupid Questions@lemmy.world•How can I find a post I saw about a local alternative to Perplexity?0·7 days agoDoesn’t sound familiar. I think it had the word sense in it but I couldn’t find it using that word.
Davy Jones@lemmy.dbzer0.comOPto Linux@lemmy.ml•Looking for sites that show popular Linux packages by category and popularity3·8 days agoBrowsing not choosing. I didn’t say I would necessarily swap, just that I like to see other options.
Davy Jones@lemmy.dbzer0.comOPto Voyager@lemmy.world•Any Lemmy web clients that show notifications from multiple accounts at once?English3·9 days agoThanks, that’s what I was looking for. Seems weird that a client I haven’t heard about has the feature but the other more used clients don’t.
Davy Jones@lemmy.dbzer0.comOPto Programming@programming.dev•Which software design principles do you rely on most?0·9 days agoSummary of A Philosophy of Software Design by John Ousterhout Source: danlebrero.com
These are notes by Daniel Lebrero Berna on John Ousterhout’s A Philosophy of Software Design.
Some advice in the book goes against the current software dogma. The current dogma is the result of previous pains, but has now been taken to the extreme, causing new pains.
What the author solves with “Comment-First Development,” others solve with Test-Driven Development. The excuses for not writing comments mirror those for not writing tests.
Key Insights
- It’s easier to see design problems in someone else’s code than your own.
- Total complexity = Σ(complexity of part × time spent on that part).
- Goal of good design: make the system obvious.
- Complexity accumulates incrementally, making it hard to remove. Adopt a “zero tolerance” philosophy.
- Better modules: interface much simpler than implementation (Deep modules).
- Design modules around required knowledge, not task order.
- Adjacent layers with similar abstractions are a red flag.
- Prioritize simple interfaces over simple implementations.
- Each method should do one thing and do it completely.
- Long methods are fine if the signature is simple and the code easy to read.
- Difficulty naming a method may indicate unclear design.
- Comments should add precision or intuition.
- If you aren’t improving the design when changing code, you’re probably making it worse.
- Comments belong in the code, not commit logs.
- Poor designers spend most of their time chasing bugs in brittle code.
Preface
- The most fundamental problem in computer science is problem decomposition.
- The book is an opinion piece.
- The goal: reduce complexity.
1. Introduction (It’s All About Complexity)
- Fight complexity by simplifying and encapsulating it in modules.
- Software design is never finished.
- Design flaws are easier to see in others’ code.
2. The Nature of Complexity
- Complexity = what makes code hard to understand or modify.
- Total complexity depends on time spent in each part.
- Complexity is more obvious to readers than writers.
- Symptoms: change amplification, cognitive load, unknown unknowns.
- Causes: dependencies, obscurity.
- Complexity accumulates incrementally; remove it aggressively.
3. Working Code Isn’t Enough
- Distinguish tactical (short-term) from strategic (long-term) programming.
- The “tactical tornado” writes lots of code fast but increases complexity.
4. Modules Should Be Deep
- A module = interface + implementation.
- Deep modules have simple interfaces, complex implementations.
- Interface = what clients must know (formal + informal).
- Avoid “classitis”: too many small classes increase system complexity.
- Interfaces should make the common case simple.
5. Information Hiding (and Leakage)
- Information hiding is key to deep modules.
- Avoid temporal decomposition (ordering-based design).
- Larger classes can improve information hiding.
6. General-Purpose Modules Are Deeper
-
Make modules somewhat general-purpose.
-
Implementation fits current needs; interface supports future reuse.
-
Questions to balance generality:
- What is the simplest interface covering current needs?
- How many times will it be used?
- Is the API simple for current use? If not, it’s too general.
7. Different Layer, Different Abstraction
- Adjacent layers with similar abstractions are a red flag.
- Pass-through methods and variables add no value.
- Fix pass-throughs by grouping related data or using shared/context objects.
8. Pull Complexity Downwards
- Prefer simple interfaces over simple implementations.
- Push complexity into lower layers.
- Avoid configuration parameters; compute reasonable defaults automatically.
9. Better Together or Better Apart?
-
Combine elements when they:
- Share information.
- Are used together.
- Overlap conceptually.
- Simplify interfaces or eliminate duplication.
-
Developers often split methods too much.
-
Methods can be long if they are cohesive and clear.
-
Red flag: one component requires understanding another’s implementation.
10. Define Errors Out of Existence
-
Exception handling increases complexity.
-
Reduce exception points by:
- Designing APIs that eliminate exceptional cases.
- Handling exceptions at low levels.
- Aggregating exceptions into a common type.
- Crashing when appropriate.
11. Design It Twice
- Explore at least two radically different designs before choosing.
12. Why Write Comments? The Four Excuses
-
Writing comments improves design and can be enjoyable.
-
Excuses:
- “Good code is self-documenting.” False.
- “No time to write comments.” It’s an investment.
- “Comments get outdated.” Update them.
- “Comments are worthless.” Learn to write better ones.
13. Comments Should Describe Things That Aren’t Obvious
- Comments should add precision and intuition.
- Document both interface and implementation.
14. Choosing Names
- Names should be precise and consistent.
- If naming is hard, the design likely isn’t clean.
15. Write the Comment First
- Like TDD, comment-first helps design, pacing, and clarity.
16. Modifying Existing Code
- Always improve design when changing code.
- Comments belong in code, not commit logs.
17. Consistency
- Don’t “improve” existing conventions without strong reason.
19. Software Trends
- Agile and TDD often promote tactical programming.
20. Designing for Performance
- Simpler code tends to be faster.
- Design around the critical path.
21. Conclusion
- Poor designers spend their time debugging brittle systems.
Davy Jones@lemmy.dbzer0.comOPto Programming@programming.dev•Which software design principles do you rely on most?0·9 days agoSummary of Clean Code by Robert C. Martin
Source: gist.github.com/wojtekluCode is clean if it can be understood easily – by everyone on the team. Clean code can be read and enhanced by a developer other than its original author. With understandability comes readability, changeability, extensibility, and maintainability.
General rules
- Follow standard conventions.
- Keep it simple stupid. Simpler is always better. Reduce complexity as much as possible.
- Boy scout rule. Leave the campground cleaner than you found it.
- Always find root cause. Always look for the root cause of a problem.
Design rules
- Keep configurable data at high levels.
- Prefer polymorphism to if/else or switch/case.
- Separate multi-threading code.
- Prevent over-configurability.
- Use dependency injection.
- Follow Law of Demeter. A class should know only its direct dependencies.
Understandability tips
- Be consistent. If you do something a certain way, do all similar things in the same way.
- Use explanatory variables.
- Encapsulate boundary conditions. Boundary conditions are hard to keep track of. Put the processing for them in one place.
- Prefer dedicated value objects to primitive type.
- Avoid logical dependency. Don’t write methods which work correctly depending on something else in the same class.
- Avoid negative conditionals.
Names rules
- Choose descriptive and unambiguous names.
- Make meaningful distinction.
- Use pronounceable names.
- Use searchable names.
- Replace magic numbers with named constants.
- Avoid encodings. Don’t append prefixes or type information.
Functions rules
- Small.
- Do one thing.
- Use descriptive names.
- Prefer fewer arguments.
- Have no side effects.
- Don’t use flag arguments. Split method into several independent methods that can be called from the client without the flag.
Comments rules
- Always try to explain yourself in code.
- Don’t be redundant.
- Don’t add obvious noise.
- Don’t use closing brace comments.
- Don’t comment out code. Just remove.
- Use as explanation of intent.
- Use as clarification of code.
- Use as warning of consequences.
Source code structure
- Separate concepts vertically.
- Related code should appear vertically dense.
- Declare variables close to their usage.
- Dependent functions should be close.
- Similar functions should be close.
- Place functions in the downward direction.
- Keep lines short.
- Don’t use horizontal alignment.
- Use white space to associate related things and disassociate weakly related.
- Don’t break indentation.
Objects and data structures
- Hide internal structure.
- Prefer data structures.
- Avoid hybrids structures (half object and half data).
- Should be small.
- Do one thing.
- Small number of instance variables.
- Base class should know nothing about their derivatives.
- Better to have many functions than to pass some code into a function to select a behavior.
- Prefer non-static methods to static methods.
Tests
- One assert per test.
- Readable.
- Fast.
- Independent.
- Repeatable.
Code smells
- Rigidity. The software is difficult to change. A small change causes a cascade of subsequent changes.
- Fragility. The software breaks in many places due to a single change.
- Immobility. You cannot reuse parts of the code in other projects because of involved risks and high effort.
- Needless Complexity.
- Needless Repetition.
- Opacity. The code is hard to understand.
Davy Jones@lemmy.dbzer0.comOPto Selfhosted@lemmy.world•How much time and money would it take to set up and maintain a server similar to disroot.org, offering the same services, for a group of ten people?English10·9 days agoThat sounds like spam. I’ll report just in case.
Davy Jones@lemmy.dbzer0.comOPto Voyager@lemmy.world•Any Lemmy web clients that show notifications from multiple accounts at once?English31·9 days agoDoes that work for reports for mods as well?
If Kim Jong Un had done something that stupid, we wouldn’t stop hearing about it. However, because it was done by the president of South Korea, we are likely not going to hear much about it.