You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

driver.go 1.7 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. package ops2
  2. import (
  3. "gitlink.org.cn/cloudream/common/pkgs/ioswitch/dag"
  4. "gitlink.org.cn/cloudream/common/pkgs/ioswitch/exec"
  5. "gitlink.org.cn/cloudream/common/utils/math2"
  6. "gitlink.org.cn/cloudream/jcs-pub/common/pkgs/ioswitch2"
  7. )
  8. // TODO 想办法直接使用ops里的Node,而不是重新实现一遍
  9. type FromDriverNode struct {
  10. dag.NodeBase
  11. From ioswitch2.From
  12. Handle *exec.DriverWriteStream
  13. }
  14. func (b *GraphNodeBuilder) NewFromDriver(fr ioswitch2.From, handle *exec.DriverWriteStream) *FromDriverNode {
  15. node := &FromDriverNode{
  16. From: fr,
  17. Handle: handle,
  18. }
  19. b.AddNode(node)
  20. node.OutputStreams().Init(node, 1)
  21. return node
  22. }
  23. func (f *FromDriverNode) GetFrom() ioswitch2.From {
  24. return f.From
  25. }
  26. func (t *FromDriverNode) Output() dag.StreamOutputSlot {
  27. return dag.StreamOutputSlot{
  28. Node: t,
  29. Index: 0,
  30. }
  31. }
  32. func (t *FromDriverNode) GenerateOp() (exec.Op, error) {
  33. t.Handle.ID = t.OutputStreams().Get(0).VarID
  34. return nil, nil
  35. }
  36. type ToDriverNode struct {
  37. dag.NodeBase
  38. To ioswitch2.To
  39. Handle *exec.DriverReadStream
  40. Range math2.Range
  41. }
  42. func (b *GraphNodeBuilder) NewToDriver(to ioswitch2.To, handle *exec.DriverReadStream) *ToDriverNode {
  43. node := &ToDriverNode{
  44. To: to,
  45. Handle: handle,
  46. }
  47. b.AddNode(node)
  48. node.InputStreams().Init(1)
  49. return node
  50. }
  51. func (t *ToDriverNode) GetTo() ioswitch2.To {
  52. return t.To
  53. }
  54. func (t *ToDriverNode) SetInput(v *dag.StreamVar) {
  55. v.To(t, 0)
  56. }
  57. func (t *ToDriverNode) Input() dag.StreamInputSlot {
  58. return dag.StreamInputSlot{
  59. Node: t,
  60. Index: 0,
  61. }
  62. }
  63. func (t *ToDriverNode) GenerateOp() (exec.Op, error) {
  64. t.Handle.ID = t.InputStreams().Get(0).VarID
  65. return nil, nil
  66. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。