Skip to content

πŸ’»βœ¨πŸ˜Ί The world's first programming language made for cats

Notifications You must be signed in to change notification settings

luiisp/catscript

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

37 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

(This is a fun project) used to demonstrate how interpreters work.

CatScript: The world's first high-level programming language for cats

🍷 Sintaxe

meow("Hello World!") # print "Hello world!" in the console
pspsps add (x, y)  { # define add function
  x + y # return 15
}
meow(add(10, 5)) # print 15

For more usage examples, check the examples

πŸ“¦ Installation & Usage

  1. Install the catscript interpreter
npm install -g runcat
  1. Run the catscript file
runcat file.cat

Done! πŸŽ‰

πŸ™€ Syntax Highlighting

image

Acess the Syntax Highlighting Repository

πŸˆβ€β¬› Learn catscript

SendIT IDE (1)

General

  • in catscript, the # symbol is used to comment a line
  • catscript is case-sensitive
  • catscript is whitespace-insensitive
  • catscript is a dynamically typed language
  • return values are implicit

Arithmetic operators

  • +: Addition
  • -: Subtraction
  • *: Multiplication
  • /: Division
  • %: Modulus

Types

catscript is a dynamically typed language, so you don't need to specify the type of a variable. The interpreter will infer the type based on the value assigned to it.

  • string: A sequence of characters
  • number: A numeric value
  • boolean: A logical value
  • Object: A collection of key-value pairs

Native functions

  • meow(): Print a message in the console
  • timecat(): Get the current time in ms

Variables

To declare a variable, use the cat or staticat keyword followed by the variable name and the value.

cat name = "Pedro Luis"
staticat age = 16

cat variables are mutable, while staticat variables are immutable.

Important

in catscript, the ; symbol is only for declaration of variables and not is optional

Functions

To declare a function, use the pspsps keyword followed by the function name and the parameters.

pspsps add (x, y) {
  x + y # return
}

To call a function, use the function name followed by the parameters (if you have).

meow(add(10, 5)) # print 15

Important

In catscript, the return value is implicit. the last value of the function is returned

Objects

To declare an object, use the {} in cat keyword or staticat followed by the object name and the key-value pairs.

staticat obj = {
    name:"catscript",
    repo:"https://github.com/luiisp/catscript",
    author:{
        name: "Pedro Luis Dias",
        github: "https://github.com/luiisp/"
    },
    version:"lasted",
};

πŸ’ͺ Contributing

We welcome contributions to the catscript project! If you would like to contribute, please follow these steps:

  1. Fork the repository on GitHub.
  2. Clone your forked repository to your local machine.
  3. Create a new branch for your changes.
  4. Make your desired changes to the codebase.
  5. Test your changes to ensure they work as expected.
  6. Commit your changes and push them to your forked repository.
  7. Submit a pull request to the main i18n4e repository.

Please make sure to follow our contribution guidelines and adhere to our code of conduct when contributing.

Important

Before submitting your PR, ensure that the code is well formatted and follows our requirements

200w

Created with ❀️ by luiisp

About

πŸ’»βœ¨πŸ˜Ί The world's first programming language made for cats

Resources

Stars

Watchers

Forks

Packages