This file is indexed.

/usr/share/SuperCollider/HelpSource/Classes/SCViewHolder.schelp is in supercollider-common 1:3.6.3~repack-5.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
CLASS:: SCViewHolder
summary:: Instead of subclassing a (Q/SC)View, this is a proxy/adapter object that holds the View
categories:: GUI
related:: Classes/View

DESCRIPTION::
When writing gui widgets it is sometimes not desireable to subclass a view class. Its preferable to write a class that acts like a View and is used where Views normally are used but isn't a direct subclass of a View class.

In the SCView hierarchy it is not possible to subclass an SCView class because under the hood there is always a strict relationship between the SCView subclass and its paired C++ class.  The C++ class makes the actual view, the SC class is an interface to that C++ object.

In Qt there is a bit more flexibility.

But there are other reasons to not inherit from a specific view: your widget may not be a single view, in which case you would want to place a CompositeView and then place subviews inside of that.  Altogether these views are what your widget manages.  SCViewHolder can be used in this situation and it would set the top level CompositeView as its primary view.

Although it is still called "SC"ViewHolder it is in fact cross platform since it doesn't draw the view(s), it simply holds them.

Another possible name might be ViewAdapter or PseudoView.  It was originally called SCViewAdapter.

Most of the standard view methods here simply defer to the proxied view.  This makes the ViewHolder act and quack like a View.  

Messages that are not understood by the view holder are forwarded to the proxied view.

Historical note: this class was originally in the cruciallib.  ObjectGui is a subclass of this.

CLASSMETHODS::

METHOD:: consumeKeyDowns
global preference variable: if true then subclasses that do not set a keyDownAction do NOT bubble up keyDown events by default.

returns:: The result of calling the method on the proxied view


INSTANCEMETHODS::


METHOD:: view
get or set the view for which this object is a proxy/adapter.

argument:: v
the view: SCView or QView 

returns:: The result of calling the method on the proxied view


METHOD:: doesNotUnderstand
Messages that are not understood by the view holder are forwarded to the proxied view.  So when the interpreter is told to send a message to a view holder object and that message is not understood, it calls doesNotUnderstand

argument:: selector
The message that was not understood

argument::  ... args
The arguments that were supplied

returns:: the result of calling the method on the proxied view


METHOD:: viewDidClose
Unsets the view variable. After the view is closed (removed from the window) then all calls to the view holder will fail, and should fail as there is no view anymore.  You can check viewHolder.isClosed if you are unsure

returns:: this

METHOD:: remove
Removes the view from the window if it has not already been removed.

returns:: this

METHOD:: action
This method is forwarded to the view

argument:: f


returns:: The result of calling the method on the proxied view

METHOD:: doAction
This method is forwarded to the view

returns:: The result of calling the method on the proxied view

METHOD:: keyDownAction
This method is forwarded to the view

argument:: f


returns:: The result of calling the method on the proxied view

METHOD:: keyDownResponder
This method is forwarded to the view.  Note: this is a cruciallib convention and will be deprecated here.

returns:: The result of calling the method on the proxied view

METHOD:: enableKeyDowns
This method is forwarded to the view. Note: this is a cruciallib convention and will be deprecated here.

returns:: The result of calling the method on the proxied view

METHOD:: asView
returns the view

returns:: the view

METHOD:: bounds
This method is forwarded to the view

argument:: b


returns:: The result of calling the method on the proxied view

METHOD:: resize
This method is forwarded to the view

argument:: r


returns:: The result of calling the method on the proxied view

METHOD:: enabled
This method is forwarded to the view

argument:: b


returns:: The result of calling the method on the proxied view

METHOD:: refresh
This method is forwarded to the view

returns:: The result of calling the method on the proxied view

METHOD:: background
This method is forwarded to the view

argument:: b


returns:: The result of calling the method on the proxied view

METHOD:: focus
This method is forwarded to the view

argument:: flag


returns:: The result of calling the method on the proxied view

METHOD:: visible
This method is forwarded to the view

argument:: boo


returns:: The result of calling the method on the proxied view

METHOD:: isClosed
This method is forwarded to the view

returns:: The result of calling the method on the proxied view

METHOD:: font
This method is forwarded to the view

argument:: f


returns:: The result of calling the method on the proxied view