diff options
-rw-r--r-- | dalos.lua | 103 |
1 files changed, 86 insertions, 17 deletions
@@ -10,9 +10,20 @@ load "iupe-tview.lua" if not dalosp then dalosp = {} end if not dalos then dalos = {} end dalos.objects = {} +dalos.objects_by_name = {} + +dalosp.NORTH = 1 +dalosp.SOUTH = 2 +dalosp.WEST = 3 +dalosp.EAST = 4 +dalosp.cross = { } function dalos:register_obj(name, constructor) - table.insert(self.objects, { name = name, constructor = constructor }) + if self.objects_by_name[name] then + error("An object of that name already exists: " .. name) + end + table.insert(self.objects, { name = name, constructor = constructor, counter = 1 }) + self.objects_by_name[name] = #self.objects if self.activemenu then self.activemenu:update_objects() end @@ -91,14 +102,24 @@ dalosp.canvas = { cv:Foreground(cd.BLACK) cv:TextOrientation(0) - cv:TextAlignment(cd.NORTH) - cv:Text(x, iy(y1 + 3), "North") - cv:TextAlignment(cd.SOUTH) - cv:Text(x, iy(y2 - 3), "South") - cv:TextOrientation(270) - cv:Text(x1 + 3, iy(y), "West") - cv:TextOrientation(90) - cv:Text(x2 - 3, iy(y), "East") + if dalosp.cross.north then + cv:TextAlignment(cd.NORTH) + cv:Text(x, iy(y1 + 3), dalosp.cross.north.name) + end + if dalosp.cross.south then + cv:TextAlignment(cd.SOUTH) + cv:Text(x, iy(y2 - 3), dalosp.cross.south.name) + end + if dalosp.cross.west then + cv:TextAlignment(cd.SOUTH) + cv:TextOrientation(270) + cv:Text(x1 + 3, iy(y), dalosp.cross.west.name) + end + if dalosp.cross.east then + cv:TextAlignment(cd.SOUTH) + cv:TextOrientation(90) + cv:Text(x2 - 3, iy(y), dalosp.cross.east.name) + end cv:Font(f, st, si) end, @@ -320,7 +341,22 @@ dalosp.canvas = { self.stateful.rghtclk.obj:configure() self:draw() elseif self.menu.x then - -- activate X menu operation + local dx, dy = x - self.menu.x, y - self.menu.y + local obj + if math.abs(dx) > math.abs(dy) then + if dx < 0 then + obj = dalosp.cross.west + else + obj = dalosp.cross.east + end + else + if dy < 0 then + obj = dalosp.cross.north + else + obj = dalosp.cross.south + end + end + if obj then dalosp.menu.add_object(self, obj) end self.menu.x = nil self.menu.y = nil self:draw() @@ -415,7 +451,24 @@ dalosp.menu = { end end, - create = function (tab) + add_object = function (canvas, object) + object.constructor(canvas, { counter = object.counter, x = 25, y = 25 }) + object.counter = object.counter + 1 + end, + + set_cross = function (canvas, object, dir) + if dir == dalosp.NORTH then + dalosp.cross.north = object + elseif dir == dalosp.SOUTH then + dalosp.cross.south = object + elseif dir == dalosp.EAST then + dalosp.cross.east = object + elseif dir == dalosp.WEST then + dalosp.cross.west = object + end + end, + + create = function (canvas, tab) local item_exit = iup.item { title = "Exit" } item_exit.action = dalosp.menu.action_exit local item_about = iup.item { title = "About" } @@ -429,14 +482,19 @@ dalosp.menu = { local item for k, v in ipairs(dalos.objects) do item = iup.item { title = v.name } + item.action = function (self) dalosp.menu.add_object(canvas, v) end table.insert(add_menu, item) item = iup.item { title = v.name } + item.action = function (self) dalosp.menu.set_cross(canvas, v, dalosp.NORTH) end table.insert(north_menu, item) item = iup.item { title = v.name } + item.action = function (self) dalosp.menu.set_cross(canvas, v, dalosp.EAST) end table.insert(east_menu, item) item = iup.item { title = v.name } + item.action = function (self) dalosp.menu.set_cross(canvas, v, dalosp.WEST) end table.insert(west_menu, item) item = iup.item { title = v.name } + item.action = function (self) dalosp.menu.set_cross(canvas, v, dalosp.SOUTH) end table.insert(south_menu, item) end end @@ -539,6 +597,12 @@ dalosp.object = { create = function (dcanvas, tab, extra) if not tab then tab = {} end + if not tab.name then + tab.name = tab.default_name + if tab.counter then + tab.name = tab.name .. " " .. tab.counter + end + end local obj = { draw = dalosp.object.default_draw, name = tab.name or "NoName", @@ -716,7 +780,6 @@ dalosp.hexview = { end, create = function (d, tab) - if not tab.name then tab.name = "Hexview" end tab.otype = dalos.objtype.LUA_FILTER tab.activate = dalosp.hexview.activate tab.input_change = dalosp.hexview.input_change @@ -724,12 +787,20 @@ dalosp.hexview = { tab.configure = dalosp.hexview.configure tab.ninputs = 1 tab.noutputs = 12 + tab.default_name = "Hexview" + + local extra = { } + local obj = dalos.object(d, tab, extra) + local hv = iupe.hexview { } local hvtb = iupe.hexview_toolbox { hexview = hv } - local hvdlg = iup.dialog { iup.hbox { iup.frame { hv }, iup.sbox { direction = "WEST", hvtb } }, title = tab.name } + local hvdlg = iup.dialog { iup.hbox { iup.frame { hv }, iup.sbox { direction = "WEST", hvtb } }, title = obj.name } + + extra.hv = hv + extra.hvtb = hvtb + extra.hvdlg = hvdlg - local obj = dalos.object(d, tab, { hv = hv, hvtb = hvtb, hvdlg = hvdlg }) obj.oldcursors = { } obj.watchees = { } obj.update_houtput = dalosp.hexview.update_houtput @@ -747,7 +818,7 @@ dalos:register_obj("Hexview", dalos.hexview) ---------------- d = dalos.canvas {} -m = dalos.menu {} +m = dalos.menu(d) b1 = Buffer(true) b1:write("Buffer 1 contents") @@ -756,8 +827,6 @@ b2:write("Buffer 2 contents") o1 = dalos.object(d, { y = 30, x = 10, noutputs = 1, name = "Buffer 1", otype = dalos.objtype.HANDLE }) o2 = dalos.object(d, { y = 120, x = 10, noutputs = 1, name = "Buffer 2", otype = dalos.objtype.HANDLE }) ---h1 = dalos.hexview(d, { y = 60, x = 100, name = "Hexview 1" }) ---h2 = dalos.hexview(d, { y = 60, x = 200, name = "Hexview 2" }) o1:set_houtput(b1) o2:set_houtput(b2) |