MXPA02006022A - Un sistema y metodo para modificar la slida de un programa de computo sin realizar modificaciones de instrucciones de codigo fuente. - Google Patents

Un sistema y metodo para modificar la slida de un programa de computo sin realizar modificaciones de instrucciones de codigo fuente.

Info

Publication number
MXPA02006022A
MXPA02006022A MXPA02006022A MXPA02006022A MXPA02006022A MX PA02006022 A MXPA02006022 A MX PA02006022A MX PA02006022 A MXPA02006022 A MX PA02006022A MX PA02006022 A MXPA02006022 A MX PA02006022A MX PA02006022 A MXPA02006022 A MX PA02006022A
Authority
MX
Mexico
Prior art keywords
text file
format
name
formula
descriptions
Prior art date
Application number
MXPA02006022A
Other languages
English (en)
Inventor
Andrew Sullivan
Original Assignee
United Parcel Service Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by United Parcel Service Inc filed Critical United Parcel Service Inc
Publication of MXPA02006022A publication Critical patent/MXPA02006022A/es

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/103Formatting, i.e. changing of presentation of documents
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/151Transformation
    • G06F40/157Transformation using dictionaries or tables
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99943Generating database or data structure, e.g. via user interface

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Health & Medical Sciences (AREA)
  • Computational Linguistics (AREA)
  • General Health & Medical Sciences (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Artificial Intelligence (AREA)
  • Stored Programmes (AREA)
  • User Interface Of Digital Computer (AREA)
  • Devices For Executing Special Programs (AREA)
  • Document Processing Apparatus (AREA)

Abstract

Un sistema y metodo para modificar la salida de un programa de computo sin tener que modificar las instrucciones de codigo fuente; un programa de computo lee en dos archivos, un archivo de entrada de datos y un archivo de texto formula; el archivo de datos de entrada contiene los pares de nombre/valor que se presentaran a un dispositivo de salida y el archivo de texto formula contiene las descripciones para dar formato; los pares de nombre/valor del archivo de entrada de datos no tiene que estar ajustado necesariamente a una estructura requerida; durante la ejecucion del programa, las descripciones para dar formato del archivo de texto formula se convierten en secuencia de objetos ejecutables y los pares de nombre/lvalor del archivo de entrada de datos se presentan en un formato conforme a estas descripciones para dar formato; una alteracion coordinada del archivo de texto de entrada y el archivo de texto formula sera el resultado de una modificacion al formato de entrada.

Description

UN SISTEMA Y MÉTODO PARA MODIFICAR LA SALIDA DE UN PROGRAMA DE COMPUTO SIN REALIZAR MODIFICACIONES DE INSTRUCCIONES DE CÓDIGO FUENTE CAMPO DE LA INVENCIÓN La presente invención generalmente describe sistemas de formato de salida de cómputo, y más particularmente describe un método y sistema para modificar el formato de la salida de un programa de cómputo sin modificar las instrucciones de código fuente del programa de cómputo.
ANTECEDENTES DE LA INVENCIÓN Los usuarios de sistemas de cómputo en ocasiones necesitan programas que realicen nuevos procedimientos que son variaciones de los procedimientos realizados actualmente. Por lo tanto, los programas de cómputo empleados por el usuario requieren mantenimiento o modificación para los procedimientos que ponen en práctica. Muchas veces las modificaciones necesarias incluyen cambios en la forma de salida del programa en caso de tener formato. Generalmente, en el pasado, la salida de un programa de cómputo estaba determinada por las instrucciones de código fuente mismas. Debido a esto, cuando se necesitaban los formatos de salida en derivación de aquellos originalmente escritos en el programa, era _ ¡_. to .v¡t~?Lxa*!kil& .?. *4^ft necesario emplear programadores de cómputo altamente calificados para realizar las modificaciones a las instrucciones de código fuente del programa de cómputo mismo. Como resultado, cuando el formato de salida de un programa de cómputo requería modificación, se experimentaban demoras 5 altamente costosas. Por ejemplo, se puede considerar un programa para la elaboración de etiquetas. Inicialmente, durante el uso def programa, la ubicación, fuente, tamaño de letra, y orientación de objetos son aceptables. Sin embargo, durante la duración útil del programa se vuelve necesario alterar 10 el formato de cierta manera para satisfacer una necesidad nueva o inesperada. Para satisfacer esta necesidad, un programador de cómputo altamente calificado tendría que reprogramar las instrucciones de código fuente del programa de cómputo originando gastos tanto de tiempo como de dinero. 15 Por consiguiente, permanece la necesidad en la técnica de reducir la cantidad de tiempo y nivel de habilidad en programación necesarios para cambiar el formato de salida de un programa de cómputo.
BREVE DESCRIPCIÓN DE LA INVENCIÓN 20 La presente invención busca proveer una manera para realizar modificaciones a formatos de salida de programas de cómputo sin realizar cambios costosos o que consuman mucho tiempo a las instrucciones de código fuente del programa. Este objetivo se logra proporcionando al programa una multitud de descripciones para dar formato que fácilmente se pueden modificar a través de un archivo de texto de entrada separado. Cuando se desea realizar un cambio en el formato de salida, más que cambiar las instrucciones de código fuente del programa, se modifica el contenido de este archivo de texto. Debido a que este es un archivo de texto de entrada y no instrucciones de código fuente, únicamente es necesario el conocimiento de las reglas simples de sintaxis del archivo y no la habilidad para crear instrucciones de código fuente complejas del programa de cómputo. Por lo tanto, se crean grandes eficiencias mediante la modificación del formato de salida de un programa de cómputo sin tener que realizar modificaciones a nivel de instrucciones que resultan costosas y consumen tiempo. En una modalidad preferida, el programa de cómputo lee dos archivos, un archivo de datos de entrada y un archivo de texto fórmula. El archivo de entrada de datos contiene los pares de nombre/valor que se presentarán un dispositivo de salida y el archivo de texto fórmula contiene las descripciones para dar formato. No se necesitan acomodar los pares de nombre/valor del archivo de entrada de datos conforme a una estructura requerida. Durante la ejecución de este programa, las descripciones para dar formato del archivo de texto fórmula se convierten en una secuencia de objetos ejecutables y los pares de nombre/valor del archivo de entrada de datos se presentan en un formato de acuerdo con estas descripciones para dar formato. Una alteración coordinada del archivo de texto de entrada y el archivo de texto fórmula dará como resultado una modificación en el formato de salida. Otro aspecto de la presente invención es un método para dar salida información con formato. El método provee un archivo de texto de datos de entrada que contiene pares de nombre/valor; provee un archivo de texto fórmula que contiene descripciones para dar formato; convierte el archivo de texto fórmula en una secuencia de objetos ejecutables; recibe una solicitud de presentar salida; y ejecuta los objetos ejecutables para presentar los pares de nombre/valor conforme a las descripciones para dar formato. Posteriormente, el método modifica el archivo de texto fórmula para incluir las descripciones modificadas para dar formato; convierte el archivo de texto fórmula modificado en una secuencia de objetos ejecutables; recibe otra solicitud de entregar la salida; y ejecuta los objetos ejecutables para presentar los pares de nombre/valor conforme a las descripciones modificadas para dar formato. El archivo de texto de datos de entrada se puede modificar para incluir pares de nombre/valor modificados correspondientes a la modificación del archivo de texto fórmula. Por ejemplo, se puede considerar nuevamente un programa para la elaboración de etiquetas. Como se mencionó anteriormente, durante el uso inicial del programa, la ubicación, fuente, tamaño de letra, y orientación de objetos son aceptables, pero durante la duración útil del programa se vuelve ~ necesario alterar el formato de cierta manera para satisfacer una necesidad nueva o inesperada. Sin embargo, para satisfacer esta necesidad, un programador de cómputo altamente calificado no tendrá que reprogramar las instrucciones de código fuente del programa de cómputo. Más que modificar las instrucciones de código fuente del programa, se puede realizar una simple adición o modificación al archivo de texto fórmula utilizando únicamente el conocimiento de la sintaxis del archivo de texto fórmula. Debido a que el programa convierte las descripciones para dar formato del archivo de texto fórmula en una secuencia de objetos ejecutables, no es necesario realizar una modificación de instrucciones de código fuente. Por lo tanto, no se requiere la capacidad de programar en un lenguaje de programación de cómputo altamente técnico.
BREVE DESCRIPCIÓN DE LOS DIBUJOS La figura 1 es un diagrama de bloque funcional de un ambiente de operación ejemplar para la puesta en práctica de las modalidades ejemplares de la presente invención; La figura 2 es una gráfica de flujo que ilustra la operación general de una modalidad ejemplar de la presente invención; La figura 3 es una ilustración de un archivo de texto fórmula.
, Z « ¿ J DESCRIPCIÓN DETALLADA DE LA MODALIDAD PREFERIDA La presente invención está dirigida a un sistema y método para modificar la salida de un programa de cómputo sin realizar modificaciones a las instrucciones de código fuente. En pocas palabras, la invención provee un archivo de datos de entrada que contiene los datos de entrada y un archivo de texto fórmula que contiene las descripciones para dar formato, para una computadora. Una vez que la computadora lee estos archivos, el archivo fórmula es convertido a una secuencia de objetos ejecutables. Después que la computadora recibe la solicitud por parte del usuario, se ejecutan los datos ejecutables para presentar los datos del archivo de datos de entrada conforme a los formatos contenidos en el archivo de texto fórmula. Después que se ha proporcionado la salida conforme a los formatos contenidos en el archivo de texto fórmula, el archivo de texto fórmula es modificado para reflejar un cambio deseado en el formato de salida. Una vez que se ha realizado lo anterior, el sistema convierte el archivo de texto fórmula en objetos ejecutables y una vez más los ejecuta en respuesta a la entrada del usuario. El resultado de esta ejecución es la salida de los datos desde el archivo de texto fórmula en un formato modificado desde la ejecución previa. La descripción de la modalidad ejemplar de la presente invención en lo sucesivo se conocerá como la delineación, en donde números similares indican elementos similares en las diversas figuras. Comenzando con la figura _«,.__ j____-J-J« •* -*--..- *»>. — ñ*?¡-Ukit.A,Á 1 , se muestra un sistema operativo ejemplar para la puesta en práctica de una modalidad ejemplar de la presente invención. Dentro del ambiente operativo ejemplar, la presente invención puede operar para facilitar la modificación de la salida de un programa de cómputo sin realizar modificaciones a las instrucciones de código fuente. Sin embargo, aquellos expertos en la técnica apreciarán que la invención se puede practicar en cualquier tipo de ambiente operativo de cómputo tal como dispositivos portátiles, sistemas de multiprocesador, sistemas electrónicos del consumidor que se pueden programar o que están basados en microprocesador, microcomputadoras, computadoras grandes y similares. La presente invención también se puede practicar en ambientes de cómputo distribuidos donde las tareas se realizan mediante dispositivos remotos de procesamiento. La modalidad ejemplar de la presente invención se describirá en el contexto general de un programa de aplicación de subsistema de salida de formato 36 en lo sucesivo el programa de aplicación FOSS. El programa de aplicación FOSS 36 facilita la modificación de la salida de un programa de cómputo, interactúa con un archivo de texto de datos de entrada 38 y un archivo de texto fórmula 39, para modificar la salida de un programa de cómputo sin tener que modificar las instrucciones de código fuente. Aquellos expertos en la técnica reconocerán que la invención se puede poner en práctica en combinación con otros módulos de programa 37. Generalmente, los módulos de programa incluyen rutinas, programas, componentes, estructuras de datos, etc. que realizan tareas particulares o implementan tipos .. , . _._t_____?_______-__ A1^,t> _a^ _a_iJ«s___»___i^ de datos abstractos particulares. Además, aquellos expertos en la técnica apreciarán que la invención se puede practicar con configuraciones de sistema de cómputo diferentes a la mostrada, que están vinculadas a través de una red de comunicaciones. En un ambiente de cómputo distribuido, los módulos de programa se pueden ubicar en dispositivos de almacenamiento de memoria tanto local como remota. Un ambiente operativo ejemplar 100 para la puesta en práctica de la invención incluye un sistema de cómputo personal convencional 20, incluyendo una unidad de procesamiento 21 , una memoria de sistema 22, y un ducto de sistema 23 que acopla la memoria de sistema 22 a la unidad de procesamiento 21. La memoria de sistema 22 incluye memoria de lectura exclusiva (ROM) 24 y memoria de acceso aleatorio (RAM) 25. Un sistema de entrada/salida básico 26 (BIOS), que contiene las rutinas básicas que ayudan a transferir la información entre elementos dentro del sistema de cómputo personal 20, tal como durante la puesta en marcha, se almacena en ROM 124. El sistema de cómputo personal 20 además incluye una unidad de disco duro 27, una unidad de disco magnético 28, por ejemplo, para leer desde o escribir en un disco removible 29, y una unida de disco óptico 30, por ejemplo, para leer un disco CD-ROM 31 o para leer de o escribir en otro medio óptico. La unidad de disco duro 27, unidad de disco magnético 28, y unidad de disco óptico 30 están conectados al ducto de sistema 23 mediante una interfaz de unidad de disco duro 32, una interfaz de unidad de disco magnético 33, y una interfaz de unidad óptica 34, respectivamente. Las unidades y sus medios de lectura por computadora asociados proveen almacenamiento no volátil para el sistema de cómputo personal 20. Por ejemplo, el archivo de texto de datos de entrada 38 se puede almacenar en la RAM 25 del disco duro 27 de la computadora personal 20. Aunque la descripción del medio de lectura por computadora antes mencionados se refieren a un disco duro, un disco magnético removible y un disco CD-ROM, aquellos expertos en la técnica apreciarán que en el ambiente operativo ejemplar también se pueden utilizar otros tipos de medios que se pueden leer mediante un sistema de cómputo, tal como casetes magnéticos, tarjetas de memoria instantánea, discos de video digital, cartuchos Bernoulli, y similares. Un número de módulos de programa se pueden almacenar en las unidades y RAM 25, incluyendo un sistema operativo 35, programa de aplicación FOSS 36, otros módulos de programa 37, un archivo de texto de datos de entrada 38, un archivo de texto fórmula 39, una secuencia de objetos ejecutables 40 y una secuencia modificada de objetos ejecutables 41. En particular, el programa de aplicación FOSS 36 que facilita la modificación de la salida de un programa de cómputo, interactúa con el archivo de texto de datos de entrada 38 y el archivo de texto fórmula 39, para modificar la salida de un programa de cómputo sin tener que modificar las instrucciones de código fuente. Posteriormente con referencia a la figura 2, se describirá de manera detallada una modalidad ejemplar del programa de aplicación FOSS 36.
-" »«" ; ^^.^-^^.^..^ ,,-^.^^^^ Otros dispositivos de entrada (no mostrados) pueden incluir un micrófono, mando de bastón, almohadilla de juego, plato parabólico, escáner, o similares. Estos y otros dispositivos de entrada con frecuencia están conectados a una unidad de procesamiento 21 a través de una interfaz de puerto en serie 46 que está acoplado al ducto de sistema, pero que se puede conectar mediante otras interfaces, tal como un puerto de juegos o un ducto en serie universal (UBS). Un dispositivo de visualización 47 u otro tipo de dispositivo tal como un monitor también está conectado al ducto de sistema 23 mediante una interfaz, tal como un adaptador de video 48. Una impresora 45 también está conectada ai ducto de sistema 23 mediante una interfaz, tal como una inter-faz paralela 44. Además del dispositivo de visualización 47 y la impresora 45, los sistemas de cómputo personales típicamente incluyen otros dispositivos periféricos de salida (no mostrados), tal como altavoces. El sistema de cómputo personal 20 puede operar en un ambiente conectado en red utilizando conexiones lógicas a uno o más de los sistemas de cómputo remotos, tal como el sistema de cómputo remoto 49. El sistema de cómputo remoto 49 puede ser un servidor, un enrutador, dispositivo paritario u otro nodo de red común, y típicamente incluye muchos o todos los elementos descritos relacionados con el sistema de cómputo personal 20, aunque únicamente se ha ilustrado en la figura 1 un dispositivo de almacenamiento de memoria 50. Las conexiones lógicas mostradas en la figura 1 incluyen una red de servicio local (LAN) 51 y una red de servicio _*_______ _._. _ ii-Hiiiinr z-^*-*-* - - «A«»-^- ^ -^»^'M¿ M>-I amplio (WAN) 52. Dichos ambientes de red son lugares comunes en oficinas, redes de cómputo amplias en empresas, intraredes y el Internet. Cuando se utiliza en un ambiente de red LAN, el sistema de cómputo personal 20 está conectado a la LAN 51 a través de una interfaz de red 53. Cuando se utiliza en un ambiente de red WAN, el sistema de cómputo personal 20 típicamente incluye un modem 54 u otro medio para establecer comunicaciones sobre la WAN 52, tal como el Internet. El modem 54, que puede ser interno o externo, está conectado al ducto de sistema 23 mediante la interfaz de puerto en serie 46. En un ambiente conectado en red, los módulos de programa mostrados en relación con el sistema de cómputo personal 20, o porciones del mismo, se pueden almacenar en el dispositivo de almacenamiento de memoria remota 50. Se podrá apreciar que las conexiones en red mostradas son ejemplares y que se pueden utilizar otros medios para establecer un vínculo de comunicaciones entre los sistemas de cómputo. También se podrá apreciar que la presente invención se podría poner en práctica de manera equivalente en sistemas de cómputo de servidor o principal menos en sistemas de cómputo personales, y de manera equivalente se podrían transmitir al sistema de cómputo principal mediante medios que no sean un CD-ROM, por ejemplo, mediante la interfaz de conexión de red 53. No obstante la amplia aplicabilidad de los principios de la presente invención, se debe entender que la configuración de la modalidad ejemplar como un programa de aplicación FOSS 36 para sistemas de ü^ H¡ ^¡gg » M^ cómputo personales ampliamente utilizados 20 provee ventajas importantes. En particular, el programa de aplicación FOSS 36, que comprende instrucciones puestas en práctica mediante computadora para realizar el método de la presente invención, descrito en esta especificación, está especialmente diseñado para mostrar características de rendimiento y uso de memoria aceptables cuando se ponen en práctica en el sistema de cómputo personal convencional 20. Al configurar de esta manera el módulo de programa de revisión 36, ciertos balances de compensación, particularmente entre los objetivos con frecuencia conflictivos de reducir al mínimo el almacenamiento de memoria e incrementar la velocidad de rendimiento, necesariamente se han alcanzado. Se deben entender que las variaciones de los alcances de los balances de compensación en las modalidades ejemplares descritas en esta especificación están dentro del espíritu y alcance de la presente invención, particularmente en vista del hecho que mejoras inevitables en hardware de cómputo y dispositivos de almacenamiento de memoria harán posibles otros balances de compensación. La figura 2, describe un método ejemplar 200 en donde la salida de un programa de cómputo es modificado sin realizar modificaciones a las instrucciones de código fuente. En esta modalidad, se describe un programa para producir etiquetas para paquetes que se enviarán. El método 200 comienza en el bloque de inicio 205 y avanza al paso 210 donde el sistema es provisto con un archivo de texto de datos de entrada 38 que contiene pares de nombre/valor específicos. Como se muestra en el cuadro A, los pares de ilÉflfÉÉ___1llff^^*"^'^^ nombre/valor contenidos en el archivo de texto de datos de entrada 38 proveen información que se desplegará en la salida. La columna A del cuadro A ilustra el nombre y la columna B ilustra el valor correspondiente de los pares de nombre/valor particulares. Específicamente, los pares de nombre/valor 305 hasta 330 pueden indicar la dirección desde donde se enviará un paquete, mientras que los pares de nombre/valor 335 hasta 360 pueden indicar la dirección a la que se enviará el paquete. El par de nombre/valor 365 puede indicar información para un código de barras que se puede colocar sobre la etiqueta. Además, se puede incluir información gráfica que representa un icono o logotipo en un par de nombre/valor y se puede incluir en el archivo de texto de datos de entrada 38. Se debe observar que la información contenida en el archivo de texto de datos de entrada no proporciona por sí misma indicación alguna de formato, y los pares de nombre/valor del archivo de texto de datos de entrada 38 no necesita estar acomodado conforme a una estructura requerida.
CUADRO A Haciendo referencia nuevamente a la figura 2, el método 200 continúa con el paso 215 donde el sistema es provisto con un archivo de texto fórmula 39 que contiene descripciones para dar formato. El archivo de texto fórmula 39 provisto al sistema se puede seleccionar a partir de una pluralidad de dichos archivos almacenados en el disco duro 32 y se puede especificar mediante información contenida en el archivo de texto de datos de entrada 38. Por ejemplo, el archivo de texto de datos de entrada 38 como se muestra en el cuadro A puede contener un par particular de nombre/valor 370 que designa un archivo de texto fórmula particular nombrado 4X6Lable. La descripción de formato contenida en el archivo de texto fórmula 39 puede especificar el tamaño de etiqueta, el tipo de letra y tamaño, y la ubicación de iconos tal como logotipos o códigos de barras. Además, si en los datos de gjjjji g lÜ^^^ ^gb entrada se especifica un destino particular tal como un país extranjero, el formato reflejará las costumbres o requerimientos del destino. La creación de la salida con formato apropiada comienza con el archivo de texto fórmula 39. El archivo de texto fórmula 39 encapsula reglas para etiquetas, reportes y otra salida con formato y se carga durante la inicialización del programa de aplicación FOSS 36. Consiste de descriptores de reglas de formato que contienen varios artefactos y/u otras descripciones para dar formato. Cada artefacto puede tener un valor constante o indicar un vínculo para datos proporcionados en los pares de nombre/valor del archivo de texto de datos de entrada 38. Los datos proporcionados en el archivo de texto de datos de entrada 38 deben ser en un par de nombre/valor con nombres de vínculo que los artefactos utilizan para obtener datos que el archivo de texto de datos de entrada 38 presentará cuando se ejecute el programa de aplicación FOSS. La transmisión utilizada para pasar el archivo de texto de datos de entrada 38 al programa de aplicación FOSS se conoce como un receptor. Un receptor puede tener un nombre, pares de cadenas de nombre-valor, y receptores integrados. Los artículos del receptor no se presentarán a menos que se haga referencia a ellos como un vínculo en el archivo de texto fórmula 39. El archivo de texto fórmula 39 contiene el siguiente tipo de descriptores de reglas de formato: ¡ ^__ *_ ______t_A,_ ._. _______,11| | r ,. j^?f l^M^.1*.*****^.*^ .
Formato El artículo de formato es el descriptor de reglas de formato raíz que define cómo presentar o más específicamente imprimir datos en los dispositivos de salida tal como una impresora de etiquetas. Contiene una colección de descriptores de reglas de formato que definen el tamaño de salida de formato, fuente por omisión, características de línea por omisión, y artefactos. Cada formato tiene un nombre que se utiliza para hacer referencia a la fórmula de formato. Muchos de los nombres se mencionan de la siguiente manera.
Artefacto "patrón" Este artefacto se utiliza para permitir la presentación de artículos de datos múltiples, desde el archivo de texto de datos de entrada 38, dentro de un descriptor de reglas de formato de artefacto único. Opera muy parecido a la función "C" programación "forma de impresión (printf)()". Las recolecciones de valores de texto se presentan utilizando un formato específico. Si los artículos a los que se hace referencia en el patrón no existen en el receptor de datos entonces se utiliza una cadena nula como el valor impreso.
Artefacto de "dibujo" Este artefacto se utiliza ya sea para trazar una línea, elipsis o un rectángulo.
Artefacto "compuesto" Este artefacto se utiliza para llamar a otro archivo de texto fórmula para que presente datos al dispositivo de salida. Sin embargo, en este caso el llamado formato puede hacer referencia a un receptor diferente para datos y tener una posición diferente en el contexto de dispositivo de salida. Por ejemplo, puede haber una fórmula de formato que define cómo imprimir una dirección. Se puede volver a utilizar para imprimir la dirección de "envío de" y "envío para". Sin embargo, los datos utilizados y las posiciones de presentación son diferentes. Por ejemplo, el artefacto compuesto "envío para" podría hacer referencia a receptor integrado que contiene únicamente la dirección "envío para" y tener una posición única donde colocarla sobre la etiqueta.
Artefacto "gráfico" Este artefacto se utiliza para imprimir una imagen gráfica en el contexto de salida. Este se puede utilizar para colocar un logotipo en una etiqueta de envío.
Artefacto de "texto" Este artefacto se utiliza para presentar un artículo de dato único desde el archivo de texto de datos de entrada 38.
I j lí _?i¡ __*!_ I ,f--^«— - «<B^>^* ^i_t.>.__^_^>.i_t_te_h^ _»<__A_H.
Artefacto de "paso" Este es un artefacto de caso especial que se utiliza para desviar cualquier control de sistema operativo del contexto de dispositivo y enviar los datos presentados directamente al dispositivo de salida tal como una impresora de etiquetas. Este se puede utilizar si el controlador de dispositivo no saca provecho de las características específicas que proporciona una impresora.
Artefacto de Maxi-códiqo Este artefacto se utiliza para recolectar datos desde el receptor de datos suministrados y presentarlos en una imagen de Maxi-código.
Artefacto de hrcs-código Este artefacto se utiliza para recolectar datos específicos del archivo de texto de datos de entrada suministrados 38 y presentarlos en un código de clasificación que las personas pueden leer. Un código de clasificación es una cadena de texto, utilizada para clasificar paquetes.
Modificador de artefacto "si" Este es un modificador de artefacto opcional. Indica que se va a realizar y pasar una prueba antes de presentar el artefacto. La prueba es una expresión booleana que permite probar el artefacto para los 5 artículos de existencia y/o valor en el archivo de texto de datos de entrada 38. _¿á_ ,A_ «á faiiiliili i jfÉttii f rt?_Mrf~**'- J "<^MÍ' Modificador de artefacto "bloque" Este es un modificador que todos los artefactos utilizan para especificar donde colocar el texto de artefacto dentro de la fórmula de formato definido. El bloque define un área rectangular dentro del espacio de formato.
Modificador de artefacto "pluma" Este es un modificador de artefacto opcional que especifica un tipo de línea y valor de ancho.
Modificador de artefacto "fuente" Este es un modificador de artefacto opcional que especifica un tipo de fuente y valor de tamaño. Las reglas para escribir un archivo de texto fórmula 39 están definidas como una gramática de Formato Backaus Nauer (BNF por sus siglas en inglés). Una gramática BNF es una técnica que se utiliza para describir un grupo de texto sensible al contexto que describe un lenguaje. En este caso, la gramática utilizada representa las reglas para describir un archivo de texto fórmula 39. En la figura 3 se muestra un archivo de texto fórmula muestra 39 que se produce utilizando esta gramática. Cada línea en la gramática representa una regla sobre cómo analizar el texto dentro de un archivo de texto fórmula. La regla tiene el siguiente formato: Nombre de regla => Regla El lado izquierdo de la "= " es el nombre de la regla de producción que especifica lo que se puede esperar en la cadena de texto que se está analizando. Para soportar varios casos gramaticales, se deben ajustar alternativas en las reglas gramaticales. Una sola regla puede tener cero, una o más posibilidades. La producción real depende del contexto de la cadena de entrada. Por ejemplo, en posiciones específicas en el archivo de texto fórmula 39, se puede esperar una regla de formato. Podría ser una línea, texto, círculo, símbolo de Maxi código, o cualquier artefacto definido. En algunos casos la regla puede no producir símbolo alguno. Para este caso un "$" se especifica como una regla alternativa. Algunos símbolos están encerrados entre paréntesis angulares ("<>"). Esto indica que el símbolo no es texto realmente en la cadena de salida, pero tiene una definición que está definida por otra regla. Esto se conoce como un símbolo que no cuenta con terminal. Todo el demás texto en la producción representa texto real denominado símbolos de terminal. En las siguientes tablas se define la gramática para crear un archivo de texto fórmula. <_?_ ... __.^ ^.«_a-_._á i_? CUADRO I a_t¿_?__^_ ^-^.¿fffrff-? CUADRO --? --f ** r\i _?-__ ^+^. i?i+i¿m*t ¿^*?*&*[?¿-** 1& Para un ejemplo de una aplicación de las reglas antes mencionadas, en el cuadro 1 se pueden obtener las siguientes dos reglas.
Aplicando las dos reglas anteriores, se pueden producir las siguientes dos líneas 405 y 410 respectivamente del texto fórmula como se muestra en la figura 3. ,[font,name=Arial,size=8] 10 ,[pen,width=1 ,style=solid]] Como se puede observar en la línea 405, se utilizará una fuente particular conocida como "Arial" con un tamaño de punto de "8" para imprimir los símbolos alfanuméricos sobre la etiqueta. Además de la línea 410, el ancho de pluma se selecciona en "1" y se trazará "sólida" en contraposición, 15 por ejemplo, a guiones. Haciendo referencia nuevamente a la figura 2, el método 202 T pasa del paso 215 al paso 220 donde el sistema convierte el archivo de texto fórmula 39 en una secuencia de objetos ejecutables apropiados para ejecución en el sistema de cómputo personal 20. Del paso 220, el método 20 pasa al bloque de decisión 225 donde la entrada de usuario determina si el usuario desea presentar salida. Los ejemplos de los medios que pueden recibir la salida presentada pueden incluir impresoras láser, impresoras de matriz de punto, impresoras de inyección de tinta, graficadores de terminal o f^grafieadores electrostáticos. Además, la salida se puede presentar en un formato electrónico incluyendo mensajes por correo electrónico, archivos ftp, archivos gif, o archivos electrónicos similares. Aquellos expertos en la técnica apreciarán que la presente invención se puede poner en práctica utilizando varias formas de mecanismos de salida. Si en el bloque de decisión 225, el usuario no desea presentar salida, el método continúa con el paso 230 donde el método termina. Sin embargo, si en el bloque de decisión 225 el usuario desea presentar salida, el método continúa con el paso 235. En el paso 235, el sistema ejecuta la secuencia de objetos ejecutables 40 producidos en el paso 220 para presentar los pares de nombre/valor del archivo de datos de entrada 38 conforme a las descripciones para dar formato del archivo de texto fórmula 39. Posteriormente, el método 200 continúa con el paso 240 donde en respuesta a la entrada del usuario, el sistema modifica el archivo de texto fórmula 39. Estas modificaciones pueden incluir el cambio del tamaño de la etiqueta que se presentará, la fuente de texto y tamaño, y la ubicación de iconos tales como logotipos o códigos de barras que se colocarán en el cuadro. Del paso 240 el método continúa con el paso 245 donde el sistema convierte el archivo de texto fórmula como se modificó en una secuencia modificada de objetos ejecutables 41. Después, el método pasa al bloque de decisión 250 donde la entrada de usuario determina si el usuario desea presentar la salida. Si el usuario no desea presentar la salida, el método continúa con el paso 255 donde termina el método. Sin embargo, si en el bloque de decisión 250 el usuario desea presentar la salida, ,i._____3l _,__._^.*i^ M^-~^A^-.-,tfÍÍftfr¡ el método continúa con el paso 260. En el paso 260, el sistema ejecuta la secuencia modificada de objetos ejecutables 41 para presentar los pares de nombre/valor del archivo de datos de entrada 30 conforme a las descripciones modificadas para dar formato del archivo de texto fórmula 39. Puesto que se está utilizando la secuencia modificada de objetos ejecutables 41 , el formato de salida presentado reflejará las modificaciones previamente realizadas. Del paso 260, el método continúa con el bloque final 265. En vista de lo antes mencionado, se apreciará que la presente invención provee un método para modificar la salida de un programa de cómputo sin realizar modificaciones a las instrucciones de código fuente. Aun así, se debe entender que lo antes mencionado describe únicamente las modalidades ejemplares de la presente invención, y que se pueden realizar numerosos cambios a las mismas sin tener que tomar como punto de partida el espíritu y alcance de la presente invención según lo definen las siguientes reivindicaciones.

Claims (5)

NOVEDAD DE LA INVENCIÓN REIVINDICACIONES
1.- Un sistema para dar salida a información con formato que comprende: un archivo de texto de datos de entrada que comprende una pluralidad de pares de nombre/valor, un archivo de texto fórmula que comprende una pluralidad de descripciones para dar formato, al menos algunas de las descripciones para dar formato indican un vínculo con uno o más de los pares de nombre/valor; y un programa de ejecución configurado para: convertir el archivo de texto fórmula en una secuencia de objetos ejecutables; recibir una solicitud de presentación de salidas; en respuesta a la solicitud, ejecutar los objetos ejecutables para presentar uno o más de dichos pares de nombre/valor conforme a dichas descripciones para dar formato; de tal manera que se puede cambiar el formato mediante alteración coordinada de dicho archivo de texto de datos de entrada y dicho archivo de texto fórmula.
2.- El sistema de conformidad con la reivindicación 1 , caracterizado además porque la salida presentada es una etiqueta.
3.- Un método para dar salida a información con formato que comprende los pasos de: proveer un archivo de texto de datos de entrada que comprende una pluralidad de pares de nombre/valor; proveer un archivo de texto fórmula que comprende una pluralidad de descripciones para dar 1 formato, al menos algunas de las descripciones para dar formato indican un vínculo con uno o más de los pares de nombre/valor; convertir el archivo ele texto fórmula en una secuencia de objetos ejecutables; recibir una primera solicitud para presentar salidas; ejecutar la secuencia de objetos ejecutables 5 para presentar uno o más de dichos pares de nombre/valor conforme a dichas descripciones para dar formato; modificar dicho archivo de texto fórmula para incluir una o más descripciones para dar formato modificadas; convertir dicho archivo de texto fórmula según se modificó en una secuencia modificada de objetos ejecutables; recibir una segunda solicitud para presentar salidas; y _k I 10 ejecutar la secuencia modificada de objetos ejecutables para presentar uno o f más de dichos pares de nombre/valor conforme a dichas descripciones para dar formato.
4.- El método de conformidad con la reivindicación 3, que además comprende el paso de: modificar dicho archivo de texto de datos de 15 entrada incluyendo uno o más de los pares de nombre/valor modificados. *
5.- El método de conformidad con la reivindicación 3, i ? caracterizado además porque la salida presentada es una etiqueta. .___¿^__l______,_^_-___..^
MXPA02006022A 1999-12-14 2000-12-14 Un sistema y metodo para modificar la slida de un programa de computo sin realizar modificaciones de instrucciones de codigo fuente. MXPA02006022A (es)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US17108399P 1999-12-14 1999-12-14
US09/593,973 US7133873B1 (en) 1999-12-14 2000-06-13 System and method for modifying output of computer program without source code modifications
PCT/US2000/033851 WO2001044923A2 (en) 1999-12-14 2000-12-14 A system and method for modifying output of a computer program without source code modifications

Publications (1)

Publication Number Publication Date
MXPA02006022A true MXPA02006022A (es) 2002-12-05

Family

ID=26866722

Family Applications (1)

Application Number Title Priority Date Filing Date
MXPA02006022A MXPA02006022A (es) 1999-12-14 2000-12-14 Un sistema y metodo para modificar la slida de un programa de computo sin realizar modificaciones de instrucciones de codigo fuente.

Country Status (8)

Country Link
US (2) US7133873B1 (es)
EP (1) EP1264236A2 (es)
JP (2) JP2003521766A (es)
CN (1) CN1204492C (es)
AU (1) AU2262101A (es)
CA (1) CA2394054C (es)
MX (1) MXPA02006022A (es)
WO (1) WO2001044923A2 (es)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
AU5132901A (en) * 2000-04-06 2001-10-23 Opentv Inc Generic data processing engine
US7249018B2 (en) 2001-01-12 2007-07-24 International Business Machines Corporation System and method for relating syntax and semantics for a conversational speech application
CN100345120C (zh) * 2004-12-24 2007-10-24 华为技术有限公司 一种利用编解码输出信息的方法
US8346555B2 (en) * 2006-08-22 2013-01-01 Nuance Communications, Inc. Automatic grammar tuning using statistical language model generation
CN109358844A (zh) * 2018-09-30 2019-02-19 仝瑞麟 程序执行方法及装置
US11849047B2 (en) * 2018-10-09 2023-12-19 International Business Machines Corporation Certifying authenticity of data modifications
US11374762B2 (en) 2018-10-09 2022-06-28 International Business Machines Corporation Certifying authenticity of data modifications

Family Cites Families (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA1267229A (en) 1986-03-10 1990-03-27 Randal H. Kerr Reconfigurable automatic tasking system
JPH077410B2 (ja) 1986-03-29 1995-01-30 株式会社東芝 文書レイアウト方法
JPH02236772A (ja) 1989-03-10 1990-09-19 Fujitsu Ltd 帳票出力形式の動的編集制御方式
DE69033121T2 (de) * 1989-09-01 1999-10-28 Amdahl Corp Betriebssystem und Datenbank mit einer Regelsprache zum bedingungsgesteuerten Rechnerbetrieb
US6076733A (en) * 1993-11-24 2000-06-20 Metrologic Instruments, Inc. Web-based system and method for enabling a viewer to access and display HTML-encoded documents located on the world wide web (WWW) by reading URL-encoded bar code symbols printed on a web-based information resource guide
US5133051A (en) * 1990-12-13 1992-07-21 Handley George E Automatic high speed publishing system
GB2272091B (en) * 1992-10-30 1996-10-23 Canon Europa Nv Apparatus for use in aligning bilingual corpora
US5485369A (en) 1993-09-28 1996-01-16 Tandata Corporation Logistics system for automating tansportation of goods
JP3448922B2 (ja) 1993-10-12 2003-09-22 富士ゼロックス株式会社 電子文書記憶装置
JPH07129391A (ja) 1993-10-28 1995-05-19 Dainippon Printing Co Ltd プログラム作成方法及び装置並びにプリントイメージデータ作成方法及び装置
JPH08142438A (ja) 1994-11-18 1996-06-04 Hitachi Ltd 帳票印刷方法
US5835712A (en) * 1996-05-03 1998-11-10 Webmate Technologies, Inc. Client-server system using embedded hypertext tags for application and database development
US6008805A (en) * 1996-07-19 1999-12-28 Cisco Technology, Inc. Method and apparatus for providing multiple management interfaces to a network device
JP3597646B2 (ja) 1996-07-23 2004-12-08 株式会社イシダ ラベル発行装置
US5895476A (en) * 1996-09-09 1999-04-20 Design Intelligence, Inc. Design engine for automatic reformatting for design and media
US5933816A (en) * 1996-10-31 1999-08-03 Citicorp Development Center, Inc. System and method for delivering financial services
US5970490A (en) * 1996-11-05 1999-10-19 Xerox Corporation Integration platform for heterogeneous databases
JPH10222510A (ja) 1997-02-07 1998-08-21 Hitachi Ltd 文書変換方法
JPH10307810A (ja) 1997-05-06 1998-11-17 Sekisui Chem Co Ltd 連立方程式系の解法手順表示方法及び連立方程式系の解法手順表示プログラムを記録したコンピュータ読み取り可能な記録媒体
JPH10307817A (ja) 1997-05-08 1998-11-17 Casio Electron Mfg Co Ltd 文字列変換装置
US6496202B1 (en) * 1997-06-30 2002-12-17 Sun Microsystems, Inc. Method and apparatus for generating a graphical user interface
US5940075A (en) * 1997-09-30 1999-08-17 Unisys Corp. Method for extending the hypertext markup language (HTML) to support enterprise application data binding
US6484149B1 (en) * 1997-10-10 2002-11-19 Microsoft Corporation Systems and methods for viewing product information, and methods for generating web pages
US6031623A (en) * 1997-12-11 2000-02-29 Hewlett-Packard Company Computer system with evolving printer
US6173316B1 (en) * 1998-04-08 2001-01-09 Geoworks Corporation Wireless communication device with markup language based man-machine interface
US6345278B1 (en) * 1998-06-04 2002-02-05 Collegenet, Inc. Universal forms engine
US6226656B1 (en) * 1998-11-12 2001-05-01 Sourcefinder, Inc. System and method for creating, generating and processing user-defined generic specs
US6377939B1 (en) * 1999-05-04 2002-04-23 Metratech Pipelined method and apparatus for processing communication metering data
US6721776B1 (en) * 1999-05-12 2004-04-13 Unisys Corporation Generic DCOM server
US6539374B2 (en) * 1999-06-03 2003-03-25 Microsoft Corporation Methods, apparatus and data structures for providing a uniform representation of various types of information
US6330554B1 (en) * 1999-06-03 2001-12-11 Microsoft Corporation Methods and apparatus using task models for targeting marketing information to computer users based on a task being performed

Also Published As

Publication number Publication date
WO2001044923A8 (en) 2003-10-23
JP2003521766A (ja) 2003-07-15
CN1423775A (zh) 2003-06-11
US7133873B1 (en) 2006-11-07
CN1204492C (zh) 2005-06-01
EP1264236A2 (en) 2002-12-11
CA2394054C (en) 2009-08-11
US7664805B2 (en) 2010-02-16
CA2394054A1 (en) 2001-06-21
WO2001044923A3 (en) 2002-10-10
JP2006179020A (ja) 2006-07-06
WO2001044923A2 (en) 2001-06-21
US20060265366A1 (en) 2006-11-23
AU2262101A (en) 2001-06-25
WO2001044923A9 (en) 2002-07-25

Similar Documents

Publication Publication Date Title
JP5520856B2 (ja) 携帯用計算デバイスへの無線通信媒体を介するコンテンツ送達のためのシステムおよび方法
RU2328034C2 (ru) Способ и система сопоставления операций семантическим меткам в электронных документах
US7904803B2 (en) Method and system for converting user interface source code of a legacy application to web pages
US7644391B2 (en) Sidebar engine, object model and schema
CN100476734C (zh) 用于修改信息以从源语言变换为目标语言的方法和系统
US20010039540A1 (en) Method and structure for dynamic conversion of data
EP1638017A2 (en) Method, program and storage medium for controlling an embedded device
JP2000048016A (ja) コンピュ―タプロセッサ上で実行可能なテキストのフォ―マット及び表示方法、テキストをフォ―マットし表示可能なコンピュ―タ装置、テキストをフォ―マットし表示可能なプログラムを記憶したコンピュ―タ読み取り可能な記憶媒体、テキストをフォ―マットし表示可能なテキストエディタに新たなスタイルを付加する付加方法
EP1830275A1 (en) Information distribution system
EP1999699A1 (en) Edi instance based transaction set definition
GB2423387A (en) Application-Generic Sequence Diagram Generator Driven by a Non-Proprietary Language
US8656287B2 (en) Information processing apparatus, information processing system, and information processing method
CN102262623A (zh) 字符输入编辑方法及设备
US6157392A (en) Animation packager for an on-line book
US7664805B2 (en) System and method for modifying output of a computer program without source code modifications
US6421055B1 (en) Method and apparatus for system enhancement to device backup font support
US7085998B2 (en) Mapping a print stream for printing on mailers from a first application for input to a second application
JP5812695B2 (ja) 情報処理装置および情報処理方法
US20040133856A1 (en) Document processing method and apparatus
US20080043272A1 (en) Method, system and article for exposing printer functionality via a logical file system
US20050177788A1 (en) Text to XML transformer and method
US20070143673A1 (en) Extensible architecture for chart styles and layouts
CN112486428A (zh) 打印方法、装置及存储介质
US20150324333A1 (en) Systems and methods for automatically generating hyperlinks
US7644358B2 (en) Usability of a portal application

Legal Events

Date Code Title Description
FG Grant or registration