From 3270d45dde3dba8def61b72f525405774e9d595d Mon Sep 17 00:00:00 2001 From: James Dunkerley Date: Tue, 17 Sep 2024 14:27:25 +0100 Subject: [PATCH] Small tweaks from using Process.run (#11110) * Once more unto the lint dear friends. * Default the arguments for process run. Allow delimiter to be used to convert Text to Table. (cherry picked from commit b2545b8b96bce3a9d6a3cb910cb0595d7e281e5e) --- .../Standard/AWS/0.0.0-dev/src/AWS_Credential.enso | 2 +- .../lib/Standard/AWS/0.0.0-dev/src/S3/S3.enso | 2 +- .../Standard/Base/0.0.0-dev/src/System/Process.enso | 4 +++- .../Database/0.0.0-dev/src/Dialect_Flags.enso | 3 +++ .../src/Internal/Postgres/Postgres_Dialect.enso | 3 ++- .../src/Internal/SQLite/SQLite_Dialect.enso | 3 ++- .../lib/Standard/Table/0.0.0-dev/src/Table.enso | 12 +++++++----- .../Visualization/0.0.0-dev/src/Widgets.enso | 4 +++- 8 files changed, 22 insertions(+), 11 deletions(-) diff --git a/distribution/lib/Standard/AWS/0.0.0-dev/src/AWS_Credential.enso b/distribution/lib/Standard/AWS/0.0.0-dev/src/AWS_Credential.enso index 3a81417216a2..4acfc3ca81c6 100644 --- a/distribution/lib/Standard/AWS/0.0.0-dev/src/AWS_Credential.enso +++ b/distribution/lib/Standard/AWS/0.0.0-dev/src/AWS_Credential.enso @@ -1,6 +1,6 @@ from Standard.Base import all -import Standard.Base.Errors.Illegal_Argument.Illegal_Argument import Standard.Base.Errors.Common.Missing_Argument +import Standard.Base.Errors.Illegal_Argument.Illegal_Argument from Standard.Base.Enso_Cloud.Enso_Secret import as_hideable_value from Standard.Base.Metadata import Display, make_single_choice, Widget from Standard.Base.Metadata.Choice import Option diff --git a/distribution/lib/Standard/AWS/0.0.0-dev/src/S3/S3.enso b/distribution/lib/Standard/AWS/0.0.0-dev/src/S3/S3.enso index 5f5d8a22a5a6..b0b4cc9239b3 100644 --- a/distribution/lib/Standard/AWS/0.0.0-dev/src/S3/S3.enso +++ b/distribution/lib/Standard/AWS/0.0.0-dev/src/S3/S3.enso @@ -6,13 +6,13 @@ import Standard.Base.System.Input_Stream.Input_Stream from Standard.Base.Network.HTTP.Response import filename_from_content_disposition import project.AWS_Credential.AWS_Credential -import project.S3.S3_File.S3_File import project.Errors.AWS_SDK_Error import project.Errors.More_Records_Available import project.Errors.S3_Bucket_Not_Found import project.Errors.S3_Error import project.Errors.S3_Key_Not_Found import project.Internal.Request_Body +import project.S3.S3_File.S3_File polyglot java import java.io.IOException polyglot java import org.enso.aws.BucketLocator diff --git a/distribution/lib/Standard/Base/0.0.0-dev/src/System/Process.enso b/distribution/lib/Standard/Base/0.0.0-dev/src/System/Process.enso index 2389b8bc8175..0821e6857e34 100644 --- a/distribution/lib/Standard/Base/0.0.0-dev/src/System/Process.enso +++ b/distribution/lib/Standard/Base/0.0.0-dev/src/System/Process.enso @@ -5,6 +5,7 @@ import project.System.Process.Exit_Code.Exit_Code import project.System.Process.Process_Builder.Process_Builder import project.System.Process.Process_Builder.Process_Result from project.Data.Boolean import Boolean, False, True +from project.Metadata.Widget import Text_Input, Vector_Editor ## ALIAS run a command GROUP Input @@ -25,8 +26,9 @@ from project.Data.Boolean import Boolean, False, True example_run = case Platform.os of Platform.OS.Windows -> Process.run "PowerShell" ["-Command", "exit 42"] _ -> Process.run "bash" ["-c", "exit 42"] +@arguments (Vector_Editor item_editor=Text_Input item_default='""') run : Text -> Vector Text -> Text -> Process_Result -run command arguments=[] stdin="" = +run command:Text arguments=[] stdin:Text="" = new_builder command arguments stdin . create ## PRIVATE diff --git a/distribution/lib/Standard/Database/0.0.0-dev/src/Dialect_Flags.enso b/distribution/lib/Standard/Database/0.0.0-dev/src/Dialect_Flags.enso index 87f3d65484e0..ea844c8c8052 100644 --- a/distribution/lib/Standard/Database/0.0.0-dev/src/Dialect_Flags.enso +++ b/distribution/lib/Standard/Database/0.0.0-dev/src/Dialect_Flags.enso @@ -11,7 +11,10 @@ from Standard.Base import all since feature flags are user-facing, and can be used to identify features that are not yet implemented. type Dialect_Flags + ## PRIVATE Value (rounding : Rounding_Flags) +## PRIVATE type Rounding_Flags + ## PRIVATE Value (supports_negative_decimal_places : Boolean) (supports_float_decimal_places : Boolean) (use_builtin_bankers : Boolean) diff --git a/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/Postgres/Postgres_Dialect.enso b/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/Postgres/Postgres_Dialect.enso index 8b04131dfc1b..3cfb19ff7fe1 100644 --- a/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/Postgres/Postgres_Dialect.enso +++ b/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/Postgres/Postgres_Dialect.enso @@ -10,6 +10,8 @@ from Standard.Table.Aggregate_Column.Aggregate_Column import all from Standard.Table.Errors import Inexact_Type_Coercion from Standard.Table.Internal.Storage import get_storage_for_column +from Standard.Database.Dialect_Flags import all + import project.Connection.Connection.Connection import project.DB_Column.DB_Column import project.DB_Table.DB_Table @@ -38,7 +40,6 @@ import project.SQL.SQL_Fragment import project.SQL_Statement.SQL_Statement import project.SQL_Type.SQL_Type from project.Dialect import Temp_Table_Style -from Standard.Database.Dialect_Flags import all from project.Errors import SQL_Error, Unsupported_Database_Operation from project.Internal.IR.Operation_Metadata import Date_Period_Metadata from project.Internal.JDBC_Connection import JDBC_Connection diff --git a/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/SQLite/SQLite_Dialect.enso b/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/SQLite/SQLite_Dialect.enso index 401840ad6ab6..c98fc772ea6e 100644 --- a/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/SQLite/SQLite_Dialect.enso +++ b/distribution/lib/Standard/Database/0.0.0-dev/src/Internal/SQLite/SQLite_Dialect.enso @@ -7,6 +7,8 @@ import Standard.Table.Internal.Problem_Builder.Problem_Builder from Standard.Table import Aggregate_Column, Value_Type from Standard.Table.Aggregate_Column.Aggregate_Column import all +from Standard.Database.Dialect_Flags import all + import project.Connection.Connection.Connection import project.DB_Column.DB_Column import project.DB_Table.DB_Table @@ -35,7 +37,6 @@ import project.SQL.SQL_Builder import project.SQL_Statement.SQL_Statement import project.SQL_Type.SQL_Type from project.Dialect import Temp_Table_Style -from Standard.Database.Dialect_Flags import all from project.Errors import SQL_Error, Unsupported_Database_Operation from project.Internal.JDBC_Connection import JDBC_Connection diff --git a/distribution/lib/Standard/Table/0.0.0-dev/src/Table.enso b/distribution/lib/Standard/Table/0.0.0-dev/src/Table.enso index 1897049cf4b0..7efd3011cd52 100644 --- a/distribution/lib/Standard/Table/0.0.0-dev/src/Table.enso +++ b/distribution/lib/Standard/Table/0.0.0-dev/src/Table.enso @@ -3784,11 +3784,13 @@ Table.from (that:Column) = that.to_table - that: The text to convert. - format: The format of the text. - on_problems: What to do if there are problems reading the text. -Table.from (that : Text) (format = Delimited_Format.Delimited '\t') (on_problems:Problem_Behavior=..Report_Warning) = - resolved_format = File_Format.resolve format - case resolved_format of - _ : Delimited_Format -> Delimited_Reader.read_text that resolved_format on_problems - _ -> Unimplemented.throw "Table.from is currently only implemented for Delimited_Format." +Table.from (that : Text) (format = Delimited_Format.Delimited '\t') (on_problems:Problem_Behavior=..Report_Warning) = case format of + _ : Text -> Table.from that (Delimited_Format.Delimited format) on_problems + _ -> + resolved_format = File_Format.resolve format + case resolved_format of + _ : Delimited_Format -> Delimited_Reader.read_text that resolved_format on_problems + _ -> Unimplemented.throw "Table.from is currently only implemented for Delimited_Format." ## PRIVATE Converts a Table into a Text value. diff --git a/distribution/lib/Standard/Visualization/0.0.0-dev/src/Widgets.enso b/distribution/lib/Standard/Visualization/0.0.0-dev/src/Widgets.enso index 9a7e56ff04e6..0a20b2b63f87 100644 --- a/distribution/lib/Standard/Visualization/0.0.0-dev/src/Widgets.enso +++ b/distribution/lib/Standard/Visualization/0.0.0-dev/src/Widgets.enso @@ -1,9 +1,11 @@ from Standard.Base import all import Standard.Base.Errors.Common.Not_Invokable from Standard.Base.Meta import Instrumentor -from Standard.Database import all + from Standard.Table import all +from Standard.Database import all + ## PRIVATE Basic preprocessor for widgets metadata visualization.