Mercurial > repos > tabletprog
view src/editor.tp @ 112:c0cf9444cf88
Add quotes to strings in editor
author | Mike Pavone <pavone@retrodev.com> |
---|---|
date | Sun, 14 Apr 2013 18:16:03 -0700 |
parents | b2a3f202d485 |
children | c0bfff39abe3 |
line wrap: on
line source
#{ //mquery functions q <- foreign: :query {} qall <- foreign: :query {} each <- foreign: :iterable fun {} addClass <- foreign: :node className {} removeClass <- foreign: :node className {} hasClass <- foreign: :node className {} get <- foreign: :url onSuccess onFail onOther {} getEl <- foreign: :from idx {} setEl <- foreign: :to idx val {} newEl <- foreign: :tagname props {} //TP Parser parser <- foreign: #{ parse <- foreign: :str {} } isLambda <- foreign: :astnode {} //js builtins console <- foreign: #{ log <- foreign: :val {} } window <- foreign: #{} Object <- foreign: #{ keys <- foreign: :object {} } //kernel definitions //import: kernel filter <- :arr pred { output <- arr slice: 0 0 each: arr :idx el { if: (pred: el) { output push: el } else: {} } output } //editor code editFile <- :path { get: path :request { addClass: (q: "body") "editorMode" src <- request responseText ast <- parser parse: src ast populateSymbols: (foreign: null) ast toHTML: (q: "#src") } } selectNode <- :node { each: (qall: ".selected") :idx el { removeClass: el "selected" } addClass: node "selected" } selectQuery <- :selector { selectQuery: selector in: (foreign: undefined) } selectQuery:in <- :selector :context { each: (qall: ".selected") :idx el { removeClass: el "selected" } each: (qall: selector context) :idx el { addClass: el "selected" } } selectParent <- :node { each: (qall: ".selectParent") :idx el { removeClass: el "selectParent" } addClass: (node parentNode) "selectParent" } popInscope:onClick <- :syms :handler { inscope <- q: "#inscope" inscope innerHTML!: "" each: syms :idx key { inscope appendChild: (newEl: "li" #{ textContent <- key onclick <- :Event { handler: key } }) } } symbolClick <- :domnode astnode event { selectNode: domnode popInscope: ((astnode symbols) allSymbols: (foreign: undefined)) onClick: :key { domnode textContent!: key astnode name!: key } event stopPropagation: (foreign: undefined) } funClick <- :domnode astnode event { selectParent: domnode selectQuery: ".selectParent > .funpart" in: (domnode parentNode) symtable <- astnode symbols syms <- filter: (symtable allSymbols: (foreign: undefined)) :sym { isLambda: ((symtable find: sym) def) } popInscope: syms onClick: :key { astnode name!: key parts <- key split: ":" parent <- domnode parentNode nodes <- [] each: (parent children) :idx val{ nodes push: val } partIdx <- 0 nodeIdx <- 0 lastWasNamePart <- true while: { partIdx < (parts length) || nodeIdx < (nodes length) } do: { if: nodeIdx < (nodes length) { node <-getEl: nodes nodeIdx nodeIdx <- nodeIdx + 1 if: (hasClass: node "funpart") { if: partIdx < (parts length) { postfix <- if: partIdx = 0 && nodeIdx = 2 && (parts length) = 1 && (nodes length) = 2 { "" } else: { ":" } t <- (getEl: parts partIdx) node textContent!: (getEl: parts partIdx) . postfix partIdx <- partIdx + 1 } else: { parent removeChild: node } lastWasNamePart <- true } else: { if: (not: lastWasNamePart) && partIdx < (parts length) && nodeIdx > 0 { parent insertBefore: (newEl: "span" #{ className <- "funpart selected" textContent <- (getEl: parts partIdx) . ":" }) node partIdx <- partIdx + 1 } lastWasNamePart <- false } } else: { console log: "part: " . (getEl: parts partIdx) parent appendChild: (newEl: "span" #{ className <- "funpart selected" textContent <- (getEl: parts partIdx) . ":" }) partIdx <- partIdx + 1 } } } event stopPropagation: (foreign: undefined) } lambdaClick <- :domnode astnode event { symbolClick: domnode astnode event } main <- { get: "/src/" :data { fakeEl <- newEl: "div" #{ innerHTML <- data response } each: (qall: "a" fakeEl) :idx el { if: ((el textContent) = "../") {} else: { nel <- newEl: "a" #{ href <- "/edit/src/" + (el textContent) textContent <- el textContent } nel onclick!: :event { link <- foreign: this path <- link href path <- path substr: (path indexOf: "/edit/") + 5 editFile: path foreign: false } li <- newEl: "li" li appendChild: nel (q: "#browser ul") appendChild: li } } } //bind handlers for editor buttons each: (qall: ".controls li") :idx el { el onclick!: :event { srcel <- (q: "#src") srcel textContent!: (srcel textContent) + (el textContent) } } visible <- "showops" (q: "#ops_button") onclick!: :event { each: (qall: ".controls") :idx el { removeClass: el visible addClass: el "showops" } visible <- "showops" } (q: "#lit_button") onclick!: :event { each: (qall: ".controls") :idx el { removeClass: el visible addClass: el "showlit" } visible <- "showlit" } path <- (window location) pathname if: (path indexOf: "/edit/") = 0 { editFile: (path substr: 5) } else: {} } }