aboutsummaryrefslogtreecommitdiff
path: root/challenge-256/luca-ferrari/pljava/src/main/java/Task2.java
diff options
context:
space:
mode:
authorMohammad Sajid Anwar <Mohammad.Anwar@yahoo.com>2024-02-15 19:07:15 +0000
committerGitHub <noreply@github.com>2024-02-15 19:07:15 +0000
commitd94684a52764452af4edbb2a33b7d409306e271c (patch)
tree0e4a7052c4c740d03ef90644e220981492e502cf /challenge-256/luca-ferrari/pljava/src/main/java/Task2.java
parente515224a439c9525a7e7cb7d33fc4b4c9af9785e (diff)
parent0cc3d19f45790123a25f7f33d9c5b3b239a48c5f (diff)
downloadperlweeklychallenge-club-d94684a52764452af4edbb2a33b7d409306e271c.tar.gz
perlweeklychallenge-club-d94684a52764452af4edbb2a33b7d409306e271c.tar.bz2
perlweeklychallenge-club-d94684a52764452af4edbb2a33b7d409306e271c.zip
Merge pull request #9587 from fluca1978/PWC256
PWC 256
Diffstat (limited to 'challenge-256/luca-ferrari/pljava/src/main/java/Task2.java')
-rw-r--r--challenge-256/luca-ferrari/pljava/src/main/java/Task2.java58
1 files changed, 58 insertions, 0 deletions
diff --git a/challenge-256/luca-ferrari/pljava/src/main/java/Task2.java b/challenge-256/luca-ferrari/pljava/src/main/java/Task2.java
new file mode 100644
index 0000000000..75e231c2c2
--- /dev/null
+++ b/challenge-256/luca-ferrari/pljava/src/main/java/Task2.java
@@ -0,0 +1,58 @@
+package PWC256;
+
+/**
+ * PL/Java implementation for PWC 256
+ * Task 1
+ * See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-256>
+ *
+ *
+ * To compile on the local machine:
+
+ $ export JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64/ # if not already set
+ $ mvn clean build
+ $ scp target/PWC256.jar luca@venkman:/tmp
+
+
+ * To install into PostgreSQL execute:
+
+ select sqlj.install_jar( 'file:///tmp/PWC256.jar', 'PWC256', true );
+
+ select 256.task2_pljava();
+
+ and then to redeploy:
+
+ select sqlj.replace_jar( 'file:///tmp/PWC256.jar', 'PWC256', true );
+
+*/
+
+import org.postgresql.pljava.*;
+import org.postgresql.pljava.annotation.Function;
+import static org.postgresql.pljava.annotation.Function.Effects.IMMUTABLE;
+import static org.postgresql.pljava.annotation.Function.OnNullInput.RETURNS_NULL;
+
+import java.util.*;
+import java.sql.SQLException;
+import java.util.logging.*;
+
+public class Task2 {
+ private final static Logger logger = Logger.getAnonymousLogger();
+
+ @Function( schema = "256",
+ onNullInput = RETURNS_NULL,
+ effects = IMMUTABLE )
+ public static final String task2_pljava( String left, String right ) throws SQLException {
+ logger.log( Level.INFO, "Entering task2_pljava" );
+
+ StringBuffer buffer = new StringBuffer( left.length() + right.length() );
+
+ int max_index = Math.max( left.length(), right.length() );
+ for ( int index = 0; index < max_index; index++ ) {
+ if ( index < left.length() )
+ buffer.append( left.charAt( index ) );
+ if ( index < right.length() )
+ buffer.append( right.charAt( index ) );
+ }
+
+ return buffer.toString();
+ }
+}