Skip to content

Latest commit

 

History

History
112 lines (100 loc) · 1.38 KB

README.md

File metadata and controls

112 lines (100 loc) · 1.38 KB

CSSp
CSS Programming Language.

Syntax

Variables

data {
    height: 10;
    --a: 50;
    --b: 20;
}
/* 
data = {
    height: 10,
    a: 50,
    b: 20
};
*/

Functions

.add {
    --result: calc(var(--a) + var(--b));
}
/* 
function add(x) {
    x.result = a + b;
    return x; 
} 
*/

#add {
  --a: 10;
  --b: 20;
}
/* add({ a:10, b:20 }); */

/* output: { result: 30 } */

Combinators

console #log {
    --logged: 'Logged to console';
}
/* console.log({ logged: 'Logged to console' }) */

#add > c {
    --a: 10;
    --b: 20;
}
/* c = add({ a:10, b:20 }); */

a > b {
    --c: 40;
}
/* b = a = { c: 40 } */

Conditionals

.is-not-5 {
    --result: calc(var(--a) - 5);
}
/* 
function isNot5(x) { 
    x.result = a - 5;
    return x; 
} 
*/

console #log:not(#is-not-5 result) {
    --a: 5;
    --logged: 'A is 5';
}
/*
    data = { a: 5, logged: 'A is 5' };
    if(!isNot5(data).result) {
        console.log(data);
    }
*/

Loops

.is-not-0 {
    --a: calc(var(--a) - 1);
    --result: calc(var(--a));
}
/*
    function isNot0 (x) {
        x.a = x.a - 1;
        x.result = x.a;
        return x;
    }
*/

console #log:matches(#is-not-0 result) {
    --a: 10;
}
/*
    loop = { a: 10 };
    while(isNot0(loop).result) {
        console.log(loop);
    }
*/