handle configurable zoom buttons
[presencevnc] / libvnc / classes / javaviewer.pseudo_proxy.patch
diff --git a/libvnc/classes/javaviewer.pseudo_proxy.patch b/libvnc/classes/javaviewer.pseudo_proxy.patch
deleted file mode 100644 (file)
index 4d2f36e..0000000
+++ /dev/null
@@ -1,141 +0,0 @@
-diff -ru vnc_javasrc/OptionsFrame.java proxy_vnc_javasrc/OptionsFrame.java
---- vnc_javasrc/OptionsFrame.java      Fri Jul  5 08:17:23 2002
-+++ proxy_vnc_javasrc/OptionsFrame.java        Thu Aug 22 23:24:44 2002
-@@ -70,6 +70,12 @@
-   Label[] labels = new Label[names.length];
-   Choice[] choices = new Choice[names.length];
-+
-+  Label proxyHostLabel;
-+  TextField proxyHostEdit;
-+  Label proxyPortLabel;
-+  TextField proxyPortEdit;
-+  
-   Button closeButton;
-   VncViewer viewer;
-@@ -93,6 +99,9 @@
-   boolean shareDesktop;
-   boolean viewOnly;
-+  String proxyHost;
-+  int proxyPort;
-+
-   //
-   // Constructor.  Set up the labels and choices from the names and values
-   // arrays.
-@@ -126,6 +135,32 @@
-       }
-     }
-+    // TODO: find a way to set these to defaults from browser
-+    proxyPort = viewer.readIntParameter("Use Proxy Port", -1);
-+    if(proxyPort>-1) {
-+      proxyHost = viewer.readParameter("Use Proxy Host", false);
-+      if(proxyHost == null)
-+      proxyHost = viewer.host;
-+
-+      proxyHostLabel = new Label("Proxy Host");
-+      gbc.gridwidth = 1;
-+      gridbag.setConstraints(proxyHostLabel,gbc);
-+      add(proxyHostLabel);
-+      proxyHostEdit = new TextField();
-+      gbc.gridwidth = GridBagConstraints.REMAINDER;
-+      gridbag.setConstraints(proxyHostEdit,gbc);
-+      add(proxyHostEdit);
-+    
-+      proxyPortLabel = new Label("Proxy Port");
-+      gbc.gridwidth = 1;
-+      gridbag.setConstraints(proxyPortLabel,gbc);
-+      add(proxyPortLabel);
-+      proxyPortEdit = new TextField();
-+      gbc.gridwidth = GridBagConstraints.REMAINDER;
-+      gridbag.setConstraints(proxyPortEdit,gbc);
-+      add(proxyPortEdit);
-+    }
-+    
-     closeButton = new Button("Close");
-     gbc.gridwidth = GridBagConstraints.REMAINDER;
-     gridbag.setConstraints(closeButton, gbc);
-@@ -161,6 +196,11 @@
-       }
-     }
-+    if(proxyPort>-1) {
-+      proxyPortEdit.setText(Integer.toString(proxyPort));
-+      proxyHostEdit.setText(proxyHost);
-+    }
-+
-     // Make the booleans and encodings array correspond to the state of the GUI
-     setEncodings();
-@@ -361,8 +401,12 @@
-   //
-   public void actionPerformed(ActionEvent evt) {
--    if (evt.getSource() == closeButton)
-+    if (evt.getSource() == closeButton) {
-       setVisible(false);
-+      proxyHost = proxyHostEdit.getText();
-+      proxyPort = Integer.parseInt(proxyPortEdit.getText());
-+      System.err.println("proxy is " + proxyHost + ":" + proxyPort);
-+    }
-   }
-   //
-diff -ru vnc_javasrc/RfbProto.java proxy_vnc_javasrc/RfbProto.java
---- vnc_javasrc/RfbProto.java  Sun Aug  4 18:39:35 2002
-+++ proxy_vnc_javasrc/RfbProto.java    Thu Aug 22 22:53:53 2002
-@@ -119,12 +119,51 @@
-     viewer = v;
-     host = h;
-     port = p;
--    sock = new Socket(host, port);
-+    if(viewer.options.proxyPort>-1)
-+      sock = new Socket(viewer.options.proxyHost, viewer.options.proxyPort);
-+    else
-+      sock = new Socket(host, port);
-     is = new DataInputStream(new BufferedInputStream(sock.getInputStream(),
-                                                    16384));
-     os = sock.getOutputStream();
-+    if(viewer.options.proxyPort>-1)
-+      negotiateProxy(host,port);
-   }
-+  // this is inefficient as hell, but only used once per connection
-+  String readLine() {
-+    byte[] ba = new byte[1];
-+    String s = new String("");
-+
-+    ba[0]=0;
-+    try {
-+      while(ba[0] != 0xa) {
-+      ba[0] = (byte)is.readUnsignedByte();
-+      s += new String(ba);
-+      }
-+    } catch(Exception e) {
-+      e.printStackTrace();
-+    }
-+    return s;
-+  }
-+
-+  void negotiateProxy(String realHost,int realPort) throws IOException {
-+    String line;
-+
-+    // this would be the correct way, but we want to trick strict proxies.
-+    // line = "CONNECT " + realHost + ":" + realPort + " HTTP/1.1\r\nHost: " + realHost + ":" + realPort + "\r\n\r\n";
-+    line = "GET " + realHost + ":" + realPort + "/proxied.connection HTTP/1.0\r\nPragma: No-Cache\r\nProxy-Connection: Keep-Alive\r\n\r\n";
-+    os.write(line.getBytes());
-+
-+    line = readLine();
-+    System.err.println("Proxy said: " + line);
-+    if(!(line.substring(0,7)+line.substring(8,12)).equalsIgnoreCase("HTTP/1. 200")) {
-+      IOException e = new IOException(line);
-+      throw e;
-+    }
-+    while(!line.equals("\r\n") && !line.equals("\n"))
-+      line = readLine();
-+  }    
-   void close() {
-     try {