From 7992fec7a1d9b323b3e70680a06380ce5e30a590 Mon Sep 17 00:00:00 2001 From: Nils <> Date: Sat, 18 Apr 2020 22:18:14 +0200 Subject: [PATCH] remove more files that are not daemon and jackpatch, are copyrighted or are of unclear licensing. This includes branding like logos and icons as well as the documentation for the NTK non-session-manager GUI that got removed here as well --- lib/ntk | 1 - session-manager/doc/API.html | 615 ------- session-manager/doc/API.mu | 611 ------- session-manager/doc/MANUAL.html | 265 --- session-manager/doc/MANUAL.mu | 266 --- session-manager/doc/Makefile | 25 - session-manager/doc/icon.png | 1 - session-manager/doc/mup.css | 461 ------ session-manager/doc/nsm.png | Bin 34308 -> 0 bytes .../128x128/apps/non-session-manager.png | Bin 14846 -> 0 bytes .../16x16/apps/non-session-manager.png | Bin 1428 -> 0 bytes .../192x192/apps/non-session-manager.png | Bin 26989 -> 0 bytes .../256x256/apps/non-session-manager.png | Bin 28987 -> 0 bytes .../32x32/apps/non-session-manager.png | Bin 3019 -> 0 bytes .../36x36/apps/non-session-manager.png | Bin 3749 -> 0 bytes .../48x48/apps/non-session-manager.png | Bin 5360 -> 0 bytes .../512x512/apps/non-session-manager.png | Bin 28594 -> 0 bytes .../64x64/apps/non-session-manager.png | Bin 7209 -> 0 bytes .../72x72/apps/non-session-manager.png | Bin 8883 -> 0 bytes .../96x96/apps/non-session-manager.png | Bin 12336 -> 0 bytes .../scalable/apps/non-session-manager.svg | 217 --- session-manager/icons/icon-16x16.xpm | 774 --------- session-manager/icons/icon-large.svg | 217 --- .../non-session-manager.desktop.in | 9 - session-manager/src/NSM_Proxy_UI.fl | 100 -- session-manager/src/nsm-proxy-gui.C | 291 ---- session-manager/src/nsm-proxy.C | 760 --------- session-manager/src/send_osc.C | 104 -- session-manager/src/session-manager.C | 1440 ----------------- 29 files changed, 6157 deletions(-) delete mode 160000 lib/ntk delete mode 100644 session-manager/doc/API.html delete mode 100644 session-manager/doc/API.mu delete mode 100644 session-manager/doc/MANUAL.html delete mode 100644 session-manager/doc/MANUAL.mu delete mode 100644 session-manager/doc/Makefile delete mode 120000 session-manager/doc/icon.png delete mode 100644 session-manager/doc/mup.css delete mode 100644 session-manager/doc/nsm.png delete mode 100644 session-manager/icons/hicolor/128x128/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/16x16/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/192x192/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/256x256/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/32x32/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/36x36/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/48x48/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/512x512/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/64x64/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/72x72/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/96x96/apps/non-session-manager.png delete mode 100644 session-manager/icons/hicolor/scalable/apps/non-session-manager.svg delete mode 100644 session-manager/icons/icon-16x16.xpm delete mode 100644 session-manager/icons/icon-large.svg delete mode 100644 session-manager/non-session-manager.desktop.in delete mode 100644 session-manager/src/NSM_Proxy_UI.fl delete mode 100644 session-manager/src/nsm-proxy-gui.C delete mode 100644 session-manager/src/nsm-proxy.C delete mode 100644 session-manager/src/send_osc.C delete mode 100644 session-manager/src/session-manager.C diff --git a/lib/ntk b/lib/ntk deleted file mode 160000 index dae1771..0000000 --- a/lib/ntk +++ /dev/null @@ -1 +0,0 @@ -Subproject commit dae177189b12f74ea01ac2389b76326c06d9be78 diff --git a/session-manager/doc/API.html b/session-manager/doc/API.html deleted file mode 100644 index 66188b0..0000000 --- a/session-manager/doc/API.html +++ /dev/null @@ -1,615 +0,0 @@ - -
- - - --The Non Session Management API is used by the various components of the Non audio production suite to allow any number of independent programs to be managed together as part of a logical session (i.e. a song). Thus, operations such as loading and saving are synchronized. -
--The API comprises a simple Open Sound Control (OSC) based protocol, along with some behavioral guidelines, which can easily be implemented by various applications. -
--The Non project contains an program called nsmd which is an implementation of the server side of the NSM API. nsmd is controlled by the non-session-manager GUI. However, the same server-side API can also be implemented by other session managers (such as LADISH), although consistency and robustness will likely suffer if non-NSM compliant clients are allowed to participate in a session. The only dependency for client implementations liblo (the OSC library), which several Linux audio applications already link to or plan to link to in the future. -
--The aim of this project is to thoroughly define the behavior required of clients. This is an area where other attempts at session management (LASH and JACK-Session) have failed. Often the difficulty with these systems has been not in implementing support for them, but in attempting to interpret the confusing, ambiguous, or ill-conceived API documentation. For these reasons and more all previous attempts at Linux audio session management protocols are considered harmful. -
--You WILL see some unambiguous and emphatic language in this document. For the good of the user, these rules are meant to be followed and are non-negotiable. If an application does not conform to this specification it should be considered broken. Consistency across applications under session management is very important for a good user experience. -
--Most graphical applications make available to the user a common set of file operations, typically presented under a File or Project menu. -
--These are: New, Open, Save, Save As, Close and Quit or Exit. -
--The following sub-sections describe how these options should behave when the application is part of an NSM session. These rules only apply when session management is active (that is, after the announce handshake described in the 1.2. NSM OSC Protocol section). In order to provide a consistent and predictable user experience, it is critically important for applications to adhere to these guidelines. -
--This option may empty/reset the current file or project (possibly after user confirmation). UNDER NO CIRCUMSTANCES should it allow the user to create a new project/file in another location. -
--This option MUST be disabled. -
--The application may, however, elect to implement an option called 'Import into Session', creates a copy of a file/project which is then saved at the session path provided by NSM. -
--This option should behave as normal, saving the current file/project as established by the NSM open message. -
--UNDER NO CIRCUMSTANCES should this option present the user with a choice of where to save the file. -
--This option MUST be disabled. -
--The application may, however, elect to implement an option called 'Export from Session', which creates a copy of the current file/project which is then saved in a user-specified location outside of the session path provided by NSM. -
-- This option MUST be disabled unless its meaning is to disconnect the application from session management. -
--This option may behave as normal (possibly asking the user to confirm exiting). -
--All project specific data created by a client MUST be stored in the per-client storage area provided by NSM. This includes all recorded audio and MIDI files, snapshots, etc. Only global configuration items, exports, and renders of the project may be stored elsewhere (wherever the user specifies). -
--Files required by the project but external to it (typically read-only data such as audio samples) SHOULD be referenced by creating a symbolic link within the assigned session area, and then referring to the symlink. This allows sessions to be archived and transported simply (e.g. with "tar -h") by tools that have no knowledge of the project formats of the various clients in the session. The symlinks thus created should, at the very least, be named after the files they refer to (some unique component may be required to prevent collisions) -
--samples/drumbeat-1.wav -samples/drumbeat-2.wav - |
-All message parameters are REQUIRED. All messages MUST be sent from the same socket as the announce message, using the lo_send_from method of liblo or its equivalent, as the server uses the return addresses to distinguish between clients. -
--Clients MUST create thier OSC servers using the same protocol (UDP,TCP) as found in NSM_URL. liblo is lacking a robust TCP implementation at the time of writing, but in the future it may be useful. -
--At launch, the client MUST check the environment for the value of NSM_URL. If present, the client MUST send the following message to the provided address as soon as it is ready to respond to the /nsm/client/open event: -
--/nsm/server/announce s:application_name s:capabilities s:executable_name i:api_version_major i:api_version_minor i:pid - |
-If NSM_URL is undefined, invalid, or unreachable, then the client should proceed assuming that session management is unavailable. -
--api_version_major and api_version_minor must be the two parts of the version number of the NSM API as defined by this document. -
--Note that if the application intends to register JACK clients, application_name MUST be the same as the name that would normally be passed to jack_client_open. For example, Non-Mixer sends "Non-Mixer" as its application_name. Applications MUST NOT register their JACK clients until receiving an open message; the open message will provide a unique client name prefix suitable for passing to JACK. This is probably the most complex requirement of the NSM API, but it isn't difficult to implement, especially if the application simply wishes to delay its initialization process breifly while awaiting the announce reply and subsequent open message. -
--capabilities MUST be a string containing a colon separated list of the special capabilities the client possesses. e.g. :dirty:switch:progress: -
--executable_name MUST be the executable name that the program was launched with. For C programs, this is simply the value of argv[0]. Note that hardcoding the name of the program here is not the same as using, as the user may have launched the program from a script with a different name using exec, or have created a symlink to the program. Getting the correct value in scripting languages like Python can be more challenging. -
-Name | Description |
---|---|
switch | client is capable of responding to multiple `open` messages without restarting |
dirty | client knows when it has unsaved changes |
progress | client can send progress updates during time-consuming operations |
message | client can send textual status updates |
optional-gui | client has an optional GUI |
-The server will respond to the client's announce message with the following message: -
--/reply "/nsm/server/announce" s:message s:name_of_session_manager s:capabilities - |
-message is a welcome message. -
--The value of name_of_session_manager will depend on the implementation of the NSM server. It might say "Non Session Manager", or it might say "LADISH". This is for display to the user. -
--capabilities will be a string containing a colon separated list of special server capabilities. -
--Presently, the server capabilities are: -
-Name | Description |
---|---|
server-control | client-to-server control |
broadcast | server responds to /nsm/server/broadcast message |
optional-gui | server responds to optional-gui messages--if this capability is not present then clients with optional-guis MUST always keep them visible |
-A client should not consider itself to be under session management until it receives this response. For example, the Non applications activate their "SM" blinkers at this time. -
--If there is an error, a reply of the following form will be sent to the client: -
--/error "/nsm/server/announce" i:error_code s:error_message - |
-The following table defines possible values of error_code: -
-Code | Meaning |
---|---|
ERR_GENERAL | General Error |
ERR_INCOMPATIBLE_API | Incompatible API version |
ERR_BLACKLISTED | Client has been blacklisted. |
-Compliant clients MUST accept the client control messages described in this section. All client control messages REQUIRE a response. Responses MUST be delivered back to the sender (NSM) from the same socket used by the client in its announce message (by using lo_send_from) AFTER the action has been completed or if an error is encountered. The required response is described in the subsection for each message. -
--If there is an error and the action cannot be completed, then error_code MUST be set to a valid error code (see 1.2.5. Error Code Definitions) and message to a string describing the problem (suitable for display to the user). -
--The reply can take one of the following two forms, where path MUST be the path of the message being replied to (e.g. "nsm/client/save": -
--/reply s:path s:message - |
-/error s:path i:error_code s:message - |
-There is no message for this. Clients will receive the Unix SIGTERM signal and MUST close cleanly IMMEDIATELY, without displaying any kind of dialog to the user and regardless of whether or not unsaved changes would be lost. When a session is closed the application will receive this signal soon after having responded to a save message. -
--/nsm/client/open s:path_to_instance_specific_project s:display_name s:client_id - |
-path_to_instance_specific_project is a path name assigned to the client for storing its project data. -
--The client may append to the path, creating a sub-directory, e.g. '/song.foo' or simply append the client's native file extension (e.g. '.non' or '.XML'). The same transformation MUST be applied to the name when opening an existing project, as NSM will only provide the instance specific part of the path. -
--If a project exists at the path, the client MUST immediately open it. -
--If a project does not exist at the path, then the client MUST immediately create and open a new one at the specified path or, for clients which hold all their state in memory, store the path for later use when responding to the save message. -
--No file or directory will be created at the specified path by the server. It is up to the client to create what it needs. -
--For clients which HAVE NOT specified the :switch: capability, the open message will only be delivered once, immediately following the announce response. -
--For clients which HAVE specified the :switch: capability, the client MUST immediately switch to the specified project or create a new one if it doesn't exist. -
--Clients which are incapable of switching projects or are prone to crashing upon switching MUST NOT include :switch: in their capability string. -
--If the user the is allowed to run two or more instances of the application simultaneously (that is to say, there is no technical limitation preventing them from doing so, even if it doesn't make sense to the author), then such an application MUST PRE-PEND the provided client_id string to any names it registers with common subsystems (e.g. JACK client names). This ensures that multiple instances of the same application can be restored in any order without scrambling the JACK connections or causing other conflicts. The provided client_id will be a concatenation of the value of application_name sent by the client in its announce message and a unique identifier. Therefore, applications which create single JACK clients can use the value of client_id directly as their JACK client name. Applications which register multiple JACK clients (e.g. Non-Mixer) MUST PRE-PEND client_id value to the client names they register with JACK and the application determined part MUST be unique for that (JACK) client. -
--For example, a suitable JACK client name would be: -
--$CLIENT_ID/track-1 - |
-Note that this means that the application MUST NOT register with JACK (or any other subsystem requiring unique names) until it receives an open message from NSM. Likewise, applications with the :switch: capability should close their JACK clients and re-create them with using the new client_id. Re-registering is necessary because the JACK API does currently support renaming existing clients, although this is a sorely needed addition. -
--A response is REQUIRED as soon as the open operation has been completed. Ongoing progress may be indicated by sending messages to /nsm/client/progress. -
--The client MUST respond to the 'open' message with: -
--/reply "/nsm/client/open" s:message - |
-Or -
--/error "/nsm/client/open" i:error_code s:message - |
Code | Meaning |
---|---|
ERR | General Error |
ERR_BAD_PROJECT | An existing project file was found to be corrupt |
ERR_CREATE_FAILED | A new project could not be created |
ERR_UNSAVED_CHANGES | Unsaved changes would be lost |
ERR_NOT_NOW | Operation cannot be completed at this time |
-/nsm/client/save - |
-This message will only be delivered after a previous open message, and may be sent any number of times within the course of a session (including zero, if the user aborts the session). -
--
-The client MUST respond to the 'save' message with: -
--/reply "/nsm/client/save" s:message - |
-Or -
--/error "/nsm/client/save" i:error_code s:message - |
Code | Meaning |
---|---|
ERR | General Error |
ERR_SAVE_FAILED | Project could not be saved |
ERR_NOT_NOW | Operation cannot be completed at this time |
- Accepting this message is optional. The intent is to signal to clients which may have some interdependence (say, peer to peer OSC connections) that the session is fully loaded and all their peers are available. Most clients will not need to act on this message. This message has no meaning when a session is being built or run--only when it is initially loaded. Clients who intend to act on this message MUST not do so by delaying initialization waiting for it. -
--/nsm/client/session_is_loaded - |
-This message does not require a response. -
--If the client has specified the optional-gui capability, then it may receive this message from the server when the user wishes to change the visibility state of the GUI. It doesn't matter if the optional GUI is integrated with the program or if it is a separate program \(as is the case with SooperLooper\). When the GUI is hidden, there should be no window mapped and if the GUI is a separate program, it should be killed. -
--/nsm/client/show_optional_gui - |
-/nsm/client/hide_optional_gui - |
-No response is message is required. -
--These are optional messages which a client can send to the NSM server to inform it about the client's status. The client should not expect any reply to these messages. If a client intends to send a message described in this section, then it MUST add the appropriate value to its capabilities string when composing the announce message. -
--If the client has specified the optional-gui capability, then it MUST send this message whenever the state of visibility of the optional GUI has changed. It also MUST send this message after it's announce message to indicate the initial visibility state of the optional GUI. -
--It is the responsibility of the client to remember the visibility state of its GUI across session loads. -
--/nsm/client/gui_is_hidden - |
-/nsm/client/gui_is_shown - |
-No response will be delivered. -
--/nsm/client/progress f:progress - |
-For potentially time-consuming operations, such as save and open, progress updates may be indicated throughout the duration by sending a floating point value between 0.0 and 1.0, 1.0 indicating completion, to the NSM server. -
--The server will not send a response to these messages, but will relay the information to the user. -
--Note that even when using the progress feature, the final response to the save or open message is still REQUIRED. -
--Clients which intend to send progress messages should include :progress: in their announce capability string. -
--/nsm/client/is_dirty - |
-/nsm/client/is_clean - |
-Some clients may be able to inform the server when they have unsaved changes pending. Such clients may optionally send is_dirty and is_clean messages. -
--Clients which have this capability should include :dirty: in their announce capability string. -
--/nsm/client/message i:priority s:message - |
-Clients may send miscellaneous status updates to the server for possible display to the user. This may simply be chatter that is normally written to the console. priority should be a number from 0 to 3, 3 being the most important. -
--Clients which have this capability should include :message: in their announce capability string. -
-Symbolic Name | Integer Value |
---|---|
ERR_GENERAL | -1 |
ERR_INCOMPATIBLE_API | -2 |
ERR_BLACKLISTED | -3 |
ERR_LAUNCH_FAILED | -4 |
ERR_NO_SUCH_FILE | -5 |
ERR_NO_SESSION_OPEN | -6 |
ERR_UNSAVED_CHANGES | -7 |
ERR_NOT_NOW | -8 |
ERR_BAD_PROJECT | -9 |
ERR_CREATE_FAILED | -10 |
-If the server publishes the :server-control: capability, then clients can also initiate action by the server. For example, a client might implement a 'Save All' option which sends a /nsm/server/save message to the server, rather than requiring the user to switch to the session management interface to effect the save. -
--The session manager not only manages clients via OSC, but it is itself controlled via OSC messages. The server responds to the following messages. -
--All of the following messages will be responded to, at the sender's address, with one of the two following messages: -
--/reply s:path s:message - |
-/error s:path i:error_code s:message - |
- The first parameter of the reply is the path to the message being replied to. The /error reply includes an integer error code (non-zero indicates error). message will be a description of the error. -
--The possible errors are: -
-Code | Meaning |
---|---|
ERR_GENERAL | General Error |
ERR_LAUNCH_FAILED | Launch failed |
ERR_NO_SUCH_FILE | No such file |
ERR_NO_SESSION | No session is open |
ERR_UNSAVED_CHANGES | Unsaved changes would be lost |
-Adds a client to the current session. -
--Saves the current session. -
--Saves the current session and loads a new session. -
--Saves the current session and creates a new session. -
--Saves and closes the current session, makes a copy, and opens it. -
--Saves and closes the current session. -
--Closes the current session WITHOUT SAVING -
--Saves and closes the current session and terminates the server. -
--Lists available projects. One /reply message will be sent for each existing project. -
--If the server includes :broadcast: in its capability string, then clients may send broadcast messages to each other through the NSM server. Clients may send messages to the server at the path /nsm/server/broadcast. -
--The format of this message is as follows: -
--/nsm/server/broadcast s:path [arguments...] - |
-The message will then be relayed to all clients in the session at the path path (with the arguments shifted by one). -
--For example the message: -
--/nsm/server/broadcast /tempomap/update "0,120,4/4:12351234,240,4/4" - |
-Would broadcast the following message to all clients in the session (except for the sender), some of which might respond to the message by updating their own tempo maps. -
--/tempomap/update "0,120,4/4:12351234,240,4/4" - |
-The Non programs use this feature to establish peer to peer OSC communication by symbolic names (client IDs) without having to remember the OSC URLs of peers across sessions. -
-![]() |
-The Non Session Manager is a graphical interface to the NSM Daemon (nsmd). By default, running the command non-session-manager will start both the GUI and an instance of the daemon. -
--If a different session root than the default is desired, it may be specified on the command-line as follows: -
--non-session-manager -- --session-root path - |
-This command will instruct the instance of nsmd that the GUI starts to use path as the session root. -
--All session data is stored in per-session sub-directories of the Session Root. -
-- There are two ways to open a session. -
--The first is to click the Open button and type in the exact name of an existing session. The second is to click on the desired session name in the session list panel on the left side of the interface. -
--Either way, opening a session saves the current session and switches to the new one. Clients which are capable of switching projects without restarting are instructed to do so, resulting in very fast session open times when such clients are participating in both sessions. -
--Clients cannot be added until a session is open, either by Open or New. -
--As each client launches, a status bar representing it will be added to the client list on the right half the interface. For clients which are capable of reporting their progress, a progress bar will also become active. -
--Only clients supporting the NSM protocol can be told what to open and when to save. Clients not supporting NSM may still be added to the session, but their behavior is undefined other than that NSM can invoke and kill them. -
--This option saves and closes the current session. All clients participating in the session are told to quit. Note that, as mentioned in the preceding section, in NSM it is not necessary to close one session before opening another. -
--This option closes the current session without saving. -
--This option saves the current session, instructing clients supporting the NSM protocol to save. -
--This option saves the current session (if one is open) and creates a new one. The user is prompted for a session name. Session names are paths under the defined Session Root. A session name may include any number of hierarchical elements, which need not be pre-existing. -
--For example, one might name a session as follows: -
--Albums/Magnum Opus/The Best Song Ever Produced - |
-When inspecting Session Root in a file manager, the above represents exactly the path you would see. -
--Renaming a session is not currently supported, but one may simply move directories around under Session Root and NSM will detect the new layout upon the next invocation. The session name is not stored anywhere except in its path. -
--
-Templates are supported in by the Non Session Manager via duplication. Clicking on the Duplicate button with a session open will prompt the user for a new session name. The daemon will then perform a recursive file copy of the session and open the copy. -
--Obviously, this should be avoided for sessions containing audio data, as the copy would be very time consuming. -
--To create a template in the first place, simply use New to start a new session (preferably with a name beginning with "Templates/"), add the desired clients to it, and configure them (e.g. add plugins, make JACK connections, etc.) Now, any time you want to start a session from that template, simply switch to the template session and click Duplicate to create a new session based on it. -
--This option will prompt the user for the executable name of the client to be added to the session. It is not necessary to type the full path (the PATH environment variable will be searched to find the executable). -
--When controlling an NSM session distributed across multiple machines, the user will also be required to choose which server to invoke the client on. -
--If a client dies unexpectedly or is closed by the user (e.g. by closing its main window), Non Session Manager will detect this and two buttons will appear on that Client's status bar. One button, the arrow, causes the client to be restarted and to reopen its project file where it left off. The X button causes the client to be permanently removed from the session. -
--NSM manages clients together in a session. That's it. NSM doesn't know or care what Window Manager or audio subsystem those clients use--nor should it. Specific clients must be written to persist these environmental factors, and added to sessions when required. -
--For saving and restoring the JACK connection graph, a simple headless client named jackpatch has been developed and included in the NSM distribution. Simply add jackpatch do your basic template session and all the sessions you base on it will have their JACK connection graphs automatically saved and restored. -
--The NSM Daemon (nsmd) is launched automatically by the Non Session Manager interface whenever one is not found to be already running at the URL specified in the environment. -
--Users who are not attempting to setup advanced modes like shared sessions between machines will not normally need to even know that nsmd is running. -
--But for those advanced users, here are the command-line options for launching nsmd separately from the GUI. -
--nsmd [--session-root path] [--osc-port port] [--detach] - |
-The --session-root option allows one to override where Session Root is, from the default of "$HOME/NSM Sessions" (this option can also be passed to the GUI, which will hand it over to the daemon). -
----osc-port instructs the daemon to bind to a specific UDP port number instead of selecting an available port automatically. -
----detach instructs the daemon to close its standard input and output and go into the background. This is useful for starting the daemon remotely with rsh. -
--When nsmd starts, it will print a string of the following form its standard output. -
--NSM_URL=osc.udp://foo.bar.net:17551/ - |
-This is the OSC URL for the daemon process. If this URL is included in the environment (by either using a fixed port number or starting nsmd early in the initialization process [like in your .xinitrc] extracting the URL from its output) then any NSM capable client will join the current session when started, even if started from outside the Non Session Manager interface (for example, by your Desktop Environment's program launch menu). -
--When dealing with multiple instances of nsmd, whether they be on the same host or separate hosts, it is most convenient to use fixed port numbers specified with the --osc-port command-line option. -
--In some situations it is necessary to have different audio programs running on different machines, connected by S/PDIF, analog wiring, or over TCP/IP as achieved by netjack. Usually the reason for doing this is that neither machine is powerful enough to do all the DSP or synthesis alone. -
--Needless to say, these configurations have historically been extremely difficult to manage--requiring heavy scripting and/or lots of manual setup. -
--NSM is the first--and currently only--system capable of managing these sessions. -
--Let us assume the following conditions for our example: -
--The first step is to decide what port numbers to use. Let's choose 6661 for Host-A and 6662 for Host-B. -
--If either host is running a firewall, then these ports must be opened explicitly! -
--To start the daemon on host A: -
--user@host-a:~$ nsmd --detach --session-root "$HOME/distributed-nsm-sessions" --osc-port 6661 - |
-To start the daemon on host B (conveniently from host A, via rsh) -
--user@host-a:~$ rsh host-b nsmd --detach --session-root "\$HOME/distributed-nsm-sessions" --osc-port 6662 - |
-Note that in the above example, there is a backslash in "$HOME", this is because otherwise the variable would be expanded on the local machine, giving the local value rather than what we intended. -
--Now that both daemons are running, we can start the Non Session Manager interface with the following command: -
--user@host-a:~$ non-session-manager --nsm-url osc.udp://host-a:6661 --nsm-url osc.udp://host-b:6662 - |
-The Non Session Manager interface will then connect to the daemons on both hosts. Creating a new session will create separate session files on each host. When adding a client, the interface will present the user with a choice of which host to invoke the client on. Aside from that it is just like managing any other session. Sessions can be opened, saved, switched between, etc. and the desired effect will be seen on each host. -
--Simply starting two (or more) instances of the Non Session Manager interface on the same machine (when the NSM_URL environment variable is unset) will result in the ability to have two different sessions open at the same time on the same host. A lock file prevents the two instances from opening the same session. -
--Imagining a useful application of this feature is left as an exercise for the reader. -
--Development of the Non Session Manager can be followed with Git: -
--git clone git://git.tuxfamily.org/gitroot/non/non.git - |
-There are no pre-compiled binaries available. -
-9^GBQ^3HX=H~~*KD=ucP z-WKbjl*}Bc^F!)axK>+^2GdUbd~0hh1eQoMGggD~Z;UpYUMY=Y`7AnG{_)-wqUZC< z-%3W}Z(>2T(EP%MkH59`%sZ aUQ;UY3LGz@sOKHC|G1T5Y%gRJ@zCB=e*o*u5p$+SGn ze<@Jqh(ata7i46nkB785Awxo5$Jn6lyCWWhhz_sq5gdU(f~8AiR$OjRU=(|8-%MZN ztz-$i-kvkiOZVK~-d;yTAFs_IDBN2YaP2q50(g{MzEcVzBR@4AW%>um{X 7l_ zUAjKFii2fw+wXo$S$b-9jp#F|UhQ^X`?q~@%Ly4a+3c`+8VTl3XJzs3*d3WoDRemk zQ`Xhg5Q+Fr8wDP4Do#tHT64{s^~8#v4dSvvOVvuSLF0vr56)-GOa2{wlieG&Fp-K< zbrKO5Jjyz!&ilx>Jx`bV3f8(Mm6b<7;b7I0N$pB-9_%e4xBb9o_OHj9AwwFyjsU}e z05SEs3GtECg_bKvb?31OIB#8St9f5;pE}(`-3BBwUr0b;H!n`a;3CjbLsOQYWZ3tp z{KocZ3Cd<@S*;Tkgm~^hS 9bhZ5j&6t}mF(9ncD%J%*c>+56u{=FwRcXfUJ+s8cVQIHqAXvx8^QsH;3 zdLL{z2UC^;VZFWUXV;I20i^H@#dIF@P^7cPR!MXMp<6Ug%R#GTx#Vx(22E;>e7w7} z1wGUK>LFRW9Cp+3mF |Q2sek)4*WzignHj>K zlQFG;y2d)Z9%pR=DBS~WsKtpgE4TPGDk>NSOZ4&DuGv!P AhF x+x9ZuoXC`st- I`oB;fk7XJn+a#pB^*qxp%|uz4B=hr2O6t`-o#<^_yIbaXVY z{p|kE&d$n85Vnn-#$t0am&vM^z-(^<^;fA=%Rh?pY%`ZKN=ki${XUjEtM8N%4lE?{ zM)C0Q!Z0w!P(wpPGWeYPNBc&nroInZq99)vLCkfG$+}n7=pjYJf9+}yY_NFJAO2?a zcpfdfUhdySMfK0!+|Vm$9X4*(1&r+`pm73g*LBN`F{(L$8c}ruXjuXNmRs0nYj}Z? zu>@E4=KGLn>TQxB-?{P7rvFTi?PSo2)lWlJ=jt6-6V-&aHd3hV#_H-H%UaQ!YwEL< z 0>)Q4w{uJuP!dC z2NMrcM4#p_hTwZIUc6ACB-I}M`gO3AGWhaH6r00px!SA;1&d6gB}^*s }RDcwb0~5;C&q*vjevd6bMMGso!hz1%GM`ICbvrkrzb2V6v_YVb74i-`Cr z9*&X9<-N)YW4Sr%$sTLN1}tMyM9N3fu9K&^n-=fPcLD-a1LjyMfg#wSFfGH_?_r}> zgTupp!^8Y;+r4Kn;TB*M1$OKtnwwE+^1}T53f(iXqT(Cb#HYtv=%_)q bibgWfNCnF;pav=)5feBdQU0K|=mZqz$KA*8E zfi+| *EWWvG%H&cn%^l#PTn7~MC=0`K1=mP#Po6 _ zM?!z!5KXJ7=V_L#Z{SO{Et-u`s25zK5;8DbU;X1D!VrG^HjbFAsj2WPxX*lgW` X#HDi?QL%mL }E1e@}F?(%)e$kXH1&hbju{K7)` z8`9gGt?X64Uk42bp3P{PnOVMvgg|wpdD6lkA;W;t!UpM;U;geCR~EfkA57((pPz4S zYb#QYOXGG8qiw*P3z#$EBI Wzv0D5>1%7l zr;7ns;pFC?;5)nR$Dj`)kERk{*XPB((NMPWa33>TUU%_K5m%3?{nT@KEGG!-tx^VG z5E;(kz)-Dc6@cM&@ra;z=?84M-d>GZB=1{|AIFXEk7|LzS{vfLP#+)r7fWhyZy#ea z4OqZ!%CE6=6_+D6_0q8<`ZeY!6D4s?jg83Hchb_*lpz8Y{F-Xk#>StMl9E&yM)oe^ z8vkGr3rH|vXYl(f+5IaRfRg*#afF!&WFAiJa7Mpl#YTI1&ZR_OR9HQUi7Bj8JM$+I z%M!)a%ma+mV*C}Dv+ZZYvw$PhQFBUbYr6-4 >67I1pm*lzC6*z?sG7tE27ua&dO`nJw&ZPt5YGx>ZE zTP@P4gam%_(P|nRIg+LLpNyHYvt5zms(LZMru^o2N+V67b8_}BiY7@ZqqY4Bf%M?d zQQ$JN$ld`jA5u_Vl@knwd{R@h9;)&uN8CXyh`HgZ-@Mk>? -on=PZ}j`Q?4#6~*pc8Bx)OvyG&?SV*0NP6ekQ 6jV2^EM2F& zJh+1Zu4eI#WIZW_hMJo5!-vlvi0(cQ2dzSZfr03R6d1=>ORYC3i8RE-#PV`~0}to@ zFZcP!g?(4AWjzzNdlZ*;+?wT~mGg}W#*cHCvlW-qZCmUGYB%TVXJFkMHN#9Qk;heG z+u>?6dZhb@!1;61^dWHlZj7{nNuiQIi!gOw&PoM;27qb4m#GB+g90{R(DN{0r+}d0 zu~o7}gO;A&h;wgcfB6~XH-%D2_1@Pe4bZ3YY}W4$U;N4TzjY1>=mY@pVt P%YH!3aZt?VoS2##BX1V$c=v^|0~GYT zZ?yVotKo+B=%L(?vctdq;7jx9!Y@;b5IcK&Nh;NB*au TRh(S3#pjvQ#9RFU`|+_`zX0NJ%!7sv^qZHzwXn>X?Y847jnM&h?Z?ue z?Gxc8#OIInp;f_GfiHlM2&k0Lzt62HLn>5(4?jf38=D(H;{zY{&K766J72t-my<(M zKX;D9Zk9s)5!bom R?rz?DBdYU1*e|0snOFFi&pujVk7BE4?M8qvW6G(*k%rDDQ0|MH4cz8tZ zX8lf9X^TrKLJ$z#(1GnGlly2iyC;@Z*mr91YVir{p*|<)QOv;`L;Sr5jNJ4+kKgqO z;Dlrgxo?i Sw?)Ze{j%Jr6}lpiU%tGQ5D~9?&ISlvOZJB zmjU! #6CtwAu`X+uiJrFN4#;%>)VaH_1e_b zMKg1Anwqj$ *>vTXZZ!1$k+%2=ehLD*^h)I^l$x5SS8 z{QUJ1)Jc8VpvQm!1v*Yn=9c2(h}`1cw6sGRLn_81Y5;(%sz$N{9yd-mm^bk80aN7D zmepyjqpQm=D5#Gf3V70!eH!K*y6Hi-@QRX>65R#|;owdRRMV5y(6{tox6W>8X;(8_ zJc^1SBlP#{YjJ-I3Rvh|*L!hjWV^e&4;E`1+{e?LI6tmfnu?2erE!;bn>w$S>x(Qd zRynghPl1J(VJ5)4<`Wb&d%wB5Z$O)z2If1RuZ1b3aXH_`rqqma7#U@28yS|Ul~fqE z46isX8rJ$8wFj~pwGWzB1N)fFSmRC)D^k#p+?vxaEK$?ina9UR;`W=Lk|fQ9gd(Oo ztK~Goohn5tUcTM{%6NG19v&WU#yXmrnQbq}i$2bms4&b+QelSY@xK2S6C;r6@Hnol znDU`LsibOVe<}!1k}?W}=i=rjfy$~^XMCC;Df)09EulsxEDW@_==*Td@H1cSwvXCn zc7j#Z{$T^YBtbO_-Ft)re0gvi!!yur#YGjef3Uwz4nnuX0iho9Bb;kC8n8uogHS)} zvH)^PM7QZsrr=g-C2xLVAwbpL;KtwP)&IVdx$j>`ioHOo(J9k!aKOjMm+v1?&JYSU zNx=^nSJMy|56*2Tqx@UFTBTD~s$KajVr^}W)Aa9gTi}6ui3XnJYh)yhu4W NTe;XSM?f!yKvln}zp^~7W&p;niIa|(30BhWk$|b3aDjpgd zDkKsJOva^vxrBHpbv1Cn?O>{zG-fQJpby}WxhVnmz2PXLx~7JSjj_pT $-JFEgiSu$i$SqJ9|M~p5)N% zg#jR0ih`wwl7qLmx1wT915{hgMAg`M`QZLOUMv_Jw2|n7k+ZvN!_Ll*(bLw}X3jwv zH(>7=d|enu5HbP^!6tD<*zQu ;3KFyxyF2=dEX)KqpX zE^llA&h$su&9B;8?e~2}*-P!2aVGC`8E%DWWPcGt_ESaypM)r;@K=S>`lb|j&(Z9J zeuFlksJFKV3@GdKJ~VE0Jl!|}%PsKf?C3>)jY(I7Jx$CSUUL$YEKzB`nlcuat*tE* z{j?oVcvp_EbWDB%NQMG?dS;d?1of3T1Kt!IKK^J#yaCF_ZI%*4MMT&Rpv_l!8sqh~ z)=gC^ijIij^IP9Oxc572wBt$7Eq>mf8qon2$K`tYkrHPmHC6XjFk+Xpglb_}i+jdO zS9rH!1l)>CAXA9~Tg7q*SWm3jsK}JTuNag2chiVo1*__46i- U``( znf`O1wvG;RNmU^ca!M}aPbzwPL~%Xi#gllFqc$*;+H?_hyx>lN_zrlghIoSBO;i2P z7!PoHcIIpz@?|P{ZjU5LqHhrp5XjSPfO04p7$U^5dz3TI&(Gg;+pL%C%U)i308|Fx z_0yqfd}=an!ng1+OpmvbU!{WM;;tfay7d2+6qjLOU`$t?=!b$Ru~AXKY!^ ZMRqad=6& g}aL{g=@LX=!fuYkDj#{AyB%J}a~t&JD@P9VFJl3^(%$ip -E(q{U@QQ)KI1oL+m-SvZwf+;JxD0xhB{wR|at-LqK zS8-8M>t|jrP4^Qe frEr#7aJT#Qr zWIw|!zy`G2>xlqPisOPDu$#8-{kZ|6D^hG7UOT59Ph`tgGc>Y?b63j#{{Hmplrj00 zm9VlIPJNnk_?{wByXVppUu@;mDY`8&v2&!?Lh}WOu6v#uBOWR?C`I<*BZfGtEtvtA zqjB&TB*m`p(FE)UtzIjUNkty}*Q7SquqC=Ga!Q1A?|cqjpwsaYsAs WxT zy_C9!291j=5I *w`2v zl0pY8KIqjm8D`%8UN-i*K|XNPMGpnw-KG3{E(2YXH4ur}T?Ns58kKCjHS;9#Wbd!- z?#iiZ$jU}`S^?5^?h>VOzh3l?kp1wXwVfT;8-2O{0osiXU_iiF53@uFLcreZllA2b z5?S`q>OMvxf={aSbn3@HfAt%Ft04?k<%kQu9Wws#x%`&cfDQg{HZ8yv4dI-Qa{q_z zMBPn91C&4q&FVn|dExbEekCO(W8@#aU+Uj?7Rt&gy?S_YDC;cy8dN;QWS+K$iGX0d zLuL|Pp*o9>{2E!{g`x6x58W{)u;~;mrw{_MvevfNPcMDZ)ydQe@Sze?KYa`^+uB+k zXlYa7v<##`KVzh=h^X^5NABN4r7bL@1Ro!Mh-EQt1UL8~BHpHQCWm94MMb4tU34jn zCc)B+*3V?on}oEryZVza%>LO(Pz8hIG&ONbO7^?Ly`k*RKJE{{Kb-HDM#XnFcLuvt zCFIm3z8CIq6XsWFbw|H{9+_(FUs6Sq#Jr2%X8X&X&Al>{fUke<_T4)pyi@ek)4%kn zI=4&z*OXy7z*i?`^Bk|caM@r>MuE%51 JGSU>W~7|Yy6w%$;$q=+1SL) zJfDeY%4P{100X;O6;E|{d)@P0jnOj8H@3pH7?F`qH=rc2jFmK`*RNa%+>daP5+(HP zuRK6RZ>(046LbbYp&CX&t7b@dG5~|7=EA`j3IMhorJsxri%oabEx$5DTPubhtH&AL z-CPV$YN}!uVX#=afv)J*>jD|`4@A{bXsffD!#(74 znP_DjEuof?2Eu$UBdapplOhi z-1+&UccZ>AKLrOT$KNk@_jdpo4i<-$nSdxLu=XqWD)(ppcP_yB>D1E$uPAjUK5njl zYop0L-^E(3;ohFJdL1wmi;AkJ+HET*O_+_e?51_p)&3|bn0w0le@S?Li~?+tb;c~; z3X=(jq0&meETNfo=>8%rpX;ythbvnGc9%lZ# 8;1 z-mQCVQy1LQk0>y(t+Fzp>s5MIbL*7djHxiITD`N`MSpTs2(proz@8;iOI7^MG2BVn zHs$QJ-^Y>sAyBktu1WnS402yBjN2_4 zd+fIiK;vzw_bY-mSt+F~tQLR&=~d6*JrqrvR&SMuVZp0(09Pi544tf){KF@B-&+q7 zQ4Y0&Nz;=PEn#=>@;(?uO4;*n%@Z+QkyUrBD!_l}X8JVnvE=+@RP>(P?eR1>SHp$B zdW$`X(Hv& SwC5>l_GoPp!{f7?`2yaFl*`Jjw$aXtqEefa$H>I zbgWFw#N`V95*STCHa6X^mqd-J{To8QY&x6gENUWcjjLL_R#pAU4CT)>!W-Ry!s!YM zzAB4U->ttjHxtJsE%d+L`B%&^c}ZGBI9fsU=JEr4 Aase1p0(YxgXUN_${gHcG yV) Hh*ftCHuOEql`4)mD>5L;z!(nb-C7?5+WfVs)GAQVm z5{|8RBlj>{UtbGhetJxgE53^+CoIWjaJwwign_}3-a&JqP6NXjEZ;YzWE|2gme;q0 zsINHqLy?2-@6RnPFy7Y!p7*vC<$U1hr%sgmQf+v-k)tiy;kx-Zxz`xtNQl-VwjXIz zL$PzUA-p`MsFcLSWAlPL6agCFm_8<$>0upjvsWsTrT=UXh$+`t X!m{QS<^-$Gw2s=J>6-3a zlYY;|BspH*7v=33uk mN6hf_uF?0qoJBvqWtIa0;L}-(6;FYew?5f#VEhs|PT}&_L zE=wPkPi7!4bV;)v*&UaLcbBU$U$s8tALB($!d~9?Xe$IywK1_;F+>G~JPNk<_8Lql zbKZmHqUcwLZ-v&mv5|L|PxVGdK8xPupXoa?7b 6PUS>7tFOw8Yt#q f9&L`TX$KR0}i zz$XSc^uAK#yKYjrQ|Lf%K3g0QC0;b)dv|mnBB&!^DMw#OMnl)rMUG|;9B&n1M@N$w zM0}rV`t~z~fF?ho=6FIXJ*u4pe79N(;}Hm+vW=!QbiZHxBX?|wup7c>Bdc|CTehOl z$(#By#0V44@H)3yte@J7JjQ(5--%Ps&zSYOgmc#}#bRWJVRIx(S+{YC?5$=)J@zn~ zF)MbXUuMg$Z-{0tpuI#E;uwSz40%&c-jA%(-h^X?a(jp9l}nYrbPd8r@=qmP8Fw8x z`y$zyg_*UwE0~l;ihP-#^@K@Tw|8nJIYt$t(x^SH&k62G$Tp^l*@V0oHJ(RNE?aQ7 zh8;2oj#4&lc<;sebx}kF JEJA^yG_{aACq7E8d6vSoz-NK%~w!Wq!(SuF;HtrMZ z5b+5z$ZBQ^--6rX3`n=}+g5 Ov$o+)~J-q%ATIQ+C1syQ&xXhYfhu&1ZtA a9rCyF6LwWs}O9c1-F3ldNzS)sz$t2&QIQ_W~;$35PFt} z)#Y1xe(0P$s1#oHo+Si3z4LKzw;fmab$GX~kjH3|@`LBbC7dDZ_I6v!wxZq}zFiXu z8zL2f>@^vw%a2`a-BZ9nxjtR!oJLNzEM9n=`*>aoHsLo2$`B#=kUCUUG zkw(3_^#bC`8w+eIOqxiDqF$eVbQ;I^|Fo`WW@NP2_=$>ib#jV9DzyD?NdH{+-rs+p zbbpMahKndBt^t}C?4PU=hW#_KAL+$C3F-b0=Z91bX_PxMZLtt+%$Hc_6r(Gu^y z$CvvkE&o^RkDteTdBlDht!*T;(~(I-=Azs-i?Qe(*)sgJC9E)3n4rsE%8pe|-FCw? zY3Nw)^dS1{myzOrR6nqT!t=WkOkiq7D&Mp<67ej!h@45T&X0Th1}ZBOO1X(j%JdAF zaGJQ=>dI>5m`W>vSa3{Cf7!kPS=_+ZiB%9@qyaiw)cUDjvRr0n5+v=yhKq=~G{2&P zO|hY=HVIq_9kBHkf-mDB35WGgvHqnte^_~gO8LT?FVllZfMwV8k~Rc8%;f6cJGB*~ z=eXO9fR3PuK?ChfJSQs$BElDh9cDHib05MA`9&4dO4
E_t_U>O_s>J>lcez$c*|5q{E8+6rbZ$Zpk`8&p6KAXk z?_G0#@b?dy0==uXP9o$9Unthl({*+t(Pl^!aFj{3D|Y zLS>9LRR)}vBlnC!g^$kIuvv+3EJe8Vl(?{(Ui zhq2o389A2Z34RGuMLh~Je({NYwc?`}24x7KH`;KiOTS&o3EnuJO^@u;1KjOm#-xAg zOPDm0Y5wih?r(r3D7k{@(%RNSt>0Tk`ky)&zEr6GD57wpayhPBS~UgFUfP^3F-wm9 z*)d5#rA$`xf4GdH4-+2VIvxt7t;03l9v;#vD${S 0O$#z&Z*Ut!x>V7&Zj juOQKR{ zDnUNHC)q#11}V@{k1WC5L`OL#{ry{073e^{ ?$T|7lJ;PGqQTjn53TpcX4&;zm<$VnNd7;B?l$ z8L#`hchRUgpf|f=+$~FYHlxi)SvQs!6`pen@J~b{qQ~8(<66&KzFO(LxAhf51I74g zFfZ22rk4(ZH`+W&ZFYN6Dd>S*Hbew*hSyT(Pm_%JTO7mUors2*=|emRWyHP#^WS<7 z2XCT;MThIQDr(9d`lO{yR3nv&JPDd^?rsQU!os8qbPS@fa~YU~sRcj$h7F8&8FS&` zC!>aXdb}QHXFx+cC+D @+S*7_g|>ZE=ta7Nbkz=Yo;eBLm9=&|);?exNh5F`6iu zp R+o%lL1&Cos9B00(+)8)H^)X2XoPBU$E*G0xI&C z;r%iorF;(RGGxwSXAkIhb}pw5`oo%ld5??GRIR+_yV+Ofd!J5-GKGKu+z8z7Yjn4( zD?%NPMT<(+@#9lL&5wfuU?NKYz4Lu~A%%eO77&s$XLPlx63z<@jM{y=kSfuhQRoLs zyj(%(%a;#B)O8A<0JR!{jQjFzpN+IJBQw( S@Jv;o+w(#vQEbj{eeGK2 zvd}!na`qb*c~B{haZ=cmkPv=wf7v2ie}&UZ(|gB_RR;ffa&i*H{&JC%s7>K*2=+Fc zmrz!DIVpgwK*YgTdf|Fk094G$jB{6n7Hc5*lk+1n5fRYiL%&&k)Qk+0XZj=^T;#jk z-pvE_VB;vBnDM@p`g#{^&=2D3`ue>=4o0A}Uz2^czu=JJmT0^Jp}J8kDaB^$(!B%_ zQGH~9OAIy0!EfS=u07CsY1DJ|SF$MJW F0!L<8D$b96`uaxkK0KcLx-4&i NlSQaTBU z%fM~hbj5tQUq|Ss&0Eig@BjplSw @zJgI*m #1MZ>x3uj82{d9tb|4kB^Umo6xYZ;$ot0 zN!hSbjniu{dxwUeHF$(7xBt8saY$}GAsHSX@?1uJxCB*#T)}^hyi=ry6O5kS1v$L@ zp9%W=^_Onb1 13Ry+Idc*6B<*2mBgFARaJ6-L2!dpO<6;r`@i5OZOx z(_xqT9)Z7Dpdy=6-* V0h>We3ggrud=%ayxqVv&jQ}trOOZI3Og@%nG}l zIgt e1evazPf4;n&9IiKuQu{0}uUdaXY27L~G3 z oCE1p`3A*UQ6+9_VLg+UZq_1>!!3LTqulGNHL5 zM;<|XdDgh9|0iH({JAsyzlr&sSIDOhGyVNbzycn6uxg93W}o|+Z`U0uJLpv(B$w6f zyQ7PGRy%(r%_PLhq#I6oddLOLhp*rEKHwpE#Q*J^;8e{?IN#baQ7sxDPB|2I#bfG* zOY^djH8}lXNEtHr=ev3UAn{}diVcD(=?K{N4zfZ5z`xuj74EZ{iz-sEg%
@>UU_(7AEmJkL@GfV!s-mvad=8`@MWa-Ou)N^5d|h2&KX{Zh zT`A{szC}-hrlQomFKg=B+K-5CO7kqQD|8!3Eyry#Up%H)z)6fsghBo$;_0$5H|eJE z{iV+hrdj1+M{c}rnTy=N{zZKsmMJSd*V#=XD|FfU*48NQQIxK8-tU(F*@H+E-7Qfp z3TREpR?*e=X52ar3K8f0Q 15Ij~H1YAcKwnC*GhRR|Z#(pcV zRldWWm4qayks-CVEti^ZeWM1Ii>;5fu0^tjmSLV&DKT-f?o5*q85FiQio}T91SD(r zZPYU*3kcG~xb`NkxU{rn4Gq(?91Jrufxx2ycy6sJ>>1rM{*dZ_f52uTGDdT*cQ(Nt zJRifjWezR=I>y4@Bj~7(2miL%WSETR8zc;}Qdlll&bnnMy&f8MgcWAziSpVIRjz|G z$==Nrs}_FC? dkYnM0>NJUQ%4@ODv19w zP@fh>HmJ;| Jad~yG3=Gedjo#yGq2TrC=_j+6c;!k(dzu7|UHNDj~Nj1F$dWN8Qp%H9T&MF|V^5 z?oCf-YYzfmE-oIXWVVXo(= idnycb~47RS~HbAHOdaldp>u z-;n(U3BCHRv9z|)WRuxkSNQEw-R7v-P(4chBENH1&Wrm y&qB=7qX|a!p5ATxIBop(+&*HQAfrxdN2|=_xH_;nORX-6dTP?AA zJ@G`ECA%#`k)sNHij9qA2R1f`3by)scbocuxGrd9lp|)};94Zg0@g$?Cx|ala539H z+<1q|snS6Q2?gZM>2G1}DA`dU%H0AZZ7Pg$VnMxx`}=%|edCm^M@P{F1MtRu9ft)= zJ +dQaYR&hll9e)b;(IM?P@1vKm;ZLAhvzJR4)~HlBmcKx5u7EJmm>v^UTci0 z$L=~F;{bq=^F0RUrAL7UE?pAN_7UXtb~`n P~ah6NWOBz zx8s?st997FaaJd5u@k`a4al&D8CvKsB*uOHlMCb{AF;WdU7c|f0iKaubt4|7gsO&* zl!x)>Y-mw zF)F1aJA3iBPXuZPYJW2R;T_)qN%+QZ5Udn|Y-VT?1mZD;AKiWP((_ XS4v5&l zr8^(n$9j#W$)wrTaMrSO4`l;?lPfqmxmrxoW&=E9+fHi0m~SH@BZ&dU0p0FEzR8k< z@E4HY#lyqz-N3r_^FN^U`9C7+%f|mKzA%t}st#0 4htymJo4 zXO1PWH`W3o5P-n&@J(zi2+C&EKRk@24iI9shK5!cJnXq#acC;TUe-W90AM~*$Fm=f z0l*C9N<>!r48(7%%%7Q=YC)u{r{|djKX)gB3PEs&5kqqU3*EC&;J6>+fA#$Z@^F7> z0FAbwV#Q6@La_dqc5J$4`X8}A3#Ole!9>t;;|w+a3h22LHucHL_|Lrlnkg2Uy6!a( z;gKKb%V*5y3#!#o_-_zq$Mpbhw@N%6uN%KQZ#t7BPsx@hh9cyXr`R%I`p_#t4)!fp zDn29(7Yv>gsCtxXi;KgubDbi4ORw}*l$71i!0U)grQ{qKf&~=lz{ZIeK*LsVXGCj; z8{KYt(De3)^iQ-y #;uPwf)X3-26O0 zJKM~;7j0^4%5 o2Ce~HJ_n`Od4 z4#a=#%98nv>765~R`y{iFJE@@Kn^GqWPse_=SDtDj`v+ip5F)j&TBWT&R3c;0_6WLy4L9!)p^Ob@0?{VJQl*v?;pWKKZ0J!Bn}Su)y{|G7RUb1TVI$d zh538!Hob C!LTB)+SalJO(*r>k;*;_m_6zP*D}En+Vlub<%+3+8W2 z#%J66b?u1E5?c`~0^^Ib-@(cf__iBQ%zV!SAXpqgz4-Q998}4k`%zm=4^J^1kmaWV zS8v;P8>6{MYPfb|#={5~(0Bor*2{X1Is4$rNKf`QTK&7D&Mkhlvo`O<*W(@F`_5cr z<#561YPBf!8HG#0JHNH9nnNg%+Hjz++0+}SG+8w9$rGt%LGQ=eUi%-&9pOe3vKjlk z^Gj$B(!+kUGO_u6GQs%&H_Qe7rwykiwj_EU6m6t$VrJJK&5F8F0DObX;k}S^p&Xk+ zKuUHo&}8rCm1>|iuJZN}|GR2hBsSU=raYSxpuxYsLW_a5hX5DQ2ABq>2;Ed-KP^%J zKg_jQqPkxI9}{8Dv;h_o;n85*gl2P-zXg~M|3H`VDEmtDWQ$7u>!#?K=$-Ash;1(C zfA>cO )NQTV KfQJjHsc5vQ=bHa71=usjciPYtTN^j8iM|QoY@K0WTNs0l z!ibeCB?$wXC9cA|VD1rNzIqx~;Ac<}gL2*E$fT!%lb@gA>)8L!1t>unp&j)8^M$N@ z7cUAB>=SdpN>RtIWs#Bbd*4iQyVOfjCu>H_(^54QLceQj$y!Wu+tfE#tEMJr4y-xf z2$8YIQzh7ni6t0-f%B!cuBQsM;20@0i{y#P`W+=VXOFSH3m0$uxGkb)sh}(uG*3I- zOYthJ&y0U3|Aoqa7? dbViliB2$jMWLRS6V;)b!c3 zr=si@0J2|MG|_A0kxoSKMscGAB09RU@0gP1#vx=-d2BC (Z&iR&~VmL}t)^f-s+W?|CE*5tHzp1aC=cOU2A*u9f49dBxG28>8*vn;T`2S|e@ z!G4$B`0C(k=annW+|(r+8h5x2lg|gyCccYMBXFVkdd%tN@Y=z)rYd~m#aq&kq&>%m zr2!pziKzT&q!t$(Au1Mz7Rex@P5dZI7R8J(Y_+|K2IjLaA@Qy@5HLm<`G`?i+okcF zw(mZMU^gc?m5wTqDu#q(ejl)Pq@%N~*Ne(6R3LH`>G*f=Ks$7}8W#3Xs$i^pQWvbw zynHs!$zr-l2uL4h&nO$4JSX+?YktRfxYl;et=M6(oNd1qIon^e`J1SmoTQ68Rya zZk`j@OX5vIH(vt`P{i-Z-p=uW=;)?^yD-K-cdk g36LVz+1Xx?T{B~c8E(kJ1~@dRlp@*T+@(MC$|+?NVQbc0 zdIBM^wW%pag$`Es%5x_IXPy1oS%G@J=kSkhzb$hteI{27(r(P{i`U`cl>1gt0Yj4f zCPpT0&D#gaQV*7sB~S30$x)D5%81 w2o^ieWLPI>7L@r z8pj&sO=i>H7?}@|jhyqY87Dn;2oH(9o<)jY;^oTxRTB$y3ge4&@~fK&6I0!5SH(lES>ixaI0-t7w?ApC_H9y~%y zSyq;Kdw0{^)MUA()6eh%82P0A)>c6dx1T$<3isrEu^qx^ZxE$b7+CL(kED~MexmT% z$Lkvp_S@4)@)Q$Cn@e_dcV{SwNP1dJg-aKF%TFt%05OQ%jRCd<>mo*mMIl!h^r|y{ zQd{0;U Hps(T$?jjqW{glZGx>R zo!Fp7Fj$2#h%LV{KZHMqarx|Ee;){}k35T6?8-1eJY{|teTIHGn+{z}@tm$QS)*6j zE|?+5CHtxI)5USibNq(gu$3WMZf)(T?PDdNpuwkrt^PR-{eRGES&Ci%mv&WEUw<$- z+ (yp7-3_xQNu5VyLjnj3L*a{8eM z+`8<}R0(fvZ^OHS{EiK-gO?=M`LtD4XFG>4<&`oz9bIXR=jTTrn$eqB{PAI2zVXhG zBj>Z~5VcP*0zTG_9?iRj5s5_XISpH&TI9YQy@|@7%ttpWK0d#?niN2so+Q}fjdPOM zpMg0(DZrno_q1Q4wMn)A8p5YeRL8@`4PXQ1EbJS+IHEjcODtx=rUj|&IMO28g}`xN z2`~K^)u`Uy-u7by{rF?AIqTZK@Yq@yxcGf}AZ%m=$RP2dfSMsLXv3smMz;yT@P?q- z*%0@gey;nhMf>m{(5^w|iGkp+A}hO<>ZX5P)M#Ms;I3GAhgPcn`T~ yw{T6H^@lFmi#IQx`g%#O4>RsIJ#s;sy zG4Jd00x3eqxT5liAfjOCYV1dV6eEvlP{7|z4;J3ATJ19jg3Y{8MJvn?%IWX*{6N|_ z1hhw@XK?YdC$AKi_czkYj!h2Lh;+X96BG2PG=~nhk5&7Tl~}3du6~#cHv7~+D8_&D zbebHr$Mp#;rWA6Gp*RC48XE$^uJqC*y+L}gvz|*rRK}lYbZ=PPY}g6_BX7FLqvr|u zfKUCJXyBoMs~FTNj>r~~M~m181W$koiW%X59^G860-mS3KGWOvvbdInI2}c{Mj48~ zc8QZ)B W2cd@=^5)Ts#yZPLw?l0$!0ynb zL)0}ciH0CV@`$Xz3cljJM`T9hRYH})IYDSJ69z`G&XF*}C#P`fZDJTwZh=N25X#B` ze6d)$;}2rM%nO1_)JQE^+z=m(tmllL^e 2S1pCc#xI2&k>P=71>bknS5v?P&> RMSR#S9V+H_OfgFLO?av$?} z SuCL$IaDMGar)8%qhH%#(yhgpkt_ z8&V$ODdYFjLDPQs?|2lHC^*Ml2mZyvHvRexM5N*E36X5nKW7+lT7r9iuoBb2o1DXc zMj(aH7={2K9n{%J(a)LzJQ<8g5D8C#VJ2FD(Z@P%@dG{20UC=P><~r{EC74Hp(yXp z*2X(0)#P$6kIM~CE;H}afh-8iS;8V7@egb;7Jd&a9eFSo{2*I~zX8IJz&Uz`4--u= zfYrz1CyH$ yNWyeQ{gyhiXzuAPBz!oDPu>h8rM+@Bq1kg}*2B}SlFQ~KLt%2o6fAudaIkB}K zS;%J5RF9c{Oi!-^jCq{{H4z&=Z=h5(p%E`*uorrYI$_56Yc3Ou1&tI%p5&MXStP6( zr*cZtECsS5B_v_Wj}^vHH6C7>8lfM LrO`pjxFHL&EA4_AaDJ31ew1N>yiB(* zls#t$FD7p2H=WILd?>rUyO;fm1u15)>w{Q2x9s3?hei87S|37&fx+TSv)h{ES8Ve& z-!iXW@j?^`CZ;4AWvUIO18+KB4Xh??e8l9ww;bzf7Mky&6K}R$9oz7}9_bQLdQUV8 z8)zFBiSqtIGD#T5&=lJhuTovxa;yK?b4|#zt+=ht+?5+)eC*_53eK$E%Zguhp*l-Z zjZf!S$j?ZN-xZZS)>ag?DIuZ=xSJs%GKSoMyNC9ztYv*-V;vWH+@Ec-_|N_C>z#2i zakvozGnEzsfO-JP*NJxrq57>}5)1;33N4oGy(FJv)8#mM0(u>`S;@yzFd{=O7?t%& zORZVATpUL@k90{B309g46W}to>*Fd8Nl$36MLs02Oy VqlNx>7j 7>pTiNz^(6OBviI$|M{7{`Um$W!#dOaUq#8sUlTGxSRekySqp@ z{i4C;0T6f!p0r=A6uqpXl=MbQhT;@wZIW`GS~H4$`$f9eH;2d4l=0I9Y6sS-i9z31 z7qp)0FZ&wY`j!ew)VFnVZChqU`R{w~rs`U+@PhITdx=a+o3QWvQ$F>mTqUkzq2NGr zAFEbu$HsL_w2qdg%G#K*6Q`pcSN6X7KL<*+Za-SW*(cFMbKP3{s~=9%eQauIUoOm0 zvwK6Fm{BxN15m1_huUre8>x9|lgfI7a1%9X?Z+o_yN(|=bG~`f6qhI+tJA{OHzQZL zDJ`>kN|4>4mcZ5PTQ2%CKs^ie$+Y5`Pux1ooto>F%^Tv8`QBW$!X7*1F8tPzL|C6D z%rGP|!xsk%&1I;2IPgrju6mP9q-3NitX5p1CiAQm%FChw$bp&oxeVX8$A8M13hle% z^#2gmBb+NtUSxH`s!R )2miU0DjPPA~I6{1REH z)LB?x7g9g2j$5OuJ~ 8pCdH>`DsSC-R}Fc zISQ0NHq6t{iT*D^ki5u=7WnzOhL)_kwfZ3vf3v%`%mGo%3~IHsJ&u#RCNh7Ro5P3C zX`w3T5`FU#srvIJky;rJrrn)K`(q~xGow EtC*t|~HM)d%&B(j4&tD% qV~qV?}{@_3kZNUcVkAgEz@aQ!3wwaDre%nN;aw6tL_J z<7)N9SduA*5>N+dh(Fz=vd@X}4(aS!78&)!EPXv! gH6`UDg`1O~IPtzIcv#e4v965SGIYA_b5-YQ&j)vQs$L`$hEc#TD zT>5d_h5SlWr#StGXnp4?F`%{#sOdcV_mAORzHWVCL=1)~%_!*ohYsAO6T S|7i-iPTV1|n|b@n!P|j}&;Ksj*o95KH7i?EB^@NSy9h zc*#g}@?0)ne6qtD-!xT@?DKYtCh4 S!FF1_8F512)x( zyK`C0!`9lCN;{qv)$CLGhz`Y5Vs 2eCS)E0q^II{eZ+u=? zXzOV5bW=rAQIWfCrKgNaXg^SiD@pl>IYoNgmu7ZSS$d^OCoSC?Cdm0{DV~86d9+E4 zbBA&|p1@E9z7IRNC+cPFt{8tZ5gosRd0`K}qPFHRMK?3k_qLA|D6hUgUKOyMF2GXY z-TWn6_j3e27Tj-HoXPF@r(eHXb82o*ZRi9X{585}-B2tj6GGmAR?Z0rc``~l#@#P) z${|4gF!qkPrU#Y%K}_l2Pp>!Jxyx@3@B*2uYX(%0$V2>Ah0}NxkV@ZaW9OC{{}ME( zk}UtWy6bO} B#ZnTY;V%<*%t&yT0*f^IhUEB{zK&a|~%T4Mj^VW}8N( zA4h~=A_8jrSWl?nK6Gj%5XN8MNvdJ7RxE#CoHzXN4)Gr(sErg7y-Dtxt4 Chu)<$&2B{Ylb=sZKt=Y&a&i3)#8i+LB+uO~} z!@Emfx2}Km-Xw?FN1_O_%z_u~=0#7$=qdW#s02e^%y&H7l-{{b(!CP-NQXvFR*pTt zf!K&~qaSPjqn5_l9~*x@OL|YdvJ6UR^c**5Ht?jR9!GGVw};oAVNu%l7oSsES@`|A zQE8cyqS43j;!|-2MiLy8zm7;ujsxw@Z*U6yoDqDPk?9KW7{AUDRop}8+VC85k-Gma z?%pA{YpgNkX!G~*kmHBV!zw(fxF775-lE%;{f<{Co*9>uYce%uCy=2^2a=Sg>$J7C z+4r3-cE?xZ ^~VJ&jF;0`nV$A5kA6m(#mZhPc0m=a*YsGQUHsg_SCZwb`H>Vt(irg% zMoJG=YqYGo+<3=^+xmNKBcoAOW%VSGOg}$NCkSM%adPqoeY>vD{`7EIxVC`D^6BV& zl*I+H)CsAF-3h%n_7`oX*IKu$@rdWecx30t2Tw0AqJP%AAAD{@!{ry7n;%$wwdSTU zGS{c|HGcFdjvWz OvMQ1i2`=so9ID?K? 0rJs445S(&Kp z*_2_s(%9ITWLh}0f8WNxQU~$I(grICo^9ueAqidAIx&v&KVAMT&hi{N@qK}6gqUi5 zS-sXruSitMDSJ;pk_cz7P&7_s#B`=sPGtROI)dY(cPr{}ZQ Hl&haO 6LD@*G(Uu< m)qoR2B2#$kHiNu?l{=t=(cQU01C zd)_~Od$eN0)-}#Ta4_&9m|dnC*;nHSgWfVX7GG)BZuU!UaB#4|NykbZV;?JX=cQAv z=Hd0q31wc3B|l%GRr@CIs?&av9k|`?q;)sTRO5@|QU;$>k$k4-&FanZ@79^7qhFBV zh^ZgsupaXKr8kKvSfR9;^3}TCY*X#uIo=8^FAMN5k4xH7H`%CD%H=0G7+4&O{W8a# zRmu*ZKG~TbP^>q?+3#Xh)54*sh~X=d4quqB$EChZ57mZ|VRbDjB?~HaiHYNk<$-ye zFR+`WBNE$;{47CRDxOZ5HvQYJz(d44OPNa`_-zp;98-7B{tgdk;6R>Uf_}5fFTAqU zz-NicXUuO@))UGsUh0j_h&GhA`9^p&Wb18&)8`xea7HK2{JGnW=v&TX|j3XiGFUXtvxF%uVR(Gn3fUZF&?_w?AVG*|0BL<0mEHo$>y-`&~hYaq--N$aI{OcR8jG_qY} zL$AK|&8N8YsFFv+e!by%*gVVYY;M6i-=t;6sUE}T^k+<4iCX^#lBOj4MZN7^`wL`> zeohIu0m(ZFs*m*Zv@r&$RaPxlCE#PlHsX#PtsEKGWHIi6%Kh@8kgvKkZHdD2$GN6m zWDGUd*=rH$ul1)=j#c*!qSCH){BxaIaUOC_Tk*(`DnHqGNv=$WpTPSla#NhL2w2j8 zp%-BBE7jE=P%f_FXPK$$Gd-@;Rvj+iMlYN;ml9YNsbN!`1M&0dy@ienD>8=^dfEVb zTG7uq$h>`8soataW{r46v~f?<$9IsMqm|}wcas233c%l6M8ILjsMGZAChOzc+MiAn zE+MnCKhea#kF}#ot2_XcO#LLE%&HnK4&c-5%~0~W4%?HGkPQ)C jM4nGLkt#RUF^x7UhOsY=_MRmS zCU&ZW|NUTX$u#~DLy_VWQUP_4j(<>`T>?$kO-~v7j@h3*yS@$a7c7<{SFxsO<#&M} zXNAYu3m$X~ic~hoscA*|GhKs0)R>_pwnst_OHaUYecXOxzT$R>PfYBbk-Bd(ts}#{ zn1Ua?iE}>1F{xR1+t7Z}<#u(zb@SWlM2d#FZLb$81EM@!V2IzNUN~YLOpPIz##xHV zOvS@Ip1Hv$l$%zMnak1Lv|05zTPJv!m4Y0TgB*iG9V>JJzm~ARh`Y;4*WSKb{hJKA z*MY6fnx~cZSc8?^a%R=ANu{Nn%aiwm 6}DC;y}|GkMU$PgfATBBh(PS4#8@ zEdm0~sDt~>5{`(6bg>OlN^Y2Pmz}__o$1M&3g0o(vS&_EnHEWBP-!>hsMHKXAoV=n zpBx(7^CiPS1;yyQK)P`FMIzUokuXAQP*rZlxx{4lI2dAzN_%WHZ82Lm77>^bTK$kz zlRw%fP1Oi@ol1EOUFIGL>>)oB;p1DBR4bUXE05T43$U`bIBpdIWM_eaffH}eG;M&w z9!6XaidX~cvMu&2L`zFMpTCJ33-*hPKmwx>YmMzc*U=HXrE}LVbQOIKb0CjkzDHu% zIjr7NAbrOs%_jVaQD#M}CPp(Zp zeRuqFtmUynK`1Si@%P5%&bM#1bUttuS9K}btl_RPj4AXSHeZNpeqp`+`HPEcmO^Z= zVZ#3iV)?5P+rfp<+FqP<6OY4N04F6*C*5*cs5ot&97*nLgGbw2BD$K5@YCq`NRybV zHs;Dj)9Us?rvgddyZe)GXK6SUC#BguM8s=oqt)G=3UJD%{5{TjW7tK~DoZ^I)Vdv6 z)2D i0!+Z)zW?C)J{p&|yB*dPBcW>zUw8gxa5aS@y|tR>iEf2!nu*IfRVXAZGw z+zQ-FOy@H=I;5tUPRQz(3z4>5a^=Jv)=uJp&GS0ZGan=67&NLip{GLbOXZS-qGaMg zc$I!wP)@I}uP?P)>nosf6f2hkJV2dZH>T{Vz(8oo;Fh>S;T!@M^&&@fl{Oe^-Jt4r zx7N9XMw(t{nDcU3Z;kee7AqWIG-2H2@U}q g3bSsVq!VR*9mFv$-t^Kd(Ax48J%$aX$+}T;aj~?i6ne) z+tp!7)b RUJv)zSC{TV0OiKj Z+2mJ4a$0$Mma=V6 z!i~)~mq|VAPu9hR$Gr~_88Knj>nr}gi#U`EFAFL9Ap1^R2Q?TZq9PRF!{J*OitD2y zVz*hEE}at<9+DkEds=OPu7ttiT5m>MBK~<3jkuKmj|jxs2aMJo?@w0vtfj_PDBDO4 zmC4B)uRu;8)}RqP2;eV>0%1ruDj8>V@j{0}GqZTh>~7G?(MKMavq)P+qf63Y$)F+P z`2h7*lkLe`{UB?^eOntq69~XQu;{|^Dx;~bt}dX(0diq~u)@Ui8(mzIqypMQ|2G%F zGzfcoj>@*Zsfrml(umd@J%WM}JsqJ$l|A#z8P7qZHPJy`fU>O@`&h6FUbdd;93fVy z#f VumeBvx*>38w>SCAqxz%p89uT`*0!&}sX|f?_0na#QqktKB={?6 1m!TO zb@J0wsve}ezdeU}7iO?r%$-`!{YEDTsn8sze9NJuxCmtoZLB(z2X0jc>!1erC}{hK z- sOi`h%Yc9m2|~rDI~5XQ)Un zrn7utQ_3uWCpCm{V1=TsAQ#WZq9Z#4Q6lp}pY4U }3YB`hkM;$Ondy-mbe z9sJZV8Ae>j#&<>hZAsj4^bn;Qg`QKvIroE~s}o|uL|HB`DnrLFT@;14>bfw?AVs<6 zj?Jv)Y4n3OlxMLX=t4LmDwS$RVQ)QqqfRlO6=b17jfAyKL!S-y>I~Bdhw&cdjj(x; zZAPhVo~AsKmPTmaP7z6Nb1CM~<%8Kv#!e1IKME4K&RXhMImds=DuKYnz2uBhrbvkT zqTE8IJ0%UjvXOQ#zJ-y?obEVrUFcsHJMSj9IEk?d{pz*-%N4GOgNz{w%S8DdJBc{A zsw!FEip*xS^Vb`kGUSA^kP#EkuCcj|fDr#ycu|XbdGLkQ0gvc~|3hRiTX}pB8|yP) zk%+l2O}B WeG$l(b8!mLc~GBc}GwqsU8 zet*P=!D<0z|1EdBP>-@8s79z3ZNaKaaBy@<6tpJCP`E&aNEAht8u(_M0$^5w7)kll z`3s&QWdzz6H7j3Eu45^aTFBdci4UJcH+X}v9Y+-tCY@ #M#F%e) z#}f}$rOf4Lg#}qi8_y+RMa1b8Z^yQB|IG(W>iQX3_tTZnIOY)Ub^qND%Ny?@=xem8 z`0^v=5&`9_5M?6YdzfR1YipuA7fI{>LSI;0$&Fv6jM&f4Gzy-DO}wGpjh+@MiaL3s zTo0<_Ny_w=i`XfLI>G918@2GoZdqsHHva9Gaiqb(Z?;=wyk{s`=O0 5P+{6Jth2hJma7814!5^9Q=DfPepoUFk^l+dYPwkGflS>icHPJw1*N+|pGRF88 zav&DkSr8geO+r@udu1kY_dN)N-doFoAQOTipTg^SeYgZSL -TKf#&Qxg;u!VVNj#?w_h0nbFC z92JH~8j+$)G=>;&z4*f6 zqxZoIetx=YO ({JBl=Gk3SO3S0O}3?&>?N C>0jsbphfS((!`q{hi zg2{FAdYotB8VxyO$L?j2r)zC#$z%QeLCNV2zG1sRJ{Z0ceozr!rBv$Z2&vtbW$*Zt zjX}=bxD3j&)Ai+k`R<43u?9=)>uB^W*X7c59(%q&A*~!{vi9~Tw0d^#o9|rZQrZ9R zq}x;GeJAxadAKH_+}q2KYWov5S^ecI&32_ {vpzUU&_Ne8d-b`W;frNyH_}l6Fy4&>Xl!Z}?5NCx` z)K4SQ=U+lkdqTe7uC-)@zAjtdyxdH7>P}f)){QdXZNRN%H&&Qu-NmCrT7vMF3cuc& zCW}%`m3QA3es(+01lUGj_7!|5#&v06Lw`4SJzrG=ROKu>uGvn{yBXf|aa7^yX+?+2 zb5|?tPtQx{*-l+PPc93G7S`cn`81i%c?pldohF~o{c*+~tMzZYX);dr$oZ}JB|`TO zSbR$Jw@6eCK?VRl<)EKqSaV}Th41>qu~o^**XM?cTOxbC4#U1wpUp3q$=d}g@^^NW zaUZ&!o_{>7CreTT4KGwwRGfhMKA!vQFEt$<-d`3AdGvZkzdWP)G &&RVjfgI`@h+xd>2cTeXtuY $NNS=XKn5Ne6;$v&!BE37PYghE3=z! z{t!M42pQ>ZbB-cjDK7;>Q 0m{3v*pd8yYy%i +mPU;fN^?*Jx3o AvJQ^UkI&AILyfn^O~tb3#ZG-Nxp-7C$A)-tsg=;d^mCAKw^B#FOQ*?e!u2 z=lkzeP^u4nM>&DGj43ZKKHmg5bds(PoqYL@W>xgQol%in0VLbv`TrK|9i&H1*a2yG zY$zM5f|PwZMQvw;oLpS)&upFDHZFWq`B+o$l-w+6BH{I2!@%BtJ%KL1QwW0s)<6}t z=D^1nIMymJTRawv m+S(-UYFkETUNHblDx~UstZal53T5YnOOyjzk(|FO_6Ya#$y; n(E57If!SEK?y zAT+ROtgh8vsjAgn*}{b2MMQD-^HxrsvYN5+){h?`j_(8T0&5;L@xzST4K *ntT(htr5exJgaE1YXlXqM1^JEyszIkIyXw0|VyIm%Bcu zOzYiGM?a}#aD^^UDfXT3qkX^a{E60YaO@j+_V=%!)LvemKF8(Y05tolU*SZ@XU47j z;^}1de2602Zly~X-f=tjgwJ|^dQ#spF+rI`V$WN?P&xYJbvx385KF2o(2jx{H+(#u zhs7vOLGUhN#nLpJWtJ%yVCH>?gbN5{aa^f?&u2O+D;5w4!b`v1&W2>mt%Fw-)kmbS z|A#NzbGg)dp=)ke|L2V_polZs&)aMgq@AAQY1uD-{6|^ZFQWu}1XCnCp6?Hm^?iP- zWRkb5x}L0EBvwB^yu-_Qjb(E4@D$JNN2YVHdMvCanex#PMqpr0h3N||t}J*B>=(bB zO!`pAO4_Y79o4QsPlRLabVKe;h{!!3LyJ)b9&276r_lbK-FE9e6-Gs&&KiP(=j C=%CVD+Q__!xg!D&9jz!Gjb6uHr zP*1b6t?|+UpWK$xhxXlzYxB6F*#D?xEv>?S8X32I*vyY!jYnMc9sE%L=i|wpEuH?! zzY|ho;(o*{kl&_}79brQKTDHMyl$2Py;FNWdDTSE(51=`*=TDMG}YVa*qBObQ&QEA zPn#u;DYJ6O7~xi}P%pFxiD_Ox-JAmCZzi+jLTMNZQi#@5BP70JWWRMFB_SetwCYsoj$ z>y~uu%s*D$tVR3{sL!6i% {n@y$nI zPI^4uU%3x~R0S_~Cs{hNP{6Q0d`m1_@Vk> WDG>ODnFGTw zcE%Y>_e+k6-hmmXMF`iKr>7)@I$r*J6wqnQj<}sp`3(q;ktX}w`NgD=5OO;@1YWhz zsw2o@cfy#*RxeIcHj8yL^M>(uwLnVXIuN}I2($xm3-HU;n~nF1ywCXq5LsvD2O;4y z(iTny0!2+StUgs!a_P9$UtB^jJl4CGj*e)uzMWU9=&TbWy(7KP`1kMMNypZpsPhvF z&mXO~iam#mwfUDxZy@mEwDc5Y@s{r1SH*KoO(eQ^H!?}gPt8wG6IuGs0}%x7BOp~) zB5oVnT2r9>%U_Qs<0UHEy20y&cqPh`=;6M&SQ*R8O1wSIfNuBj-Q+H@D}ELi2uBv^ zh@hc?XJ~)}b)a;eb4N6!j6=m@jS^+gXCa;=0kH-o`Llh4fu;Y+8%1GbxBUCpFD}+! zWp)_=v5_Pt7cNbdBv7|?%Ov8$L-M{%GS^cjL& CrLl-GiJ086Sn7J~E6ojH1eR6pTS z5V+!?EbsvJzh8;5;%g`u_As1wlUn+ReGK}7QL3x;P~hM}WED~(z*yq!G7kH-4m9uE zKDY@45ultO__8-s?l6L#sSl5ieYSbJJ)ZA&(PC5paJaO-0QW!t+Q$owI`vW*6EvAy zYIbA6Fs)yDyO{xZ|BxF1^22}!n f~DDPM}je)#)UKqh_yx!a71r>5{8#32&Cf28d+lg-R8pZffJNC{&;u6 z<^TiXg@}qFfiXyUF90Y$P^*B314WOjyEfnim@GWCKf;6I>yiEkrdRAtV0658yaZRM zlVHClW0&N;-kbrrhIA?wZ$QGPobDkQ0jCofuiGDv4$-Xq0c<>AdmJ2-fVJL(6kT4` z7Iqx+s{SAdJfOA-0|4$G`6IYHk*Q;-!AXsW1n4OOU=8>g)_Gj)EY+JQ|17OquQ6Q1 zkWih*iF`H!Lxqd$Xjb1Fj4ibRKsgj^^5f0#I^LDPqsjJ*EoUKlMamw!Q?x8eF E?F~i#vht)E)~i!))Mx)AgJ7xSG>o8l_KGVfy=y zC7*%t=_k20Hg*|4AbN`Q!zOi2O-*0q8x!z4BC0Gd@pS$ImX9=987ipIIK_++mmyq5 z&YZm|L8NQL)LAUQTQgV;9^wzIVww$w;zKmB1|T?MgTUgh^<@fWLBAbn0{GJQG@+zt zlgQ(W-W%Wo?56PkEYOK-VFAr!F@a8n`S~^oI9W3|EsYcuUfa9r)c)xKoXY%O)m`^U zDmpq{ca{G#grb2n`sH?DA=_g|;fATZyJffzxK_8KKB_;dtd<{>=K)0!(#7Au^?dKh zL%DUOsQuwm?`*+5$3Af$y3i+A9e8 z8Lr!DHVz$@Gs zz}&sNX6pO6#UWCbV|IF!jrVvy${Z<9@p2x-0 zQYxsFU Rd#1ufFy8{O%}Z!F%ROMLTu#fdBv%Eb2{=oN zUjzs&)EWH@%tGV`eBuJ6MzxFfA3U5TbaVvuoTkL^zHO~{Ul+3Y&Z*>66|;10T??Fa z?b5(arZ|o=@z}0){A``}eclb9)NXUWoAhaNJ< |S4blpyC>M;V2h-E&Y+M6|4Hj{sjHKOU-)%GE(iMx-rh{X9 z9-x&Z9^0{fYCYvu9ba2qH!bu|OI38_W{~y52Z83Ia}SSOr0dV+a6X@anp+Y9S6-bp z&5K~CA5l$B3;MoKi^kC&`-RDXMKCz=argPb_j!!N*A;c8!J|IEl=NYdk7xbs%E6p< zh{Zxxm5AB6cHJ$7F#|M3>wQG{E-Z)@1^|O3KoGxUrv^ zHT!O?I4Z@hA37i|0R@EjBiP3N npAecB^< zMe2mq0A&&}K7I x?u0r!{V 325)|5Iozvsr^0wTaRzuVV92m-LdcU-UHglOG&%iekF-4 z?`uHd+w*|_9R>ytn+PA&4Y~Z?rIF8ATv%xS`q#So_g5Xao3)J|ppV^xo>$-1g8s$oiO)ltbrsUbftg+m z7dMHk0DxF?cl71D5s5|cB>-u{+RjeCc!r3_uI(wRJ>xTU{oxtyb-KHmZg%9cw^!Aq z^o}mS^*^1K1LU)S+u@~*L1=wu<^kx)#Ji$V;a*eSd;*+9x4&QRY=E5ECfkSn=qKR7 zXli?S3IM*7?U=9@?9ZaTXV!>45O_>VD61^MEtf(mYnWyt8X>6)BzJ}q#HJ9GvsoRC zyUP_A8g)1-1D`h2374eD`v(W~$#;1m_XXfu)NxXo`3y&LX_xuKcKu;(0T4q>wBy6W z-#|~bZBOXQF-{~-;TIdA;|P$qEcl>b-}!LZ(=}$0{c&+{KS7qpgqx`nc}1& )qX`uNiz>I(1e)W%M-C1S78_*K{5v1p1 zy(vwlKR=Dk2o#5Uq3FOJ8W|Z0P$QT+mdW=!4*fsZXdl1C9{C$qS!#tWLF0jlI$kxJ zRHy$P5N<+%Uh@usAIR}QhhV<%B>Xow z|1NR>O>m$Fu`=$AWj$TbR|2N|51}~^31X#@72W^dlL)s)7>3^KMnD9C|8bh?y_frU zYKG} cZ?{rM%w#e0pAl$)<@P?lI{VkhYS+F zQuG}XEWR=p!50+`5bG*c-Py)f4b5WD*UlD*e>tl&F(NmL6a4#j7ynGVg9zkTR`dN& z<2b2cG8GmZTdhfFX~iY05*GrPVPtUaJ@s(EavhUxIHQa +Kdb)hJ`Yy+VrR4NjTD?S!80lib1ac$=@t(%2s~5$wvysiv3B+S8 zA+O-dBu$%H3XB&!5X#2Zlkp}SYxBivT0(~Uv(N-?me^o}j4$dPFoTwAU$g)_x~V=R zaxt|bgi?$W(o06i7vGeR-iv`?NRE-L^&1W}0vi3}JR(nB;Vf;Y?8@D@#JHjr$IZbZ zbMrPn&zIcX@RqUvyb-sY!dev_1Bn`wPb4NqO1jP#lUhrQonpG_P&H0gC50NR-j-m$ zfHg) Cof;q%UB9pDfF4M%cGD28H2hD+!6@}P3Q8T>8=T6fi{G9c(aX9|l6T=m= zl^vU9X&O`d9(D0$t)@B~pht+&ev0Q9AK%zgKo&8((jD4BwIbMr8ce)Pi-pu9&x{=l z*2E-Wv?T`@^fXZgp)VmLYz`Hf46DzF3`9sKAUEt#)WLh*Xt{8;pn(!ZjOms}>Jl5- z>FVk-#vQo()RVO8u&5KbrF2@%py`H_QQ_kpC}1dD!fmN~u0tR6FeNyEDjr>#9l?-Q zCOyb-F_;X@Au9U5mafoNN1fjYKiCgFN*3O$tv=G_^#yOHlavvghU*G4|Jnp|SSE3= z$k#8loOuc?A75S*9-)aP z)~+~KT|)nKI0pZx>2Cygt b^oIH LkeWA-?al8J!coWUH*#P4_Xq%a|%% zIFA_pX|CtNPgy>WU&FVF0inZWbnh?-`s0Gg%)(QKIklt>@hNRFgBkq)(-(fKdV*Jd z$(zCsQyNlcXItXt3w|RNr(ENlRI~diNVzS~zh& QcJODL7(-SBFs!OWzoaG T5KrdW%@eex3t|M5u}Ui=?tV3<@`~L@PF=2AvXl z;DL=lJjMV6MiCc<(gO)g(kMwZpfeUTi)kp~ -Y7-7i@?1ndQE~IGPP&kUKnj!*xLGy zB-TYFsyIrpB)kzg2p!XGb0{dLAQCtz_y~e}Nu+Zt)CL(-OX}2O%1o{hbdf?AQ~8rZ z7I9mNmCW5s$Zj~W3@JC^?OOyiSU?+oJOsQiJ&7W2Q&hOEWJZQK74YPVPtcDyMG8o( zzX>F6QYhIF47V|@JNC_>28&P%h_p^GIUsE49`XK8WxJxGzlFXeTc#kYi!x~K;~E+= zQJP~acN4d%=Q!Xk2Z+Ikqx*%~Qzd2)kWV6-h`}&uzAN>t6L(>vL`)R9VM7XF;^haM z0HiRcX4rM7xS442Kcv+@mnGpGJZVct{lrV?dsMmpAjH^
YQ3E6UvWBNb8BwshodcF^DZd-ajF3-n&YQNz v0q4|F-psx-L;1B;XJN^GR`2VLZ!N+|e)j?7GiI -m)$Tnv37(!dHFd44>pAfT zC2yJysFLb6Bx6IAmj8f%^11z-|DfgE&***e9Mvct9o;VfYzr_bBt+sYmk)pxE)=s3 zARxG6i$YLU9qOgS5)=Q3o%jDxVB@+HR9?KA^Y3&7GsnAPpEP{|J{iJNWLOz`{O9S< zvF6<^HI{P9AHEL(B4De*$pi6rCL==D-iy{=5n>}EmXmhfn;zwdydKIGXfc2ptDbIU z8^9&7UJcCK>Ef8 x;~D=d(iFN`{O*0RE)A<0g_i+HOM`D8)J`G zUt>E{7mNAlgF(CGkD8oEwdcJ3!4t?&ds*&XlIq)&Dr1l^`bVsfuM%WA&s!?L+9;8u zhY7O{6eB9I176)B2z0*SlX%N>$w{E_FJBPCIL;}~c*02$Ee|0{bnHh5zs1h#OQ)N| znt7RciJPZG(Yys~ x#O6md2Bu6J$af&@u6g zqfPvi8MyVg-H!D0K={~YZZwBktob`b9e<#4mmJFve2gX%Bh%*hi!y?UD>7gyZ{EbT z5v8rm?Lm7=R%GKP#~)P~!I IyB_qbw{Na~Fe*zHlg-m>MtqefeOoG~Lws?*7Vo0m)chys z!SMKW6mf$319b_(pVfc4=A7o;$_GNiMt1v0kHMAqKu@wHPdx_Kb9kO$9wG;L;|(mw z*USEOpNE&hVP4TU+)DQj0f@d%4nYAO(rr2Ew_ +qk$P4P8f4{hNMigmEqfj|NcxpLII%k^4-vgZgL=XW9ijSR3pTR-ukG^ y-K(^iv=013KMOeZJOk;l;|(M(GO=9%!}M`C !8NbSsr7yp}5+K2S_d zOduxa)>ShjT=HP|z6ZE`Z54~ >Q%54(N2%eUIwF={uR< zhmjkW3Wgcdayxyk`cl+5P~31F2&TfwSIfNG;QKQ08}xZ@s}u67a@N)}Ucq~?w)%AZ zI7+{sLeiC*zX8dR3;E| n>~`UD;q@Kwvd6p* ^z3x; z1l32W3e`}er7cRUs&o`P2&P4GLq10zeD*Sy6@9CiYfs B{xg@%fv z8?93^8;vZ8S;-6c*X=LIPxuh(M%i+N)6O&1ziSIPTmpw)Q-?YWMK0R>Wf`W++a(%B z%n@opnLCoXySdwNF4R=qe~2U~ytfWyFULMEQQyuH-BvgGdYyYAfe(`p^k%n@*`K^l zvEPWh`$L|Qi9&mOu?#3E?w+1jJ66+Md@V(cU8{VH(tM4L-wK1%M?oYHPn1y3U%!4a z|N3R}`gF@V50)Yo8GT`O_w+QjV|e2hcKP%+IGEwYC$fJl`eH3q)>FlIv6J*3#mLw= z6~XdL5 |2Lkxa8d{{OF^`G4t|TFwCZB uQ+B#wr$DL&!hFIkV%lC|vn{o* dAb6vVU-j@i@wwz0w o#)Q$EpkUo7 zX&t*Pz5G)$e4HL7xyKj@nFN_1xrC9Qu_8EynEiFLx3?l9(CY(*o^a{?&@s5~y6n`r z^2tsx#$KSYw>i1Ewvwc?^|o~DVm!Eox04;$c)c)I2_c=Q+A(J#(H|jKf2Y*5lzW1| zjW=#%)^EovMJFI&&3kWaax+@`4Fh@Ad64|r(UGqd>XD-A<5z-OV0t+65hb#6tmUT4 z7_4^i Zg 3#{Zd)2V46;L~I&xiXuueiRT6cXg zH;GNdc+n9AR1Qmzgy1Ir2-e*y@+aKM`sNECx%7~4#W|t8q(4SJ@`lDyWLA0HJe