Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/peyman-borhani/info-code

A simple method to describe code information. (Things that matter), when TS over complexion is not needed...
https://github.com/peyman-borhani/info-code

Last synced: 20 days ago
JSON representation

A simple method to describe code information. (Things that matter), when TS over complexion is not needed...

Awesome Lists containing this project

README

        

# `info-code`

Investigate/Evaluate Typescript Pros/Cons/usability factors, to realize a minimal alternative feazability.
> JS: javascript
> TS: typescript
> PL: programming Language
> OOP: object oriented programming



## `Purpose`

- why TS is so popular?
- is it that valid? (usability/use-case)
- when TS is not required?
- which TS features can be done by using latest JS?
- can latest JS plus specific libs/framework/ide/tools/AI, provide automated TS intentions/usablity?
- any tools where TS features/functions are automated or done in background? (including TS itself)
- #### `conclusion`:
- find answers to above questions by investigation.
- `any alternative options available/possible?`
- 1. TS intentions/usability automated in background without using the lang.
- 2. minimal developer pattern alternatives.
- 3. Best minimal dev pattern for TS itself. how and where to use and avoid.
- `new pattern to describe code information/types...`(only general/important/useful things)
-

## Todo Update (main reason LS/LC/LSP in IDEs, also popularity hype)

## `Type script`
Typescript is a superset of javascript, which mainly used to provide static typing, force structural constraints,
prevent mistakes or OOP maybe whatever other PL devs were used to.
of dynamic typing. afterwards they add more tooling and principles such as OOP concepts, etc... which might be useful in specific use-cases, such as:

- static typing, force constraints, custom types, some OOP principles...
- preventing ambiguity, mistakes or intentional code manipultion by a bad/noob/careless developer.
- dev-team rules/type check/regulated setup, preventing mistake or careless/intentional manipulation.
- non-JS traditional non web programmers mindset,... but going full TS is overrated hype and not valid.

The general assumption is TS prevents bugs, clarifies intent, safety etc... which in fact depends on:
- Developer + development model -> dev-structure-pattern, implementation, tools, best practices, code readability, integration...
- Run-time process: usually all TS is removed at compilation/build-time, before is executed on a JS runtime.
- Run-time data/input: sanitize inputs, unit and in specific integration testing is effective.

`To summarize`: some of typescipt's abilities might come useful in your dev cycle/env, when used at the correct time/place, but going all TS by trend might negetively impact your dev productivity.

***

### `TS Pros`:
* easier traversal of annotated objects
* better schema definitions for functions and classes
* type safety, early warnings on improper usage, and yes, sometimes safer code like having to check for null
* easier inline documentation for those that can read TS
* beneficial to developers coming from static typed languages mindset, (C++, C#, Java...)

### `TS Cons`:
* JS must be a valid TS but in practice JS developer or code might not be able to integrate with TS.
* discards JS dynamic pattern and mindset, which is productive, simple and in specific cases is required.
* concentrates only on dev/env time, at the build/run-time TS code is removed, code safety is up to runtime.
* learning curve + bad learning (using it in wrong places and not using it where is practical)
* double standards/rules in JS eco-system, which is forced by TS devs, and is non productive.
* un-readable + unexpected code behavior: if complex/custom type systems are badly architected.
* env dependencies and library workarounds at times of lacking support.
* false assumption of TS -> (prevents bugs + error free + team understands my TS) -> devaluing of unit/integration testing
* DRY -> (redundant + unnecessary TS code pollution): typing,...etc at multiple places where one was enough and effective.

### `Final thoughts`:
At present time IDE's (EX: VScode) frameworks(EX: Svelte/kit), methods/libs/tools such as testing will use TS under the hood or inform the user in a better way than the TS itself, considering future progress of native progress of JS and AI automation, typescript intention can be handled without polluting the code, just the intent matters, therefore in my oppinion is best to adopt better JS practices and strategies and using new native system to keep your work standard and unpolluted, at the mean-time use TS as a tool only where applies for the benefits rather than upholding it as a new language.