aboutsummaryrefslogtreecommitdiff
path: root/challenge-253/luca-ferrari/pljava
diff options
context:
space:
mode:
authorMohammad Sajid Anwar <Mohammad.Anwar@yahoo.com>2024-01-22 18:19:47 +0000
committerGitHub <noreply@github.com>2024-01-22 18:19:47 +0000
commit64774d41bd8c23d9c281dcd27228aaa53967a822 (patch)
tree29d250990e5d207389956486e34870881034e1b9 /challenge-253/luca-ferrari/pljava
parent1126463e11f729ed009174cca95f65443b3ec575 (diff)
parent52e2018af75d08a9b77b8e3bb56a7b2fffc6f42b (diff)
downloadperlweeklychallenge-club-64774d41bd8c23d9c281dcd27228aaa53967a822.tar.gz
perlweeklychallenge-club-64774d41bd8c23d9c281dcd27228aaa53967a822.tar.bz2
perlweeklychallenge-club-64774d41bd8c23d9c281dcd27228aaa53967a822.zip
Merge pull request #9444 from fluca1978/PWC253
PWC 253
Diffstat (limited to 'challenge-253/luca-ferrari/pljava')
-rw-r--r--challenge-253/luca-ferrari/pljava/pom.xml67
-rw-r--r--challenge-253/luca-ferrari/pljava/src/main/java/Task1.java49
-rw-r--r--challenge-253/luca-ferrari/pljava/src/main/java/Task2.java75
3 files changed, 191 insertions, 0 deletions
diff --git a/challenge-253/luca-ferrari/pljava/pom.xml b/challenge-253/luca-ferrari/pljava/pom.xml
new file mode 100644
index 0000000000..d9047c527c
--- /dev/null
+++ b/challenge-253/luca-ferrari/pljava/pom.xml
@@ -0,0 +1,67 @@
+<project
+ xmlns="http://maven.apache.org/POM/4.0.0"
+ xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation= "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" >
+ <modelVersion>4.0.0</modelVersion>
+
+ <groupId>PWC</groupId>
+ <artifactId>PWC253</artifactId>
+ <version>1</version>
+
+ <name>Perl Weekly Challenge 253</name>
+ <description>Implementation of the tasks in PL/Java for PWC 253</description>
+
+ <properties>
+ <project.build.sourceEncoding>US-ASCII</project.build.sourceEncoding>
+ </properties>
+
+ <dependencies>
+ <dependency>
+ <groupId>org.postgresql</groupId>
+ <artifactId>pljava-api</artifactId>
+ <version>1.6.6</version>
+ </dependency>
+ </dependencies>
+
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-compiler-plugin</artifactId>
+ <version>3.8.1</version>
+ <configuration>
+ <release>9</release>
+ </configuration>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-jar-plugin</artifactId>
+ <version>2.6</version>
+ <configuration>
+ <archive>
+ <manifest>
+ <!-- This identifies and version-stamps the jar.
+ Not essential, but easy and useful. -->
+ <addDefaultImplementationEntries>
+ true
+ </addDefaultImplementationEntries>
+ </manifest>
+
+ <manifestSections>
+ <!-- This identifies a file in the jar named
+ pljava.ddr as an SQLJDeploymentDescriptor. -->
+ <manifestSection>
+ <name>pljava.ddr</name>
+ <manifestEntries>
+ <SQLJDeploymentDescriptor>
+ true
+ </SQLJDeploymentDescriptor>
+ </manifestEntries>
+ </manifestSection>
+ </manifestSections>
+ </archive>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+</project>
diff --git a/challenge-253/luca-ferrari/pljava/src/main/java/Task1.java b/challenge-253/luca-ferrari/pljava/src/main/java/Task1.java
new file mode 100644
index 0000000000..af8329b557
--- /dev/null
+++ b/challenge-253/luca-ferrari/pljava/src/main/java/Task1.java
@@ -0,0 +1,49 @@
+package PWC253;
+
+/**
+ * PL/Java implementation for PWC 253
+ * Task 1
+ * See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-253>
+ *
+ * To install into PostgreSQL execute:
+
+ select sqlj.install_jar( 'file:///tmp/PWC253.1.jar', 'PWC253', true );
+ select sqlj.set_classpath( 'public', 'PWC253' );
+
+ select task$tn_pljava();
+
+*/
+
+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.util.logging.*;
+
+public class Task1 {
+ private final static Logger logger = Logger.getAnonymousLogger();
+
+ @Function( onNullInput = RETURNS_NULL, effects = IMMUTABLE )
+ public static final String[] task1_pljava( String separator, String[] words ) {
+ List<String> result = new LinkedList<String>();
+ logger.info( "Entering task1_pljava" );
+ for ( String w : words ) {
+ if ( ! w.contains( separator ) )
+ result.add( w );
+ else
+ System.out.println( "SPLITTO " + w );
+ for ( String ww : w.split( "[" + separator + "]" ) ) {
+ result.add( ww );
+ }
+ }
+
+ return result.toArray( new String[ result.size() ] );
+ }
+
+ @Function
+ public static void logMessage(String logLevel, String message) {
+ Logger.getAnonymousLogger().log(Level.parse(logLevel), message);
+ }
+}
diff --git a/challenge-253/luca-ferrari/pljava/src/main/java/Task2.java b/challenge-253/luca-ferrari/pljava/src/main/java/Task2.java
new file mode 100644
index 0000000000..9afa1e555f
--- /dev/null
+++ b/challenge-253/luca-ferrari/pljava/src/main/java/Task2.java
@@ -0,0 +1,75 @@
+package PWC253;
+
+/**
+ * PL/Java implementation for PWC 253
+ * Task 2
+ * See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-253>
+ *
+ * To install into PostgreSQL execute:
+
+ select sqlj.install_jar( 'file:///tmp/PWC253.1.jar', 'PWC253', true );
+ select sqlj.set_classpath( 'public', 'PWC253' );
+
+ select task$tn_pljava();
+
+*/
+
+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.*;
+
+/*
+ example of invocation
+
+ java=# select task2_pljava( 4 , array[
+ [1, 0, 0, 0],
+ [1, 1, 1, 1],
+ [1, 0, 0, 0],
+ [1, 0, 0, 0]
+ ] );
+ task2_pljava
+--------------
+ {0,2,3,1}
+(1 row)
+
+
+*/
+public class Task2 {
+
+ @Function( onNullInput = RETURNS_NULL, effects = IMMUTABLE )
+ public static final Integer[] task2_pljava( int size, int[] matrix ) throws Exception {
+ int row_index = 0;
+ Map<Integer, List<Integer>> ones = new HashMap<Integer, List<Integer>>();
+
+ int number_of_ones = 0;
+
+ for ( int i = 0; i < matrix.length; i++ ) {
+ number_of_ones += matrix[ i ];
+ if ( ( i + 1 ) % size == 0 || i == matrix.length ) {
+
+ if ( ! ones.containsKey( number_of_ones ) )
+ ones.put( number_of_ones, new LinkedList<Integer>() );
+
+ ones.get( number_of_ones ).add( row_index++ );
+ number_of_ones = 0;
+ }
+
+
+ }
+
+ List<Integer> keys = new LinkedList<Integer>( ones.keySet() );
+ Collections.sort( keys );
+
+ List<Integer> result = new LinkedList<Integer>();
+ for ( int k : keys ) {
+ List<Integer> values = ones.get( k );
+ Collections.sort( values );
+ result.addAll( values );
+ }
+
+ return result.toArray( new Integer[ result.size() ] );
+ }
+}